

# **AM62x Processors Silicon Revision 1.0**

## **Texas Instruments Families of Products**

### *Technical Reference Manual*

---



Literature Number: SPRUV7B  
MAY 2022 – REVISED SEPTEMBER 2023



## Table of Contents

---



|                                                                            |    |
|----------------------------------------------------------------------------|----|
| <b>Read This First</b>                                                     | 11 |
| About This Manual                                                          | 11 |
| Glossary                                                                   | 11 |
| Related Documentation From Texas Instruments                               | 11 |
| Support Resources                                                          | 11 |
| Export Control Notice                                                      | 11 |
| <b>1 Introduction</b>                                                      | 12 |
| 1.1 Device Overview                                                        | 13 |
| 1.2 Functional Block Diagram                                               | 14 |
| 1.3 Module Allocation and Instances within Device Domains                  | 15 |
| 1.4 Device MAIN Domain                                                     | 15 |
| 1.4.1 Arm Cortex-A53 Subsystem (A53SS)                                     | 16 |
| 1.4.2 Programmable Real-Time Unit Subsystem (PRUSS)                        | 17 |
| 1.4.3 DDR 16-bit Subsystem (DDR16)                                         | 17 |
| 1.4.4 Region-based Address Translation Module (RAT)                        | 18 |
| 1.4.5 Data Movement Subsystem (DMSS)                                       | 18 |
| 1.4.6 Mailbox (MAILBOX)                                                    | 19 |
| 1.4.7 Spinlock (SPINLOCK)                                                  | 19 |
| 1.4.8 General Purpose Input/Output Interface (GPIO)                        | 19 |
| 1.4.9 Inter-Integrated Circuit Interface (I2C)                             | 19 |
| 1.4.10 Serial Peripheral Interface (SPI)                                   | 19 |
| 1.4.11 Universal Asynchronous Receiver/Transmitter (UART)                  | 20 |
| 1.4.12 3-port Gigabit Ethernet Switch (CPSW3G)                             | 20 |
| 1.4.13 Universal Serial Bus (USB) Subsystem 2.0                            | 20 |
| 1.4.14 General Purpose Memory Controller (GPMC)                            | 21 |
| 1.4.15 Error Location Module (ELM)                                         | 21 |
| 1.4.16 Flash Subsystem (FSS) with Octal Serial Peripheral Interface (OSPI) | 21 |
| 1.4.17 Multi-Media Card/Secure Digital Interface (MMCSD)                   | 22 |
| 1.4.18 Enhanced Capture Module (ECAP)                                      | 22 |
| 1.4.19 Enhanced Pulse-Width Modulation Module (EPWM)                       | 22 |
| 1.4.20 Enhanced Quadrature Encoder Pulse Module (EQEP)                     | 22 |
| 1.4.21 Controller Area Network (MCAN)                                      | 23 |
| 1.4.22 Timers                                                              | 23 |
| 1.4.23 Internal Diagnostics Modules                                        | 23 |
| 1.5 Device MCU Domain                                                      | 24 |
| 1.5.1 MCU Arm Cortex M4F Subsystem (MCU_M4FSS)                             | 25 |
| 1.5.2 MCU General Purpose Input/Output Interface (MCU_GPIO)                | 26 |
| 1.5.3 MCU Inter-Integrated Circuit Interface (MCU_I2C)                     | 26 |
| 1.5.4 MCU Multi-channel Serial Peripheral Interface (MCU_SPI)              | 26 |
| 1.5.5 MCU Universal Asynchronous Receiver/Transmitter (MCU_UART)           | 26 |
| 1.5.6 MCU Timers                                                           | 27 |
| 1.5.7 MCU Internal Diagnostics Modules                                     | 27 |
| 1.6 Device WKUP Domain                                                     | 28 |
| 1.6.1 Arm Cortex-R5F Processor (R5FSS)                                     | 28 |
| 1.7 Device Identification                                                  | 30 |
| <b>2 Memory Map</b>                                                        | 31 |
| 2.1 Memory Maps                                                            | 32 |
| 2.1.1 Memory Map                                                           | 32 |
| 2.2 SoC Address Aliasing                                                   | 46 |

|                                                               |           |
|---------------------------------------------------------------|-----------|
| 2.3 Processor Memory Map View.....                            | 46        |
| 2.3.1 A53 Memory View.....                                    | 46        |
| 2.3.2 HSM M4F Memory View.....                                | 47        |
| 2.3.3 MCU M4F Memory View.....                                | 48        |
| 2.3.4 WKUP R5 Memory View.....                                | 49        |
| 2.4 Memory Map Summary.....                                   | 51        |
| 2.5 MMU Optimization Note.....                                | 68        |
| <b>3 System Interconnect.....</b>                             | <b>70</b> |
| 3.1 System Interconnect Overview.....                         | 71        |
| 3.1.1 Domain Partition.....                                   | 71        |
| 3.1.2 IO Coherency Support.....                               | 72        |
| 3.1.3 Timeout Gasket.....                                     | 73        |
| 3.1.4 Route ID Allocation.....                                | 75        |
| 3.1.5 Quality of Service (QoS).....                           | 76        |
| 3.1.6 Initiator-Side Security Controls and Firewalls.....     | 81        |
| 3.1.7 Interconnect Error Reporting Feature.....               | 92        |
| 3.1.8 Connectivity Table.....                                 | 92        |
| 3.1.9 QoS Programming Guide.....                              | 95        |
| 3.1.10 Performance Considerations.....                        | 96        |
| <b>4 Module Integration.....</b>                              | <b>97</b> |
| 4.1 Memory Controllers.....                                   | 98        |
| 4.1.1 DDR16 Subsystem (DDR16SS).....                          | 99        |
| 4.2 Processors and Accelerators.....                          | 100       |
| 4.2.1 Arm Cortex A53 Subsystem (A53SS).....                   | 100       |
| 4.2.2 Arm Cortex R5F Subsystem (WKUP_R5FSS).....              | 104       |
| 4.2.3 Arm Cortex M4F Subsystem (MCU_M4FSS).....               | 106       |
| 4.2.4 Programmable Real-Time Unit Subsystem (PRUSS).....      | 107       |
| 4.3 Interprocessor Communication.....                         | 110       |
| 4.3.1 Mailbox.....                                            | 111       |
| 4.3.2 Spinlock.....                                           | 114       |
| 4.4 Device Configuration.....                                 | 115       |
| 4.4.1 Control Module (CTRL_MMR).....                          | 115       |
| 4.4.2 Pad Configuration Module (PADCFC_CTRL).....             | 116       |
| 4.5 Data Movement Architecture.....                           | 119       |
| 4.5.1 Data Movement Subsystem (DMSS).....                     | 120       |
| 4.5.2 Peripheral DMA (PDMA).....                              | 121       |
| 4.6 Audio.....                                                | 122       |
| 4.6.1 Multichannel Audio Serial Port (MCASP).....             | 122       |
| 4.7 General Connectivity.....                                 | 126       |
| 4.7.1 General Purpose Input/Output (GPIO).....                | 126       |
| 4.7.2 Inter-Integrated Circuit (I2C).....                     | 132       |
| 4.7.3 Multichannel Serial Peripheral Interface (MCSPI).....   | 137       |
| 4.7.4 Universal Asynchronous Receiver/Transmitter (UART)..... | 140       |
| 4.8 High-speed Serial Interfaces.....                         | 146       |
| 4.8.1 Gigabit Ethernet Switch (CPSW).....                     | 146       |
| 4.8.2 Universal Serial Bus Subsystem (USB).....               | 149       |
| 4.9 Memory Interfaces.....                                    | 151       |
| 4.9.1 Flash Subsystem (FSS).....                              | 151       |
| 4.9.2 Octal Serial Peripheral Interface (OSPI).....           | 152       |
| 4.9.3 General-Purpose Memory Controller (GPMC).....           | 154       |
| 4.9.4 Error Location Module (ELM).....                        | 155       |
| 4.9.5 Multimedia Card Secure Digital (MMCSD).....             | 156       |
| 4.10 Industrial and Control Interfaces.....                   | 158       |
| 4.10.1 Modular Controller Area Network (MCAN).....            | 158       |
| 4.10.2 Enhanced Capture (ECAP).....                           | 162       |
| 4.10.3 Enhanced Pulse Width Modulation (EPWM).....            | 164       |
| 4.10.4 Enhanced Quadrature Encoder Pulse (EQEP).....          | 167       |
| 4.11 Camera Subsystem.....                                    | 169       |
| 4.11.1 Camera Serial Interface Receiver (CSI_RX_IF).....      | 169       |
| 4.11.2 MIPI D-PHY Receiver (DPHY_RX).....                     | 171       |
| 4.12 Timer Modules.....                                       | 172       |

|                                                     |            |
|-----------------------------------------------------|------------|
| 4.12.1 Global Timebase Counter (GTC).....           | 172        |
| 4.12.2 Real Time Interrupt (RTI).....               | 174        |
| 4.12.3 Real-Time Clock (RTC).....                   | 178        |
| 4.12.4 Timer.....                                   | 179        |
| 4.13 Internal Diagnostic Modules.....               | 190        |
| 4.13.1 Dual Clock Comparator (DCC).....             | 190        |
| 4.13.2 Error Signaling Module (ESM).....            | 199        |
| 4.13.3 Memory Cyclic Redundancy Check (MCRC64)..... | 201        |
| 4.13.4 ECC Aggregator (ECC_AGGR).....               | 203        |
| 4.14 Graphics Processing Unit (GPU).....            | 466        |
| 4.14.1 GPU Unsupported Features.....                | 466        |
| 4.14.2 Module Allocations.....                      | 466        |
| 4.14.3 Resets, Interrupts, and Clocks.....          | 466        |
| 4.15 Display Subsystem (DSS).....                   | 467        |
| 4.15.1 DSS_UL Unsupported Features.....             | 467        |
| 4.15.2 Module Allocations.....                      | 467        |
| 4.15.3 Resets, Interrupts, and Clocks.....          | 467        |
| 4.15.4 OLDI_TX Integration Features.....            | 468        |
| 4.16 Spinlock.....                                  | 469        |
| 4.16.1 SPINLOCK Unsupported Features.....           | 469        |
| 4.16.2 Module Allocations.....                      | 469        |
| 4.16.3 Resets, Interrupts, and Clocks.....          | 469        |
| <b>5 Initialization.....</b>                        | <b>470</b> |
| 5.1 Initialization Overview.....                    | 471        |
| 5.1.1 ROM Code Overview.....                        | 471        |
| 5.1.2 Bootloader Modes.....                         | 471        |
| 5.1.3 Terminology.....                              | 472        |
| 5.2 Boot Process.....                               | 474        |
| 5.2.1 Public ROM Code Architecture.....             | 474        |
| 5.2.2 M4 ROM Description.....                       | 475        |
| 5.2.3 Boot Process Flow.....                        | 475        |
| 5.3 Boot Mode Pins.....                             | 479        |
| 5.3.1 BOOTMODE Pin Mapping.....                     | 480        |
| 5.4 Boot Modes.....                                 | 481        |
| 5.4.1 OSPI\xSPI\QSPI\SPI Boot.....                  | 482        |
| 5.4.2 I2C Boot.....                                 | 489        |
| 5.4.3 SD Card Boot.....                             | 490        |
| 5.4.4 eMMC Boot.....                                | 492        |
| 5.4.5 Ethernet Boot.....                            | 494        |
| 5.4.6 USB Boot.....                                 | 498        |
| 5.4.7 UART Boot.....                                | 499        |
| 5.4.8 GPMC NOR Boot.....                            | 501        |
| 5.4.9 GPMC NAND Boot.....                           | 503        |
| 5.4.10 Serial NAND Boot.....                        | 504        |
| 5.4.11 No boot/Development boot.....                | 506        |
| 5.5 PLL Configuration.....                          | 507        |
| 5.6 Boot Parameter Tables.....                      | 509        |
| 5.6.1 Common Header.....                            | 509        |
| 5.6.2 PLL Setup.....                                | 510        |
| 5.6.3 OSPI/QSPI/SPI Boot Parameter Table.....       | 511        |
| 5.6.4 UART Boot Parameter Table.....                | 512        |
| 5.6.5 I2C Boot Parameter Table.....                 | 512        |
| 5.6.6 MMCSD/eMMC Boot Parameter Table.....          | 513        |
| 5.6.7 Ethernet Boot Parameter Table.....            | 514        |
| 5.6.8 xSPI Boot Parameter Table.....                | 515        |
| 5.6.9 USB DFU Boot Parameter Table.....             | 516        |
| 5.6.10 USB MSC Boot Parameter Table.....            | 516        |
| 5.6.11 GPMC NOR Boot Parameter Table.....           | 517        |
| 5.6.12 GPMC NAND Boot Parameter Table.....          | 517        |
| 5.7 Boot Image Format.....                          | 519        |
| 5.7.1 Overall Structure.....                        | 519        |

|                                                             |            |
|-------------------------------------------------------------|------------|
| 5.7.2 X.509 Certificate.....                                | 519        |
| 5.7.3 Organizational Identifier (OID).....                  | 519        |
| 5.7.4 X.509 Extensions Specific to Boot.....                | 520        |
| 5.7.5 Extended Boot Info Extension.....                     | 520        |
| 5.7.6 Generating X.509 Certificates.....                    | 523        |
| 5.8 Boot Memory Maps.....                                   | 526        |
| 5.8.1 Global Memory Addresses Used by ROM Code.....         | 526        |
| <b>6 Device Configuration.....</b>                          | <b>527</b> |
| 6.1 Memory Mapped Control Register Modules (CTRL_MMR).....  | 528        |
| 6.1.1 General Purpose Control Register Modules.....         | 529        |
| 6.1.2 Pad Configuration Register Modules.....               | 532        |
| 6.1.3 Security Control Register Modules.....                | 533        |
| 6.2 Power.....                                              | 533        |
| 6.2.1 Power Management Overview.....                        | 533        |
| 6.2.2 Power Control Modules.....                            | 533        |
| 6.2.3 Power Management Techniques.....                      | 543        |
| 6.2.4 Power Modes.....                                      | 543        |
| 6.2.5 Power Supply Modules.....                             | 550        |
| 6.3 Reset.....                                              | 569        |
| 6.3.1 Overview.....                                         | 571        |
| 6.3.2 Reset Sources.....                                    | 583        |
| 6.3.3 Reset Status.....                                     | 584        |
| 6.3.4 Reset Controls.....                                   | 587        |
| 6.3.5 Reset Details.....                                    | 590        |
| 6.4 Clocking.....                                           | 614        |
| 6.4.1 Overview.....                                         | 614        |
| 6.4.2 Clock Inputs.....                                     | 615        |
| 6.4.3 Clock Outputs.....                                    | 616        |
| 6.4.4 Device Oscillators.....                               | 619        |
| 6.4.5 PLLs.....                                             | 622        |
| <b>7 Processors and Accelerators.....</b>                   | <b>642</b> |
| 7.1 Arm Cortex-A53 Subsystem (A53SS).....                   | 643        |
| 7.1.1 A53SS Overview.....                                   | 644        |
| 7.1.2 A53SS Functional Description.....                     | 646        |
| 7.2 Device Manager Cortex R5F Subsystem (WKUP_R5FSS).....   | 652        |
| 7.2.1 WKUP_R5FSS Overview.....                              | 652        |
| 7.2.2 WKUP_R5FSS Functional Description.....                | 654        |
| 7.2.3 Vectored Interrupt Manager (VIM).....                 | 673        |
| 7.3 Cortex-M4F Subsystem (MCU_M4FSS).....                   | 684        |
| 7.3.1 MCU_M4FSS Overview.....                               | 685        |
| 7.3.2 MCU_M4FSS Functional Description.....                 | 686        |
| 7.4 Programmable Real-Time Unit Subsystem (PRUSS).....      | 698        |
| 7.4.1 PRUSS Overview.....                                   | 698        |
| 7.4.2 PRUSS Environment.....                                | 700        |
| 7.4.3 PRUSS Top Level Resources Functional Description..... | 707        |
| 7.4.4 PRUSS PRU Cores.....                                  | 712        |
| 7.4.5 PRUSS Broadside Accelerators.....                     | 742        |
| 7.4.6 PRUSS Local INTc.....                                 | 754        |
| 7.4.7 PRUSS UART Module.....                                | 760        |
| 7.4.8 PRUSS ECAP Module.....                                | 775        |
| 7.4.9 PRUSS IEP.....                                        | 776        |
| <b>8 Interprocessor Communication (IPC).....</b>            | <b>786</b> |
| 8.1 Inter-processor Communication Scheme (IPC).....         | 787        |
| 8.1.1 Mailbox.....                                          | 788        |
| 8.1.2 Spinlock.....                                         | 795        |
| 8.1.3 Secure Proxy (SEC_PROXY).....                         | 800        |
| <b>9 Memory Controllers.....</b>                            | <b>801</b> |
| 9.1 DDR Subsystem (DDRSS).....                              | 802        |
| 9.1.1 DDRSS Overview.....                                   | 802        |
| 9.1.2 DDRSS Environment.....                                | 805        |
| 9.1.3 DDRSS Functional Description.....                     | 807        |

|                                                                |             |
|----------------------------------------------------------------|-------------|
| 9.2 Region-based Address Translation (RAT) Module.....         | 817         |
| 9.2.1 RAT Functional Description.....                          | 817         |
| <b>10 Interrupts.....</b>                                      | <b>819</b>  |
| 10.1 Interrupt Architecture.....                               | 820         |
| 10.1.1 ESM Connectivity.....                                   | 821         |
| 10.1.2 Events.....                                             | 830         |
| 10.1.3 Interrupt Router (INTROUTER).....                       | 833         |
| 10.1.4 Time Synchronization Support.....                       | 833         |
| 10.1.5 GPIO Interrupt Handling.....                            | 835         |
| 10.1.6 Utilizing Miscellaneous Signals as Interrupt.....       | 841         |
| 10.1.7 Interrupt Connections for MCUSS NVIC.....               | 844         |
| 10.1.8 Interrupt Connections for GICSS.....                    | 846         |
| 10.1.9 Interrupt Connections for R5FSS.....                    | 853         |
| 10.1.10 Interrupt Connection for HSM.....                      | 859         |
| 10.1.11 Interrupt Connection for ICSSM.....                    | 862         |
| 10.1.12 Interrupt Connections Summary.....                     | 864         |
| <b>11 Data Movement Architecture.....</b>                      | <b>866</b>  |
| 11.1 Data Movement Architecture Overview.....                  | 867         |
| 11.1.1 Overview.....                                           | 867         |
| 11.1.2 Definition of Terms.....                                | 881         |
| 11.1.3 DMSS Hardware/Software Interface.....                   | 883         |
| 11.1.4 Operational Description.....                            | 910         |
| 11.2 Data Movement Subsystem (DMSS).....                       | 928         |
| 11.2.1 Data Movement Subsystem (DMSS).....                     | 929         |
| 11.2.2 Ring Accelerator (RINGACC).....                         | 932         |
| 11.2.3 Secure Proxy (SEC_PROXY).....                           | 943         |
| 11.2.4 Interrupt Aggregator (INTAGGR).....                     | 949         |
| 11.2.5 Packet Streaming Interface Link (PSI-L).....            | 954         |
| 11.3 Peripheral DMA (PDMA).....                                | 958         |
| 11.3.1 PDMA Controller.....                                    | 958         |
| <b>12 Peripherals.....</b>                                     | <b>1023</b> |
| 12.1 Audio Peripherals.....                                    | 1024        |
| 12.1.1 Multichannel Audio Serial Port (MCASP).....             | 1025        |
| 12.2 General Connectivity Peripherals.....                     | 1098        |
| 12.2.1 General-Purpose Interface (GPIO).....                   | 1099        |
| 12.2.2 Inter-Integrated Circuit (I2C) Interface.....           | 1108        |
| 12.2.3 Multichannel Serial Peripheral Interface (MCSPI).....   | 1135        |
| 12.2.4 Universal Asynchronous Receiver/Transmitter (UART)..... | 1184        |
| 12.3 High-speed Serial Interfaces.....                         | 1243        |
| 12.3.1 Gigabit Ethernet Switch (CPSW3G).....                   | 1244        |
| 12.3.2 Universal Serial Bus Subsystem (USBSS).....             | 1346        |
| 12.4 Memory Interfaces.....                                    | 1351        |
| 12.4.1 Flash Subsystem (FSS).....                              | 1352        |
| 12.4.2 Octal Serial Peripheral Interface (OSPI).....           | 1357        |
| 12.4.3 General-Purpose Memory Controller (GPMC).....           | 1386        |
| 12.4.4 Error Location Module (ELM).....                        | 1495        |
| 12.4.5 Multi-Media Card Secure Digital (MMCSD) Interface.....  | 1505        |
| 12.5 Industrial and Control Interfaces.....                    | 1578        |
| 12.5.1 Modular Controller Area Network (MCAN).....             | 1579        |
| 12.5.2 Enhanced Capture (ECAP) Module.....                     | 1616        |
| 12.5.3 Enhanced Pulse Width Modulation (EPWM) Module.....      | 1645        |
| 12.5.4 Enhanced Quadrature Encoder Pulse (EQEP) Module.....    | 1706        |
| 12.6 Camera Subsystem.....                                     | 1731        |
| 12.6.1 Camera Serial Interface Receiver (CSI_RX_IF).....       | 1732        |
| 12.6.2 MIPI D-PHY Receiver (DPHY_RX).....                      | 1754        |
| 12.7 Timer Modules.....                                        | 1762        |
| 12.7.1 Global Timebase Counter (GTC).....                      | 1762        |
| 12.7.2 RTI-Windowed Watchdog Timer (WWDT).....                 | 1764        |
| 12.7.3 Real-Time Clock (RTC).....                              | 1771        |
| 12.7.4 Timers.....                                             | 1785        |
| 12.8 Internal Diagnostics Modules.....                         | 1808        |

|                                                              |             |
|--------------------------------------------------------------|-------------|
| 12.8.1 Dual Clock Comparator (DCC).....                      | 1808        |
| 12.8.2 Error Signaling Module (ESM).....                     | 1815        |
| 12.8.3 Memory Cyclic Redundancy Check (MCRC) Controller..... | 1829        |
| 12.8.4 ECC Aggregator.....                                   | 1843        |
| 12.9 Display Subsystem (DSS) and Peripherals.....            | 1923        |
| 12.9.1 Display Subsystem (DSS).....                          | 1924        |
| 12.9.2 Graphics Processing Unit (GPU).....                   | 2013        |
| <b>13 On-Chip Debug.....</b>                                 | <b>2015</b> |
| 13.1 On-Chip Debug Overview.....                             | 2016        |
| 13.2 On-Chip Debug Features.....                             | 2016        |
| 13.3 On-Chip Debug Functional Description.....               | 2017        |
| 13.3.1 On-Chip Debug Block Diagram.....                      | 2017        |
| 13.3.2 Device Interfaces.....                                | 2018        |
| 13.3.3 Debug and Boundary Scan Access and Control.....       | 2018        |
| 13.3.4 Debug Boot Modes and Boundary Scan Compliance.....    | 2019        |
| 13.3.5 Power, Reset, Clock Management.....                   | 2020        |
| 13.3.6 Debug Cross Triggering.....                           | 2020        |
| 13.3.7 WKUP_R5F Debug.....                                   | 2021        |
| 13.3.8 SMS0_HSM and MCU_M4F Debug.....                       | 2022        |
| 13.3.9 A53SS0 Debug.....                                     | 2023        |
| 13.3.10 PRUSS Debug.....                                     | 2024        |
| 13.3.11 SoC Debug and Trace.....                             | 2024        |
| 13.3.12 Trace Traffic.....                                   | 2027        |
| 13.3.13 Application Support.....                             | 2028        |
| <b>14 Registers.....</b>                                     | <b>2029</b> |
| 14.1 System Interconnect Registers.....                      | 2030        |
| 14.1.1 CBASS Registers.....                                  | 2031        |
| 14.1.2 CBASS_CENTRAL Registers.....                          | 3791        |
| 14.1.3 CBASS_DBG Registers.....                              | 4016        |
| 14.1.4 CBASS_FW Registers.....                               | 4030        |
| 14.1.5 CBASS_INFRA Registers.....                            | 4044        |
| 14.1.6 CBASS_IPCSS Registers.....                            | 4058        |
| 14.1.7 CBASS_MCASP Registers.....                            | 4264        |
| 14.1.8 CBASS_MISC_PERI Registers.....                        | 4278        |
| 14.1.9 CBASS_SAFE Registers.....                             | 4292        |
| 14.2 Device Configuration Registers.....                     | 4305        |
| 14.2.1 CTRL_MMR Registers.....                               | 4305        |
| 14.2.2 Power Registers.....                                  | 5966        |
| 14.2.3 Clocking Registers.....                               | 6092        |
| 14.3 Processors and Accelerators Registers.....              | 6241        |
| 14.3.1 A53SS Registers.....                                  | 6241        |
| 14.3.2 M4FSS Registers.....                                  | 7911        |
| 14.3.3 R5FSS Registers.....                                  | 7935        |
| 14.3.4 VIM Registers.....                                    | 7970        |
| 14.3.5 PRUSS Registers.....                                  | 7978        |
| 14.3.6 GPU Registers.....                                    | 8486        |
| 14.4 Interprocessor Communication Registers.....             | 8535        |
| 14.4.1 MAILBOX_CLUSTER_0 Registers.....                      | 8536        |
| 14.4.2 SPINLOCK Registers.....                               | 8552        |
| 14.5 Memory Controller Registers.....                        | 8557        |
| 14.5.1 ROM Registers.....                                    | 8558        |
| 14.5.2 PSRAMECC Registers.....                               | 8560        |
| 14.5.3 PSRAMECC_16K Registers.....                           | 8578        |
| 14.5.4 DDR16SS Registers.....                                | 8596        |
| 14.6 Interrupt Router Registers.....                         | 9967        |
| 14.6.1 GICSS Registers.....                                  | 9968        |
| 14.6.2 MAIN_GPIOMUX_INTROUTER Registers.....                 | 10903       |
| 14.6.3 MCU_GPIOMUX_INTROUTER Registers.....                  | 10906       |
| 14.6.4 CMP_EVENT_INTROUTER Registers.....                    | 10909       |
| 14.6.5 TIMESYNC_EVENT_ROUTER Registers.....                  | 10912       |
| 14.7 DMA Controller Registers.....                           | 10914       |

|                                                         |              |
|---------------------------------------------------------|--------------|
| 14.7.1 DMASS_BCDMA_0 Registers.....                     | 10915        |
| 14.7.2 DMASS_INTAGGR_0 Registers.....                   | 11023        |
| 14.7.3 DMASS_PKTDMA_0 Registers.....                    | 11054        |
| 14.7.4 DMASS_PSILCFG_0 Registers.....                   | 11144        |
| 14.7.5 DMASS_PSILSS_0 Registers.....                    | 11151        |
| 14.7.6 DMASS_RINGACC_0 Registers.....                   | 11162        |
| 14.7.7 DMASS_SEC_PROXY_0 Registers.....                 | 11178        |
| 14.7.8 PDMA Registers.....                              | 11194        |
| 14.8 Peripherals Registers.....                         | 11210        |
| 14.8.1 Audio Registers.....                             | 11210        |
| 14.8.2 General Connectivity Registers.....              | 11337        |
| 14.8.3 High-speed Serial Interfaces Registers.....      | 11569        |
| 14.8.4 Memory Interfaces Registers.....                 | 12451        |
| 14.8.5 Industrial and Control Interfaces Registers..... | 12976        |
| 14.8.6 Camera Subsystem Registers.....                  | 13168        |
| 14.8.7 Timer Modules Registers.....                     | 13312        |
| 14.8.8 Internal Diagnostics Modules Registers.....      | 13425        |
| 14.8.9 Display Subsystem Registers.....                 | 13693        |
| 14.9 On-Chip Debug Registers.....                       | 14103        |
| 14.9.1 DEBUGSS Registers.....                           | 14104        |
| 14.9.2 DEBUGSS_WRAP Registers.....                      | 14911        |
| 14.9.3 DBGSUSPENDROUTER Registers.....                  | 15780        |
| 14.9.4 PBIST Registers.....                             | 15783        |
| <b>15 Revision History.....</b>                         | <b>15861</b> |

This page intentionally left blank.



## About This Manual

This Technical Reference Manual (TRM) details the integration, the environment, the functional description, and the programming models for each peripheral and subsystem in the device.

## Glossary

[TI Glossary](#) This glossary lists and explains terms, acronyms, and definitions.

## Related Documentation From Texas Instruments

For a complete listing of related documentation and development-support tools for the device, visit the Texas Instruments website at [www.ti.com](http://www.ti.com).

Below are some direct links to additional documentation:

- [AM62x Datasheet](#)
- [AM62x Schematic Review Checklist](#)

## Support Resources

[TI E2E™ support forums](#) are an engineer's go-to source for fast, verified answers and design help — straight from the experts. Search existing answers or ask your own question to get the quick design help you need.

Linked content is provided "AS IS" by the respective contributors. They do not constitute TI specifications and do not necessarily reflect TI's views; see TI's [Terms of Use](#).

## Trademarks

TI E2E™ and are trademarks of Texas Instruments.

MPCore™ and CoreSight™ are trademarks of Arm.

Neon™ is a trademark of Arm Limited (or its subsidiaries) in the US and/or elsewhere.

Arm®, Thumb®, and are registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere.

ARM® and Cortex® are registered trademarks of ARM Ltd..

TrustZone® are registered trademarks of Arm.

is a registered trademark of Texas Instruments.

All trademarks are the property of their respective owners.

## Export Control Notice

Recipient agrees to not knowingly export or re-export, directly or indirectly, any product or technical data (as defined by the U.S., EU, and other Export Administration Regulations) including software, or any controlled product restricted by other applicable national regulations, received from disclosing party under nondisclosure obligations (if any), or any direct product of such technology, to any destination to which such export or re-export is restricted or prohibited by U.S. or other applicable laws, without obtaining prior authorization from U.S. Department of Commerce and other competent Government authorities to the extent required by those laws.

# Chapter 1

## Introduction

---



This chapter introduces the features, subsystems, and architecture of the AM62x Sitara Processor Platform high-performance System-on-Chip (SoC).

---

### Note

This document describes the Superset architecture, processors and peripherals of the AM62x Family of SoCs, which are part of the AM62x Multicore SoC architecture platform. Not all features are available on each family of devices. The superset AM623 and AM625 (each of which will have a single, dual and quad core option) devices are available for preproduction software development. Software should constrain the features used to match the intended production device. For more information on the specific features, processors and peripherals available on a particular device, refer to the Device Comparison table in the corresponding device-specific Data sheet.

The AM62x Sitara Processor Platforms are hereinafter commonly referred to as *AM62x platform*, *device*, or *SoC*.

---

|                                                                |    |
|----------------------------------------------------------------|----|
| 1.1 Device Overview.....                                       | 13 |
| 1.2 Functional Block Diagram.....                              | 14 |
| 1.3 Module Allocation and Instances within Device Domains..... | 15 |
| 1.4 Device MAIN Domain.....                                    | 15 |
| 1.5 Device MCU Domain.....                                     | 24 |
| 1.6 Device WKUP Domain.....                                    | 28 |
| 1.7 Device Identification.....                                 | 30 |

## 1.1 Device Overview

This section gives overview

## 1.2 Functional Block Diagram

Figure 1-1 is functional block diagram for the device.

### Note

To understand what device features are currently supported by TI Software Development Kits (SDKs), see the *AM62x Software Build Sheet*.



Figure 1-1. Functional Block Diagram

## 1.3 Module Allocation and Instances within Device Domains

| Module Full Name                                                             | Module Abbreviation | Device Domain |      |      |
|------------------------------------------------------------------------------|---------------------|---------------|------|------|
|                                                                              |                     | MCU           | MAIN | WKUP |
| Quad-Core Arm Cortex A53 Subsystem                                           | A53SS               | -             | 1    | -    |
| Single-Core Arm Cortex-R5F Subsystem                                         | R5FSS               | -             | -    | 1    |
| Arm Cortex-M4F Subsystem                                                     | M4FSS               | 1             | -    | -    |
| Programmable Real-Time Unit and Industrial Communication Subsystem - Megabit | PRUSS_M             | -             | 1    | -    |
| Interprocessor Communication - Mailbox                                       | Mailbox             | -             | 1    | -    |
| Interprocessor Communication - Spinlock                                      | Spinlock            | -             | 1    | -    |
| Dual Data Rate Random Access Memory (16-Bit) Subsystem                       | DDRSS               | -             | 1    | -    |
| Region-based Address Translation                                             | RAT                 | 1             | 2    | 1    |
| Data Movement Subsystem                                                      | DMSS                | -             | 1    | -    |
| Peripheral DMA                                                               | PDMA                | -             | 3    | -    |
| Common Platform Time Sync Module                                             | CPTS                | -             | 1    | -    |
| General Purpose Input/Output                                                 | GPIO                | 1             | 2    | -    |
| Inter-Integrated Circuit                                                     | I2C                 | 1             | 4    | 1    |
| Multi-channel Serial Peripheral Interface                                    | MCSPI               | 2             | 3    | -    |
| Universal Asynchronous Receiver/Transmitter                                  | UART                | 1             | 7    | 1    |
| 2 Port Gigabit Ethernet Switch                                               | CPSW                | -             | 1    | -    |
| Universal Serial Bus Subsystem                                               | USB                 | -             | 2    | -    |
| Enhanced Pulse Width Modulation Module                                       | EPWM                | -             | 3    | -    |
| Enhanced Quadrature Encoder Pulse Module                                     | EQEP                | -             | 3    | -    |
| Enhanced Capture Module                                                      | ECAP                | -             | 3    | -    |
| Controller Area Network Interface                                            | MCAN                | 2             | 1    | -    |
| Flash Memory Subsystem                                                       | FSS                 | -             | 1    | -    |
| Octal Serial Peripheral Interface                                            | OSPI                | -             | 1    | -    |
| General Purpose Memory Controller                                            | GPMC                | -             | 1    | -    |
| Error Location Module                                                        | ELM                 | -             | 1    | -    |
| Multi-Media Card/Secure Digital Interface                                    | MMCSD               | -             | 3    | -    |
| Global Time Counter                                                          | GTC                 | -             | -    | 1    |
| Real Time Interrupt/Windowed WatchDog Timer                                  | RTI/WWDT            | 1             | 5    | 1    |
| Dual-Mode Timer                                                              | TIMER               | 4             | 8    | 2    |
| Real-Time Clock                                                              | RTC                 | -             | -    | 1    |
| Dual Clock Comparator                                                        | DCC                 | 2             | 7    | -    |
| Error Signaling Module                                                       | ESM                 | -             | 1    | 1    |
| Memory Cyclic Redundancy Check Controller                                    | MCRC                | 1             | 1    | -    |
| Multi-channel Audio Serial Port                                              | McASP               | -             | 3    | -    |
| Camera Serial Interface Receiver                                             | CSI-RX              | -             | 1    | -    |
| MIPi D-PHY Receiver                                                          | DPHY_RX             | -             | 1    | -    |
| Display Subsystem                                                            | DSS                 | -             | 1    | -    |
| 3D Graphics Processing Unit                                                  | GPU                 | -             | 1    | -    |

## 1.4 Device MAIN Domain

This section describes the modules integrated in the device MAIN domain.



**Figure 1-2. AM62x MAIN Domain Functional Block Diagram**

#### 1.4.1 Arm Cortex-A53 Subsystem (A53SS)

The integrated 64-bit Arm Cortex-A53 subsystem (A53SS) supports the following main features:

- Up to a quad-core Arm Cortex-A53 MPCore processor with L1 memory system and a single shared L2 cache.
- Full Arm®v8-A architecture compliancy
- Advanced Single Instruction Multiple Data (SIMD) and floating point extension (Arm® Neon™)
- Floating-Point Unit (FPU) VFPv4
- Armv8 Cryptography Extensions
- Arm General Interrupt Controller (GICv3) architecture
- In-order pipeline with symmetric dual-issue of most instructions
- 32KB program and 32KB data Level 1 (L1) Cache
- 512KB shared Level 2 (L2) Cache

- Support for up to four timers within each Cortex-A53 core
- Arm® CoreSight™ Debug and Trace Architecture
- ECC protection for L1 data cache and L2 Cache
- Parity protection for L1 Instruction Cache
- 128-bit wide, synchronous or asynchronous VBUSM initiator interface
- Dedicated RTI windowed watchdog timer per core
- Support for Big-Endian (BE) and Little-Endian (LE) at core level
- Interface with Arm GIC-500 Interrupt Controller (SoC level, not part of A53SS)
- Advanced power management for low power optimization

#### **1.4.2 Programmable Real-Time Unit Subsystem (PRUSS)**

Integrated in MAIN domain: Two instances of the Programmable Real-Time Unit Subsystem used primarily for driving GPIO for cycle accurate protocols such as additional UARTS, I2C and external ADC.

MAIN domain encompasses two identical PRUSS subsystems, each supporting the following main features, among others:

- Two Programmable Real-time Unit Subsystems (PRUSS):
  - PRU:
    - Asynchronous capture (Serial Capture Unit (SCU)] with EnDat 2.2 protocol and Sigma-Delta demodulation support
    - 20 Enhanced General Purpose Inputs (EGPI) and 20 Enhanced General Purpose Outputs (EGPO)
    - 12 KB program memory per PRU (PRU0\_IRAM and PRU1\_IRAM) with ECC
    - CRC16/CRC32 HW accelerator
    - RX XFR2VBUS
  - Scratchpad Memory (SPAD) with 2 banks of 30 x 32-bit registers
    - 3 banks for the PRU0 and PRU1 cores
    - 32KB shared general purpose RAM with ECC, shared between PRU0 and PRU1
    - Two 8KB (shared) Data Memories with ECC (one per slice)
    - 36-bit VBUSM Controller Port
      - Optional address translation for all transactions to External Host
  - 16 Software Events generated by 2 PRUs
  - One Enhanced Capture (ECAP) module
  - One interrupt controller (INTC)
    - Up to 32 internal events, generated by modules, internal to the PRUSS
    - Up to 32 external events, generated by the system
    - Supports up to 10 interrupt channels
    - Generation of 18 Host interrupts
      - 2 Host interrupts tp PRU0, PRU1
      - 8 Host interrupts, exported from the PRUSS for signaling the Arm interrupt controllers (pulse and level provided)
    - Each system event can be enabled and disabled
    - Each host event can be enabled and disabled
    - Hardware prioritization of events
  - One 32-bit VBUSP target port for memory mapped register and internal memories access
  - Flexible power management support
  - Integrated 32-bit interconnect

#### **1.4.3 DDR 16-bit Subsystem (DDR16)**

Integrated in MAIN domain: One instance of DDR 16-bit Subsystem (DDR16) (also referred to as DDRSS) is used as an interface to external SDRAM devices which can be utilized for storing program or data. The DDRSS provides the following main features:

- Support of LPDDR4 memory type (up to 1600Mbps)
- Support of DDR4 memory type (up to 1600Mbps)

- 16-bit memory bus interface with in-line ECC
- Up to 8 GB memory address range
- Support of dual rank configuration
- Support of automatic idle power saving mode when no or low activity is detected
- Class of Service (CoS) - three latency classes supported
- Dynamic change of refresh reach via SW for extended temperatures
- Prioritized refresh scheduling
- Statistical counters for performance management

#### 1.4.4 Region-based Address Translation Module (RAT)

Integrated in MAIN domain: One instance of the Region-based Address Translation (RAT) module to perform a region based address translation of a 32-bit input address into a 36-bit output address. The RAT module provides the following main features:

- 4 regions with dedicated registers for attributes configuration:
  - Region base address
  - Region size
  - Translated base address
- Address translation for only enabled regions
- Region boundary crossing transactions error generation

#### 1.4.5 Data Movement Subsystem (DMSS)

Integrated in the MAIN domain: One Data Movement subsystem named DMSS can be used for efficient transfer of data support between software, firmware and hardware in all combinations. It consists of the following main modules:

- Packet DMA Controller
- Block Copy DMA Controller
- Ring Accelerator provides hardware acceleration to enable straightforward passing of work between a producer and a consumer and has the following main features:
  - Supports up to 20 independent memory-mapped ring structures
  - Supports various modes for each ring based on usage and compatibility
  - Provides single-word deep shared incoming Transfer Response FIFO
  - Provides bit-wide source VBUSM read/write target interface for accesses from DMA controller entities
- Secure proxy module is a modified version of the proxy module and in addition has the following main features:
  - Provides proxy function to store large data bursts that a host can only access in smaller amounts
  - Supports a configurable number of threads, where each has their own independent proxy function
  - Keeps the large data burst coherent until the complete data has been accessed
  - Allows for interleaved access between multiple hosts or tasks using multiple proxy threads
  - Supports a configurable target resource. The target has a configurable number of channels, size of each channel and base address
  - Supports a programmable fixed queue for each proxy thread
  - Supports multiple producers all writing to the same queue
  - Supports programmable thresholds for when to generate events
  - Supports a max message count for outbound proxy threads limiting the number of messages a thread can produce
  - Optionally supports dynamic clock gating
- Interrupt Aggregator modules provide a centralized machine which handles the termination of system events to that they can be coherently processed by the host(s) in the system. Main features are as follows:
  - 64-bit VBUSP target using 64-bit registers
  - Provide a set of TI Interrupt Architecture compliant interrupt status and mask registers which are used to pass specific event status to one or more host blocks.

- Provides an optional set of Unmapped event (UNMAP) which can take an 'unmapped' event from the ingress ETL and generate a Global event on the egress Event Transport Lane (ETL) interface.
- Provides an optional set of Global Event Input (GEVI) counters which can count events delivered via an ingress Event Transport Lane (ETL)
- Provides an optional set of Local Event Input (LEVI) to Global event registers which can be used to convert pulsed discrete interrupt inputs or clock synchronous rising edge events into Global events on an egress ETL
- Provides an optional set of Global Event Input (GEVI) 'Multicast' registers which can take a Global event from an ingress ETL and generate two egress Global events on two egress ETL interfaces

#### **1.4.6 Mailbox (MAILBOX)**

Integrated in MAIN domain: One Mailbox (MAILBOX) module to facilitate the communication between the various on-chip processor cores of the device by providing a queued mailbox-interrupt mechanism with the following main features:

- 1x clusters
- 32-bit message width
- Message reception and queue-not-full notification using interrupts
- Non-intrusive emulation

#### **1.4.7 Spinlock (SPINLOCK)**

One Spinlock module with (256 hardware semaphores) for synchronizing the processes running on multiple cores in the device.

#### **1.4.8 General Purpose Input/Output Interface (GPIO)**

Integrated in MAIN domain: Two General Purpose Input/Output (GPIO) modules that provide dedicated general-purpose pins that can be configured as either inputs or outputs. The GPIO modules main features include:

- Support of 9 banks x 16 GPIO pins
- Support of up to 9 banks of interrupt capable GPIOs
- Interrupts can be triggered by rising and/or falling edge, specified for each interrupt capable GPIO pin
- Set/clear functionality per individual GPIO pin

#### **1.4.9 Inter-Integrated Circuit Interface (I2C)**

Integrated in MAIN domain: Four instances of the multi-controller Inter-Integrated Circuit (I2C) interface module, each with the following main features:

- 1x Instances with open-drain voltage buffers in compliance with the Philips I2C-bus specification version 2.1
- Support of standard mode (up to 100 Kbps) and fast mode (up to 400 Kbps)
- Support of 7-bit and 10-bit device addressing modes
- 8-bit-wide data access
- Support of multi-controller transmitter/peripheral receiver and receiver/peripheral transmitter modes
- Built-in FIFOs with fixed size of 32 bytes.
- Support of Auto Idle, Idle Request/Idle Acknowledge handshake, and Asynchronous wake-up mechanisms
- Low power consumption

#### **1.4.10 Serial Peripheral Interface (SPI)**

Integrated in MAIN domain: Three instances of the Serial Peripheral Interface (SPI) module with the following main features:

- Serial clock with programmable frequency, polarity, and phase for each channel
- Wide selection of SPI word lengths, ranging from 4 to 32 bits
- Up to four channels in controller mode, or single channel in receiver mode
- Support for various controller multichannel modes
- Single interrupt line for multiple interrupt source events
- Support of start-bit write command
- Support of start-bit pause and break sequence

- Built-in FIFO available for a single channel

#### **1.4.11 Universal Asynchronous Receiver/Transmitter (UART)**

Instances of the configurable Universal Asynchronous Receiver/Transmitter (UART) interface module have the following main features:

- 16C750-compatible interface
- Support of RS-485 external transceiver auto flow control
- Dual 64-byte FIFOs – one per each received and transmitted data paths
- Programmable and selectable transmit and receive FIFO trigger levels for DMA and interrupt generation
- Programmable sleep mode
- Baud-rate from 300 bits/s up to 3.6864 Mbits/s with 48 MHz functional clock
- Auto-baud between 1200 bits/s and 115.2 Kbits/s (only when 48 MHz function clock is used)
- Support of IrDA 1.4 Slow Infrared (SIR), Medium Infrared (MIR), and Fast Infrared (FIR) communications
- Support of Consumer Infrared Remote control mode (CIR) with programmable data encoding

##### **Note**

Only one UART instance has support for support full modem control functions. All other UART instances will support only the TX, RX, RTS, and CTS signals.

#### **1.4.12 3-port Gigabit Ethernet Switch (CPSW3G)**

Integrated in MAIN domain: One instance of the 3-port Gigabit Ethernet Switch (CPSW3G) subsystem provides Ethernet packet communication for the device. The CPSW3G subsystem provides the following main features:

- Two external Ethernet ports with selectable RGMII and RMII interfaces and one internal Communications Port Programming Interface (CPPI) port.
- Synchronous 10/100/1000 Mbit operation
- Flexible logical FIFO-based packet buffer structure
- Support of eight priority level Quality Of Service (QOS) - 802.1p
- Support for Audio/Video Bridging (P802.1Qav/D6.0 and 802.1Qaz)
- Ethernet port reset isolation
- Support for IEEE 1588 Clock Synchronization (2008 Annex D, Annex E and Annex F)
- Differentiated Services Code Point (DSCP) Priority Mapping (IPv4 and IPv6)
- IPV4/IPV6 UDP/TCP checksum offload
- Priority Based Flow Control (801.1QBB) and Flow Control (802.3x) Support
- Wire rate switching (802.1d)
- Store and Forward Switching
- Non-Blocking switch fabric
- Support of Time Sensitive Network - IEEE P902.3br/D2.0 Interspersing Express Traffic and IEEE 802.1Qbv/D2.2 Enhancements for Scheduled Traffic
- Address Lookup Engine (ALE) with 512 ALE table entries
- EtherStats and 802.3 Stats Remote Network Monitoring (RMON) statistics gathering (per port statistics)
- Maximum frame size of 2020 bytes
- Management Data Input/Output (MDIO) module for PHY Management
- Host port CPPI Streaming Packet Interface
- Emulation support

#### **1.4.13 Universal Serial Bus (USB) Subsystem 2.0**

Instantiated in MAIN domain: Two instances of the Universal Serial Bus (USB) subsystem with integrated USB2.0 PHY module has the following main features:

- Dual-Role Device (DRD) capability
- Support of Peripheral (aka Device) mode at High Speed (HS at 480 Mbps) and Full Speed (FS at 12 Mbps)
- Support of Host mode at High Speed (HS at 480 Mbps), Full Speed (FS at 12 Mbps), and Low Speed (LS at 1.5 Mbps)

- Support of Host Negotiation Protocol (HNP)
- Support of USB3 low power protocol states (U1, U2, and U3)
- USB instance contains a single xHCI compliant with xHCI 1.0 specification with internal DMA controller
- ECC on internal RAMs
- Embedded USB 2.0 PHY

#### **1.4.14 General Purpose Memory Controller (GPMC)**

One instance of the General-Purpose Memory Controller (GPMC) module. The GPMC is dedicated to interfacing with external memory devices and has the following main features:

- Support of 8- or 16-bit-wide data path to external memory devices
- Supports up to 4 independent chip-select regions of programmable size and programmable base addresses on 16MB, 32MB, 64MB, or 128MB boundary in a total address space of 1GB
- Support of the following wide range of external memories/devices:
  - Asynchronous or synchronous 8-bit wide memory or device (non-burst device)
  - Asynchronous or synchronous 16-bit wide memory or device
  - 16-bit non-multiplexed NOR flash device
  - 16-bit address and data multiplexed NOR flash device
  - 8-bit and 16-bit NAND flash device
  - 16-bit pseudo-SRAM (pSRAM) device
- Supports various interface protocols when communicating with external memory or external devices:
  - Asynchronous read/write access
  - Asynchronous read page access (4, 8, and 16 Word16)
  - Synchronous read/write access
  - Synchronous read burst access without wrap capability (4, 8, and 16 Word16)
  - Synchronous read burst access with wrap capability (4, 8, and 16 Word16)
- Supports up to 16-bit on-the-fly error code detection using the Bose-Chaudhuri-Hocquenghem (BCH) or Hamming code to improve the reliability of NAND with a minimum effect on software (NAND flash with 512-byte page size or greater)

#### **1.4.15 Error Location Module (ELM)**

One instance of the Error Location Module (ELM). The ELM module works in conjunction with the GPMC and has the following main features:

- ECC calculations (up to 16-bit) for NAND support and ability to work in both page-based and continuous modes
  - 4, 8, and 16 bits per 512-byte block error-location, based on BCH algorithms
  - Eight simultaneous processing contexts
  - Page-based and continuous modes
  - Interrupt generation on error-location process completion

#### **1.4.16 Flash Subsystem (FSS) with Octal Serial Peripheral Interface (OSPI)**

Integrated in MAIN domain: One instance of the Flash Subsystem (FSS) module provides access to external flash devices via Octal Serial Peripheral Interface (OSPI) along with encryption/decryption and in-line ECC protection. FSS supports the following main features:

- Provides one OSPI flash interfaces
- OSPI interface supports:
  - Execute in place (XIP) operation
  - 32-byte Block Copy (BC) operation
  - ECC
- OSPI supports up to 4 devices
- OSPI supports single, dual, quad, or octal SPI devices
- The OSPI interface has independent power management for low power operations

#### 1.4.17 Multi-Media Card/Secure Digital Interface (MMCSD)

Integrated in MAIN domain: Three Multi-Media Card/Secure Digital (MMCSD) controller modules with the following main features:

- One controller with 8-bit wide data bus
- Two controllers with 4-bit wide data bus
- Support of eMMC5.1 Host Specification (JESD84-B51)
- Support of SD Host Controller Standard Specification - SDIO 3.00
- Integrated DMA controller supporting SD Advanced DMA - ADMA2 and ADMA3
- eMMC Electrical Standard 5.1 (JESD84-B51)
- Multi-Media card features:
  - Backward compatible with earlier eMMC standards
  - Legacy MMC SDR: 3.3/1.8 V, 8/4/1-bit bus width, 0-25 MHz, 25/12.5/3.125 MB/s
  - High Speed SDR: 3.3/1.8 V, 8/4/1-bit bus width, 0-50 MHz, 50/25/6.25 MB/s
  - High Speed DDR: 3.3/1.8 V, 8/4-bit bus width, 0-50 MHz, 100/50 MB/s
  - HS200 SDR: 1.8 V, 0-200 MHz, 8/4-bit bus width, 200/100 MB/s
- SD card support: SDIO, SDR12, SDR25, SDR50, SDR104, DDR50
- System bus interface: CBA 4.0 VBUSM controller port with 64-bit data width and 64-bit address, little endian only
- Configuration bus interface: CBA 4.0 VBUSM with 32-bit data width, 32-bit aligned accesses only, linear incrementing addressing mode, little endian only

#### 1.4.18 Enhanced Capture Module (ECAP)

Integrated in MAIN domain: Three Enhanced Capture (ECAP) modules provide accurate timing for different events. When not being used for event capture, its resources can be used to generate a single channel of asymmetrical PWM waveforms (configurable as either one capture input, or as one auxiliary PWM output). Each ECAP module supports the following main features:

- 32-bit time base counter
- 4 x 32 bits event time-stamp capture registers
- 4 stage sequencer (Mod4 counter), synchronized to external events
- Independent edge polarity selection for up to four sequenced time-stamp capture events
- Input capture signal pre-scaling (from 1 to 16)
- Interrupt capabilities on any of the four capture events
- Support of different capture modes (single shot capture, continuous mode capture, absolute timestamp capture or delta mode time-stamp capture)

#### 1.4.19 Enhanced Pulse-Width Modulation Module (EPWM)

Integrated in MAIN domain: Three Enhanced Pulse-Width Modulation (EPWM) modules, each with the following main features:

- Dedicated 16-bit time-base counter with period and frequency control
- Two independent PWM outputs that can be used in different configurations (with single-edge operation, with dual-edge symmetric operation or one independent PWM output with dual-edge asymmetric operation)
- Asynchronous override control of PWM signals during fault conditions
- Programmable phase-control support for lag or lead operation relative to other EPWM modules
- Dead-band generation with independent rising and falling edge delay control
- Programmable trip zone allocation of both latched and un-latched fault conditions
- Events enabling to trigger both CPU interrupts and start of ADC conversions

#### 1.4.20 Enhanced Quadrature Encoder Pulse Module (EQEP)

Integrated in MAIN domain: Three 32-bit Enhanced Quadrature Encoder Pulse (EQEP) modules for position, speed, and frequency measurements support, each with the following main features:

- Input synchronization
- Three stage/six stage digital noise filter

- Quadrature decoder unit
- Position counter and control unit for position measurement
- Quadrature edge capture unit for low speed measurement
- Unit time base for speed/frequency measurement
- Watchdog timer for detecting stalls

#### **1.4.21 Controller Area Network (MCAN)**

Integrated in the domain: One Controller Area Network interfaces (MCAN) supporting both classic CAN and CAN FD (CAN with Flexible Data-Rate) specifications and having the following main features:

- Conforms with CAN Protocol version 2.0 part A, B and ISO 11898-1:2015
- Full CAN FD (up to 64 data bytes) support
- SAE J1939 support
- AUTOSAR support
- Up to 32 dedicated transmit buffers and 64 dedicated receive buffers
- Two configurable receive FIFOs, up to 64 elements each
- Configurable transmit FIFO, up to 32 elements
- Configurable transmit queue, up to 32 elements
- Configurable transmit event FIFO, up to 32 elements
- Up to 128 filter elements
- Maskable interrupts, two interrupt lines
- Timestamp Counter

#### **1.4.22 Timers**

Three different types of timer modules are instantiated in the MAIN domain:

- One instance of Global Time Counter (GTC) module that can be used for time synchronization and debug trace time stamping with the following main features:
  - 64-bit up counter
  - No rollover during the lifetime of the device
  - Compatible with Armv8 system counter requirements
  - Outputs reflected binary (Gray) encoded timer value for system timer bus distribution to other modules
  - Selectable counter bit output as a push event that can be used by CPTS modules, timers or interface protocols
- Five instances Windowed Watchdog Timer (WWDT), implemented by using the Digital Windowed Watchdog (DWWD) function of the Real Time Interrupt (RTI) module providing timer functionality for operation systems and benchmarking code with the following main features:
  - Two independent 64 bit counter blocks
  - Four configurable compare registers for generating operating system ticks
  - Free running counter 0 can be incremented by either the internal pre-scale counter or by an external event
  - Selectable RTI clock input (derived from any of the available clock sources)
  - Fast enabling/disabling of events
- Eight instances of the dual mode Timer (TIMER) module with support of the following main features:
  - Free running 32-bit upward counter
  - Generates a 1-ms tick with a 32.768-kHz functional clock
  - Interrupts generated on overflow, compare and capture
  - Supported modes of operation: compare and capture, auto-reload and start-stop
  - Programmable divider clock source ( $2^n$ , where  $n = [0-8]$ )
  - Dedicated input trigger for capture mode and dedicated output trigger/PWM signal
  - On-the-fly read/write register (while counting) for systems operation and benchmarking code

#### **1.4.23 Internal Diagnostics Modules**

Instantiated in MAIN domain are different internal diagnostics modules which provide monitoring and diagnostic functions required to achieve certain safety compliance levels:

- Seven Dual Clock Comparator (DCC) modules, used to determine the accuracy of a clock signal during the time execution of an application, each having the following main features:
  - Two independent counter blocks count clock pulses from each clock source
  - Each counter block is programmable, however, for proper operation the counters must be programmed with seed values that respect the ratio of the two clock frequencies
  - Configurable time base for error signal
  - Error signal generation when one of the clocks is out of spec
  - Clock frequency measurement
- One instance of Error Signaling Module (ESM) for safety-related events and/or errors aggregation from throughout the device into one location supports the following main features:
  - Up to 1024 level or pulse error event inputs
  - Selectable low and high priority interrupt error pin prioritization of each error event
  - Error signal routed out of device through MCU\_ESM error signal
  - Configurable time base for error signal
  - Error forcing capability
  - Internal redundant flops on safety critical fields
- Multiple ECC aggregator modules supporting ECC mechanism for providing increased system reliability via reduction of memory software errors by allowing single bit errors to be detected and corrected (SEC) and double bit errors to be detected (DED). Applied to different memories in many of the subsystems, each of the ECC aggregators has the following main features:
  - Reduces memory software errors via single error correction (SEC) and double error detection (DED)
  - Provides a mechanism to control and monitor the ECC RAMs in a module or subsystem
  - Supports software readable status of ECC errors (single and double-bit) and associated info such as RAM address and data bit or bits that are in error
  - Aggregates level pending status from the ECC RAMs in two interrupts to the device CPU – interrupt for correctable error (SEC) and interrupt for uncorrectable error (DED)
  - Supports up to 256 ECC endpoints (either ECC RAM or interconnect ECC component)
  - Single bit error detection via parity checking results in a non-correctable error interrupt

## 1.5 Device MCU Domain

This section describes the modules integrated in the device MCU domain.

---

### Note

In TI documentaiton, the MCU Domain may be referred to as "M4FSS Island", "MCU Island", "MCU Channel", or "MCU Subsystem".

---

The Microcontroller Unit Domain (MCU Domain) is a “chip-in-a-chip” concept and it operates using separate clock sources and resets. This allows the MCU Domain to function continuously regardless of the state of the rest of the device, including periods in which the rest of the device is held in reset or powered down. The MCU island integrates communication peripherals such as SPI, I2C, and UART which are expected to be used for safety critical communication, so if the main SoC goes down, the MCU island can communicate this information to the rest of the system. Isolation of the MCU Arm Cortex-M4F Microcontroller Subsystem helps to provide Freedom From Interference (FFI).



**Figure 1-3. AM62x MCU Domain Functional Block Diagram**

### 1.5.1 MCU Arm Cortex M4F Subsystem (MCU\_M4FSS)

Integrated in the MCU domain: One Arm Cortex-M4F Subsystem module. This processor core can be configured as an isolated safety MCU or general purpose MCU.

- Cortex M4F With MPU
- ARMv7-M architecture
- Support for Nested Vectored Interrupt Controller (NVIC) with 64 inputs
- Ability to execute code from internal or external memories
- 192 KB of SRAM (I-Code)
- 64 KB of SRAM (D-Code)
- Debug Support Including:
  - DAP based Debug to the CPU Core
  - Full Debug Features of CPU Core are enabled
  - Standard ITM trace

- CTM Cross Trigger
- ETM Trace Support
- Fault Detection and Correction:
  - SECDED ECC protection on I-CODE
  - SECDED ECC protection on D-CODE
  - Fault Error Interrupt Output

### **1.5.2 MCU General Purpose Input/Output Interface (MCU\_GPIO)**

Integrated in MCU domain: One General Purpose Input/Output (MCU\_GPIO) module provides dedicated general-purpose pins that can be configured as either inputs or outputs. the MCU\_GPIO module includes these main features:

- Support of 9 banks x 16 GPIO pins
- Support of up to 9 banks of interrupt capable GPIOs
- Interrupts can be triggered by rising and/or falling edge, specified for each interrupt capable GPIO pin
- Set/clear functionality per individual GPIO pin

### **1.5.3 MCU Inter-Integrated Circuit Interface (MCU\_I2C)**

Integrated in MCU domain: One multi-controller Inter-Integrated Circuit (MCU\_I2C) interface with the following main features:

- Compliancy to the Philips I2C-bus specification version 2.1
- Support of standard mode (up to 100 Kbps) and fast mode (up to 400 Kbps)
- Support of 7-bit and 10-bit device addressing modes
- Support of multi-controller transmitter/peripheral receiver and receiver/peripheral transmitter modes
- Built-in FIFOs with programmable size of 8 to 64 bytes for buffered read or write
- 8-bit-wide data access
- Support of Auto Idle, Idle Request/Idle Acknowledge handshake, and Asynchronous Wakeup mechanisms
- Low power consumption

### **1.5.4 MCU Multi-channel Serial Peripheral Interface (MCU\_SPI)**

Integrated in MCU domain: Two Multi-channel Serial Peripheral Interface (MCU\_SPI) modules where each have the following main features:

- Serial clock with programmable frequency, polarity, and phase for each channel
- Wide selection of MCSPI word lengths, ranging from 4 to 32 bits
- Up to four controller channels, or single channel in receiver mode
- Support of different controller multichannel modes
- Single interrupt line for multiple interrupt source events
- Support of start-bit write command
- Support of start-bit pause and break sequence
- Built-in FIFO available for a single channel

### **1.5.5 MCU Universal Asynchronous Receiver/Transmitter (MCU\_UART)**

Integrated in MCU domain: One configurable Universal Asynchronous Receiver/Transmitter (MCU\_UART) interface with the following main features:

- Support of RS-485 external transceiver auto flow control
- Dual 64-byte FIFOs – one per each received and transmitted data paths
- Programmable and selectable transmit and receive FIFO trigger levels for DMA and interrupt generation
- Programmable sleep mode
- 16C750 compatible interface
- Baud rates up to 3.6 Mbps with 48 MHz functional clock
- Auto-baud between 1200 bits/s and 115.2 Kbits/s (only when 48 MHz function clock is used)
- Support of IrDA 1.4 Slow Infrared (SIR), Medium Infrared (MIR), and Fast Infrared (FIR) communications
- Support of Consumer Infrared Remote control mode (CIR) with programmable data encoding

### 1.5.6 MCU Timers

Two different types of timer modules are instantiated in the MCU domain:

- One instance Windowed Watchdog Timer (WWDT), implemented by using the Digital Windowed Watchdog (DWWD) function of the Real Time Interrupt (RTI) module providing timer functionality for operation systems and benchmarking code with the following main features:
  - Two independent 64 bit counter blocks
  - Four configurable compare registers for generating operating system ticks
  - Free running counter 0 can be incremented by either the internal pre-scale counter or by an external event
  - Selectable RTI clock input (derived from any of the available clock sources)
  - Windowed Watchdog Timer (WWDT) feature
  - Some RTI modules are pre-dedicated to specific processor cores
- Four instances of Timer module with support of the following main features:
  - Free running 32-bit upward counter
  - Generates a 1-ms tick with a 32.768-kHz functional clock
  - Interrupts generated on overflow, compare and capture
  - Supported modes of operation: compare and capture, auto-reload and start-stop
  - Programmable divider clock source (2<sup>n</sup>, where n = [0-8])
  - Dedicated input trigger for capture mode and dedicated output trigger/PWM signal
  - On-the-fly read/write register (while counting) for systems operation and benchmarking code
  - Each odd numbered timer instance may be optionally cascaded with the previous even numbered timer instance to form up to a 64-bit timer

### 1.5.7 MCU Internal Diagnostics Modules

Instantiated in MCU domain are different internal diagnostics modules which provide monitoring and diagnostic functions required to achieve certain safety compliance levels:

- One instance of the Dual Clock Comparator (MCU\_DCC) module, used to determine the accuracy of a clock signal during the time execution of an application, each having the following main features:
  - Two independent counter blocks count clock pulses from each clock source
  - Each counter block is programmable, however, for proper operation the counters must be programmed with seed values that respect the ratio of the two clock frequencies
  - Configurable time base for error signal
  - Error signal generation when one of the clocks is out of spec
  - Clock frequency measurement
- One instance of Error Signaling Module (MCU\_ESM) for safety-related events and/or errors aggregation from throughout the device into one location supports the following main features:
  - Up to 1024 level or pulse error event inputs
  - Selectable low and high priority interrupt error pin prioritization of each error event
  - Single Error Pin output to signal severe device failure to outside world
  - Configurable time base for error signal
  - Triple Redundant Pulse Inputs
  - Two Priority Levels
  - Error Forcing capability
  - Internal redundant flops on safety critical fields
- Multiple ECC aggregator modules supporting ECC mechanism for providing increased system reliability via reduction of memory software errors by allowing single bit errors to be detected and corrected (SEC) and double bit errors to be detected (DED). Applied to different memories in many of the subsystems, each of the ECC aggregators has the following main features:
  - Reduces memory software errors via single error correction (SEC) and double error detection (DED)
  - Provides a mechanism to control and monitor the ECC RAMs in a module or subsystem
  - Supports software readable status of ECC errors (single and double-bit) and associated info such as RAM address and data bit or bits that are in error

- Aggregates level pending status from the ECC RAMs in two interrupts to the device CPU – interrupt for correctable error (SEC) and interrupt for uncorrectable error (DED)
- Supports up to 256 ECC endpoints (either ECC RAM or interconnect ECC component)
- Single bit error detection via parity checking results in a non-correctable error interrupt
- Memory Cyclic Redundancy Check module used to perform CRC to verify the integrity of a memory system. The MCRC module has the following main feature:
  - Four Channels of CRC Compression based Signature Generation
  - 8, 16, 32, or 64-bit Data Size
  - Maximum Length PSA based on 64-bit Polynomial
  - Programmable 20 bit pattern counter per channel
  - Three Operating Modes: Auto, Semi-CPU, Full CPU
  - MCRC or CPU can perform signature verification for each Channel
  - Timeout Interrupt if CRC is not performed within the time limit

## 1.6 Device WKUP Domain

This section describes the modules integrated in the device WKUP domain.

### 1.6.1 Arm Cortex-R5F Processor (R5FSS)

The ARM Core Cortex-R5F processor subsystem (R5FSS) supports the following main features:

- Armv7-R architecture
- R5FSS Memory System
  - 32KB Instruction Cache
    - 4x8KB ways
    - SECDED ECC protected per 64 bits
  - 32KB Data Cache
    - 4x8KB ways
    - SECDED ECC protected per 32 bits
  - 64KB tightly-coupled memory (TCM) per CPU
    - SECDED ECC protected per 32 bits
    - TCM hard error cache Implemented in CPU
    - Readable/writable from system
    - TCMs initialized (to 0's) at reset
    - 32KB TCMA (ATCM)
    - 16KB TCMB0 (B0TCM)
    - 16KB TCMB1 (B1TCM)
  - Full-precision Floating Point (VFPv3)
  - 16-region Memory Protection Unit (MPU)
  - 8 breakpoints, 8 watch points
  - CoreSight Debug Access Port (DAP)
  - CoreSight ETM-R5 interface (CTI, ETM)
  - Performance Monitoring Unit (PMU)
  - 32-bit to 36-bit Region-based Address Translation (RAT) on memory access initiators
  - Integrated Vectored Interrupt Manager (VIM) per core with 256 Interrupt Inputs each
    - Programmable interrupt priority (4-bit)
    - Programmable interrupt enable mask
    - Software-generated interrupts
  - Synchronous clock domain crossing on all core interfaces

---

#### Note

CORE0 has 64KB of TCM.

---

---

**Note**

These details describe a superset of the R5FSS memory configuration. For additional details on device memory availability, please refer to the device-specific Datasheet.

---

## 1.7 Device Identification

The device part number identification data can be read in the [WKUP\\_CTRL\\_MMR\\_CFG0\\_JTAG\\_USER\\_ID](#) register. See [Table 1-1](#) for more information.

**Table 1-1. Device Part Number Identifier**

| WKUP_CTRL_MMR_CFG0_JTAG_USE<br>R_ID<br>Register Field | Value and Description                                                                                                                                            | Comment                                                                                                                                    |
|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| [31-13] DEVICE_ID                                     | Base Part Number.                                                                                                                                                | Refer to the Device Comparison table in the device specific datasheet for the combined DEVICE_ID and FEATURES value of a given part number |
| [12] SAFETY                                           | 0 = Non Functional Safety<br>1 = Functional Safety                                                                                                               |                                                                                                                                            |
| [11] SECURITY                                         | 0 = Non-Secure<br>1 = Secure                                                                                                                                     |                                                                                                                                            |
| [10-6] SPEED                                          | Device Speed Grade.<br>1 (0x01) = A speed designator<br>2 (0x02) = B speed designator<br>...<br>25 (0x19) = Y speed designator<br>26 (0x1A) = Z speed designator | Refer to the device-specific Datasheet for the supported speed grades and the definitions for a given device.                              |
| [5-3] TEMP                                            | Temperature grade.<br>3 = 0°C to 95°C<br>4 = -40°C to 105°C<br>5 = -40°C to 125°C<br>Others = Reserved                                                           | Operating junction temperature range.                                                                                                      |
| [2-0] PKG                                             | Package<br>1 = ALW<br>6 = AMC<br>Others = Reserved                                                                                                               | Device Package type.                                                                                                                       |

The manufacturer identity, the boundary scan part number, and the silicon revision of the device can be read in the [WKUP\\_CTRL\\_MMR\\_CFG0\\_JTAGID](#) register. See [Table 1-2](#) and [Table 1-3](#) tables for more information.

**Table 1-2. Device JTAG ID**

| WKUP_CTRL_MMR_CFG0_JTAGID<br>Register Field | Value                         | Comment                           |
|---------------------------------------------|-------------------------------|-----------------------------------|
| [31-28] VARIANT                             | See <a href="#">Table 1-3</a> | Silicon Revision (SR) identifier. |
| [27-12] PARTNO                              | See <a href="#">Table 1-3</a> | Part number for boundary scan.    |
| [11-1] MFG                                  | 0x277F                        | Manufacturer identity (TI).       |
| [0] LSB                                     | 0x1                           | Always reads 1.                   |

**Table 1-3. Device JTAG ID Values**

| Silicon Type | VARIANT | PARTNO | WKUP_CTRL_MMR_CFG0_JTAGID<br>Register Value |
|--------------|---------|--------|---------------------------------------------|
| AM62x SR1.0  | 0x0     | 0xBB7E | 0x43000014                                  |

## Chapter 2

# Memory Map

---



AM62 SoC level memory map is constructed using 36b physical address and follows the guideline to put peripheral at 64KB aligned boundary. No virtual address is supported on the SoC level. However, A53 core can support virtual address internally. If software utilizes the address more than 36b, only the lower 36b is used for SoC level address decoding and the upper address bits will be ignored by the SoC. Not all the 36b memory regions are implemented by AM62. Any transactions hitting the unimplemented address range will be terminated and routed to null end point to avoid system hang. An interrupt will be asserted and the above transaction will be logged.

All the SoC level peripherals and processors use the common SoC memory except the 32b only processors, such as M4F core and R5 core. For those processors and peripherals which natively only supports 32b physical address, the Region based Address Translation (RAT) module is used to remap the 32b address into the common 36b SoC address map.

AM62 contains three domains: main domain, mcu domain and wkup domain. The following sections shows the detailed memory map in each domain.

|                                           |           |
|-------------------------------------------|-----------|
| <b>2.1 Memory Maps.....</b>               | <b>32</b> |
| <b>2.2 SoC Address Aliasing.....</b>      | <b>46</b> |
| <b>2.3 Processor Memory Map View.....</b> | <b>46</b> |
| <b>2.4 Memory Map Summary.....</b>        | <b>51</b> |
| <b>2.5 MMU Optimization Note.....</b>     | <b>68</b> |

## 2.1 Memory Maps

### 2.1.1 Memory Map

Table 2-1. Memory Map

| Region                                               | Start        | End          | Size   |
|------------------------------------------------------|--------------|--------------|--------|
| PSRAMECC0_RAM                                        | 0x0000000000 | 0x0000000400 | 1 KB   |
| PADCFIG_CTRL0_CFG0                                   | 0x0000F0000  | 0x0000F8000  | 32 KB  |
| CTRL_MMR0_CFG0                                       | 0x000100000  | 0x000120000  | 128 KB |
| CBASS_DBG0_ERR                                       | 0x000200000  | 0x000200400  | 1 KB   |
| CBASS_INFRA1_ERR                                     | 0x000210000  | 0x000210400  | 1 KB   |
| CBASS_FW0_ERR                                        | 0x000220000  | 0x000220400  | 1 KB   |
| CBASS_IPCSS0_ERR                                     | 0x000230000  | 0x000230400  | 1 KB   |
| CBASS_MCASP0_ERR                                     | 0x000240000  | 0x000240400  | 1 KB   |
| EFUSE0                                               | 0x000300000  | 0x000300100  | 256 B  |
| PBIST1                                               | 0x000310000  | 0x000310400  | 1 KB   |
| COMPUTE_CLUSTER0_PBIST                               | 0x000330000  | 0x000330400  | 1 KB   |
| PSC0                                                 | 0x000400000  | 0x000401000  | 4 KB   |
| PLLCTRL0                                             | 0x000410000  | 0x000410200  | 512 B  |
| ESMO_CFG                                             | 0x000420000  | 0x000421000  | 4 KB   |
| DFTSS0                                               | 0x000500000  | 0x000500400  | 1 KB   |
| DDPA0                                                | 0x000580000  | 0x000580400  | 1 KB   |
| GPIO0                                                | 0x000600000  | 0x000600100  | 256 B  |
| GPIO1                                                | 0x000601000  | 0x000601100  | 256 B  |
| PLL0_CFG                                             | 0x000680000  | 0x0006A0000  | 128 KB |
| PSRAMECC0_ECC_AGGR                                   | 0x000700000  | 0x000700400  | 1 KB   |
| PSC0_REGS                                            | 0x000700400  | 0x000700800  | 1 KB   |
| USB0_DEBUG_TRACE_MMR_TRACE_VBUSBP_USB2SS_DEBUG_TRACE | 0x000703000  | 0x000703200  | 512 B  |
| CPSW0_ECC                                            | 0x000704000  | 0x000704400  | 1 KB   |
| MMCSD0_ECC_AGGR_RXMEM                                | 0x000706000  | 0x000706400  | 1 KB   |
| MMCSD0_ECC_AGGR_TXMEM                                | 0x000707000  | 0x000707400  | 1 KB   |
| MMCSD1_ECC_AGGR_RXMEM                                | 0x000708000  | 0x000708400  | 1 KB   |
| MMCSD1_ECC_AGGR_TXMEM                                | 0x000709000  | 0x000709400  | 1 KB   |
| MMCSD2_ECC_AGGR_TXMEM                                | 0x00070A000  | 0x00070A400  | 1 KB   |
| MMCSD2_ECC_AGGR_RXMEM                                | 0x00070B000  | 0x00070B400  | 1 KB   |
| USB1_DEBUG_TRACE_MMR_TRACE_VBUSBP_USB2SS_DEBUG_TRACE | 0x00070C000  | 0x00070C200  | 512 B  |
| CSI_RX_IF0_ECC_AGGR_CFG                              | 0x00070E000  | 0x00070E400  | 1 KB   |
| SA3_SS0_ECC_AGGR                                     | 0x000712000  | 0x000712400  | 1 KB   |
| FSS0_OSP10_ECC_AGGR                                  | 0x000716000  | 0x000716400  | 1 KB   |
| COMPUTE_CLUSTER0_SS_ECC_AGGR                         | 0x000718000  | 0x000718400  | 1 KB   |
| COMPUTE_CLUSTER0_CORE0_ECC_AGGR                      | 0x000718400  | 0x000718800  | 1 KB   |

**Table 2-1. Memory Map (continued)**

| Region                                   | Start        | End          | Size  |
|------------------------------------------|--------------|--------------|-------|
| COMPUTE_CLUSTER0_CORE1_ECC_AGGR          | 0x0000718800 | 0x0000718C00 | 1 KB  |
| COMPUTE_CLUSTER0_CORE2_ECC_AGGR          | 0x0000718C00 | 0x0000719000 | 1 KB  |
| COMPUTE_CLUSTER0_CORE3_ECC_AGGR          | 0x0000719000 | 0x0000719400 | 1 KB  |
| DCC0                                     | 0x0000800000 | 0x0000800040 | 64 B  |
| DCC1                                     | 0x0000804000 | 0x0000804040 | 64 B  |
| DCC2                                     | 0x0000808000 | 0x0000808040 | 64 B  |
| DCC3                                     | 0x000080C000 | 0x000080C040 | 64 B  |
| DCC4                                     | 0x0000810000 | 0x0000810040 | 64 B  |
| DCC5                                     | 0x0000814000 | 0x0000814040 | 64 B  |
| DCC6                                     | 0x0000818000 | 0x0000818040 | 64 B  |
| MAIN_GPIOMUX_INTRROUTER0_INTR_ROUTER_CFG | 0x0000A00000 | 0x0000A00800 | 2 KB  |
| CMP_EVENT_INTRROUTER0_INTR_ROUTER_CFG    | 0x0000A30000 | 0x0000A30800 | 2 KB  |
| TIMESYNC_EVENT_ROUTER0_INTR_ROUTER_CFG   | 0x0000A40000 | 0x0000A40400 | 1 KB  |
| WKUP_GTC0_GTC_CFG0                       | 0x0000A80000 | 0x0000A80400 | 1 KB  |
| WKUP_GTC0_GTC_CFG1                       | 0x0000A90000 | 0x0000A94000 | 16 KB |
| WKUP_GTC0_GTC_CFG2                       | 0x0000AA0000 | 0x0000AA4000 | 16 KB |
| WKUP_GTC0_GTC_CFG3                       | 0x0000AB0000 | 0x0000AB4000 | 16 KB |
| WKUP_VTM0_MMR_VBUSP_CFG1                 | 0x0000B00000 | 0x0000B00400 | 1 KB  |
| WKUP_VTM0_MMR_VBUSP_CFG2                 | 0x0000B01000 | 0x0000B01400 | 1 KB  |
| WKUP_VTM0_ECCAGGR_CFG                    | 0x0000B02000 | 0x0000B02400 | 1 KB  |
| PDMA0                                    | 0x0000C00000 | 0x0000C00400 | 1 KB  |
| PDMA1                                    | 0x0000C01000 | 0x0000C01400 | 1 KB  |
| GICSS0_GIC_TRANSLATER                    | 0x0001000000 | 0x0001400000 | 4 MB  |
| GICSS0_GIC                               | 0x0001800000 | 0x0001900000 | 1 MB  |
| TIMER0_CFG                               | 0x0002400000 | 0x0002400400 | 1 KB  |
| TIMER1_CFG                               | 0x0002410000 | 0x0002410400 | 1 KB  |
| TIMER2_CFG                               | 0x0002420000 | 0x0002420400 | 1 KB  |
| TIMER3_CFG                               | 0x0002430000 | 0x0002430400 | 1 KB  |
| TIMER4_CFG                               | 0x0002440000 | 0x0002440400 | 1 KB  |
| TIMER5_CFG                               | 0x0002450000 | 0x0002450400 | 1 KB  |
| TIMER6_CFG                               | 0x0002460000 | 0x0002460400 | 1 KB  |
| TIMER7_CFG                               | 0x0002470000 | 0x0002470400 | 1 KB  |
| UART0                                    | 0x0002800000 | 0x0002800200 | 512 B |
| UART1                                    | 0x0002810000 | 0x0002810200 | 512 B |
| UART2                                    | 0x0002820000 | 0x0002820200 | 512 B |
| UART3                                    | 0x0002830000 | 0x0002830200 | 512 B |
| UART4                                    | 0x0002840000 | 0x0002840200 | 512 B |

Table 2-1. Memory Map (continued)

| Region                                       | Start        | End          | Size   |
|----------------------------------------------|--------------|--------------|--------|
| UART5                                        | 0x0002850000 | 0x0002850200 | 512 B  |
| UART6                                        | 0x0002860000 | 0x0002860200 | 512 B  |
| MCASP0_CFG                                   | 0x0002B00000 | 0x0002B02000 | 8 KB   |
| MCASP0_DMA                                   | 0x0002B08000 | 0x0002B08400 | 1 KB   |
| MCASP1_CFG                                   | 0x0002B10000 | 0x0002B12000 | 8 KB   |
| MCASP1_DMA                                   | 0x0002B18000 | 0x0002B18400 | 1 KB   |
| MCASP2_CFG                                   | 0x0002B20000 | 0x0002B22000 | 8 KB   |
| MCASP2_DMA                                   | 0x0002B28000 | 0x0002B28400 | 1 KB   |
| WKUP_PSC0                                    | 0x0004000000 | 0x0004001000 | 4 KB   |
| MCU_PLLCTRL0                                 | 0x0004020000 | 0x0004020200 | 512 B  |
| WKUP_SAFE_ECC_AGGR0_ECC_AGGR                 | 0x0004030000 | 0x0004030400 | 1 KB   |
| WKUP_PLL0_CFG                                | 0x0004040000 | 0x0004041000 | 4 KB   |
| WKUP_PADCFG_CTRL0_CFG0                       | 0x0004080000 | 0x0004088000 | 32 KB  |
| WKUP_ESM0_CFG                                | 0x0004100000 | 0x0004101000 | 4 KB   |
| MCU_GPIO0                                    | 0x0004201000 | 0x0004201100 | 256 B  |
| WKUP_MCU_GPIOMUX_INTRROUTER0_INTR_ROUTER_CFG | 0x0004210000 | 0x0004210200 | 512 B  |
| MCU_TIMEOUT0_CFG                             | 0x0004300000 | 0x0004300400 | 1 KB   |
| MCU_TIMEOUT1_CFG                             | 0x0004301000 | 0x0004301400 | 1 KB   |
| MCU_CTRL_MMR0_CFG0                           | 0x0004500000 | 0x0004520000 | 128 KB |
| WKUP_CBASS_SAFE1_ERR                         | 0x0004600000 | 0x0004600400 | 1 KB   |
| MCU_MCAN0_ECC_AGGR                           | 0x0004701000 | 0x0004701400 | 1 KB   |
| MCU_MCAN1_ECC_AGGR                           | 0x0004702000 | 0x0004702400 | 1 KB   |
| MCU_ECC_AGGR0_ECC_AGGR                       | 0x0004703000 | 0x0004703400 | 1 KB   |
| MCU_CBASS0_ERR                               | 0x0004720000 | 0x0004720400 | 1 KB   |
| MCU_TIMER0_CFG                               | 0x0004800000 | 0x0004800400 | 1 KB   |
| MCU_TIMER1_CFG                               | 0x0004810000 | 0x0004810400 | 1 KB   |
| MCU_TIMER2_CFG                               | 0x0004820000 | 0x0004820400 | 1 KB   |
| MCU_TIMER3_CFG                               | 0x0004830000 | 0x0004830400 | 1 KB   |
| MCU_RTI0_CFG                                 | 0x0004880000 | 0x0004880100 | 256 B  |
| MCU_I2C0_CFG                                 | 0x0004900000 | 0x0004900100 | 256 B  |
| MCU_UART0                                    | 0x0004A00000 | 0x0004A00200 | 512 B  |
| MCU_MCSPI0_CFG                               | 0x0004B00000 | 0x0004B00400 | 1 KB   |
| MCU_MCSPI1_CFG                               | 0x0004B10000 | 0x0004B10400 | 1 KB   |
| MCU_DCC0                                     | 0x0004C00000 | 0x0004C00040 | 64 B   |
| MCU_MCRC64_0_REGS                            | 0x0004D00000 | 0x0004D01000 | 4 KB   |
| MCU_MCAN0_MSGMEM_RAM                         | 0x0004E00000 | 0x0004E08000 | 32 KB  |
| MCU_MCAN0_CFG                                | 0x0004E08000 | 0x0004E08200 | 512 B  |

**Table 2-1. Memory Map (continued)**

| Region                              | Start        | End          | Size   |
|-------------------------------------|--------------|--------------|--------|
| MCU_MCAN0_SS                        | 0x0004E09000 | 0x0004E09100 | 256 B  |
| MCU_MCAN1_MSGMEM_RAM                | 0x0004E10000 | 0x0004E18000 | 32 KB  |
| MCU_MCAN1_CFG                       | 0x0004E18000 | 0x0004E18200 | 512 B  |
| MCU_MCAN1_SS                        | 0x0004E19000 | 0x0004E19100 | 256 B  |
| MCU_M4FSS0_IRAM                     | 0x0005000000 | 0x000502FFFF | 192 KB |
| MCU_M4FSS0_DRAM                     | 0x0005040000 | 0x000504FFFF | 64 KB  |
| MCU_M4FSS0_RAT                      | 0x0005FF0000 | 0x0005FF1000 | 4 KB   |
| MCU_M4FSS0_ECC_AGGR                 | 0x0005FF1000 | 0x0005FF1400 | 1 KB   |
| CPSW0_NUSS                          | 0x0008000000 | 0x0008200000 | 2 MB   |
| RTI0_CFG                            | 0x000E000000 | 0x000E000100 | 256 B  |
| RTI1_CFG                            | 0x000E010000 | 0x000E010100 | 256 B  |
| RTI2_CFG                            | 0x000E020000 | 0x000E020100 | 256 B  |
| RTI3_CFG                            | 0x000E030000 | 0x000E030100 | 256 B  |
| RTI15_CFG                           | 0x000E0F0000 | 0x000E0F0100 | 256 B  |
| DDR16SS0_REGS_SS_CFG_SSCFG          | 0x000F300000 | 0x000F300200 | 512 B  |
| DDR16SS0_CTLPHY_WRAP_CTL_CFG_CTLCFG | 0x000F308000 | 0x000F310000 | 32 KB  |
| USB0_MMR_MMRVBP_USB2SS_CFG          | 0x000F900000 | 0x000F900800 | 2 KB   |
| USB0_PHY2                           | 0x000F908000 | 0x000F908400 | 1 KB   |
| USB1_MMR_MMRVBP_USB2SS_CFG          | 0x000F910000 | 0x000F910800 | 2 KB   |
| USB1_PHY2                           | 0x000F918000 | 0x000F918400 | 1 KB   |
| USB0_ECC_AGGR                       | 0x000F980000 | 0x000F980400 | 1 KB   |
| USB1_ECC_AGGR                       | 0x000F990000 | 0x000F990400 | 1 KB   |
| MMCSD1_CTL_CFG                      | 0x000FA00000 | 0x000FA01000 | 4 KB   |
| MMCSD1_SS_CFG                       | 0x000FA08000 | 0x000FA08400 | 1 KB   |
| MMCSD0_CTL_CFG                      | 0x000FA10000 | 0x000FA11000 | 4 KB   |
| MMCSD0_SS_CFG                       | 0x000FA18000 | 0x000FA18400 | 1 KB   |
| MMCSD2_CTL_CFG                      | 0x000FA20000 | 0x000FA21000 | 4 KB   |
| MMCSD2_SS_CFG                       | 0x000FA28000 | 0x000FA28400 | 1 KB   |
| FSS0_CFG                            | 0x000FC00000 | 0x000FC00100 | 256 B  |
| FSS0_FSAS_CFG                       | 0x000FC10000 | 0x000FC10100 | 256 B  |
| FSS0_OTFA_CFG                       | 0x000FC20000 | 0x000FC21000 | 4 KB   |
| FSS0_OSP10_CTRL                     | 0x000FC40000 | 0x000FC40100 | 256 B  |
| FSS0_OSP10_SS_CFG                   | 0x000FC44000 | 0x000FC44200 | 512 B  |
| GPU0_RGX_CR                         | 0x000FD00000 | 0x000FD20000 | 128 KB |
| I2C0_CFG                            | 0x0020000000 | 0x002000100  | 256 B  |
| I2C1_CFG                            | 0x0020010000 | 0x0020010100 | 256 B  |
| I2C2_CFG                            | 0x0020020000 | 0x0020020100 | 256 B  |

Table 2-1. Memory Map (continued)

| Region                        | Start        | End          | Size  |
|-------------------------------|--------------|--------------|-------|
| I2C3_CFG                      | 0x0020030000 | 0x0020030100 | 256 B |
| MCSPI0_CFG                    | 0x0020100000 | 0x0020100400 | 1 KB  |
| MCSPI1_CFG                    | 0x0020110000 | 0x0020110400 | 1 KB  |
| MCSPI2_CFG                    | 0x0020120000 | 0x0020120400 | 1 KB  |
| CBASS_MISC_PERI0_ERR          | 0x00201F0000 | 0x00201F0400 | 1 KB  |
| MCAN0_SS                      | 0x0020700000 | 0x0020700100 | 256 B |
| MCAN0_CFG                     | 0x0020701000 | 0x0020701200 | 512 B |
| MCAN0_MSGMEM_RAM              | 0x0020708000 | 0x0020710000 | 32 KB |
| EPWM0_EPWM                    | 0x0023000000 | 0x0023000100 | 256 B |
| EPWM1_EPWM                    | 0x0023010000 | 0x0023010100 | 256 B |
| EPWM2_EPWM                    | 0x0023020000 | 0x0023020100 | 256 B |
| ECAP0_CTL_STS                 | 0x0023100000 | 0x0023100100 | 256 B |
| ECAP1_CTL_STS                 | 0x0023110000 | 0x0023110100 | 256 B |
| ECAP2_CTL_STS                 | 0x0023120000 | 0x0023120100 | 256 B |
| EQEP0_REG                     | 0x0023200000 | 0x0023200100 | 256 B |
| EQEP1_REG                     | 0x0023210000 | 0x0023210100 | 256 B |
| EQEP2_REG                     | 0x0023220000 | 0x0023220100 | 256 B |
| MCAN0_ECC_AGGR                | 0x0024018000 | 0x0024018400 | 1 KB  |
| ELM0                          | 0x0025010000 | 0x0025011000 | 4 KB  |
| MAILBOX0_REGS0                | 0x0029000000 | 0x0029000200 | 512 B |
| SPINLOCK0                     | 0x002A000000 | 0x002A008000 | 32 KB |
| WKUP_RTIO_CFG                 | 0x002B000000 | 0x002B000100 | 256 B |
| WKUP_TIMER0_CFG               | 0x002B100000 | 0x002B100400 | 1 KB  |
| WKUP_TIMER1_CFG               | 0x002B110000 | 0x002B110400 | 1 KB  |
| WKUP_RTCSS0_RTC               | 0x002B1F0000 | 0x002B1F0080 | 128 B |
| WKUP_I2C0_CFG                 | 0x002B200000 | 0x002B200100 | 256 B |
| WKUP_UART0                    | 0x002B300000 | 0x002B300200 | 512 B |
| WKUP_CBASS0_ERR               | 0x002B400000 | 0x002B400400 | 1 KB  |
| WKUP_PBIST0                   | 0x002B500000 | 0x002B500400 | 1 KB  |
| WKUP_ECC_AGGR0_ECC_AGGR       | 0x002B600000 | 0x002B600400 | 1 KB  |
| ICSSM0_DRAM0_SLV_RAM          | 0x0030040000 | 0x0030042000 | 8 KB  |
| ICSSM0_DRAM1_SLV_RAM          | 0x0030042000 | 0x0030044000 | 8 KB  |
| ICSSM0_RAT_SLICE0_CFG         | 0x0030048000 | 0x0030049000 | 4 KB  |
| ICSSM0_RAT_SLICE1_CFG         | 0x0030049000 | 0x003004A000 | 4 KB  |
| ICSSM0_RAM_SLV_RAM            | 0x0030050000 | 0x0030058000 | 32 KB |
| ICSSM0_PR1_ICSS_INTC_INTC_SLV | 0x0030060000 | 0x0030062000 | 8 KB  |
| ICSSM0_PR1_PDSP0_IRAM         | 0x0030062000 | 0x0030062100 | 256 B |

**Table 2-1. Memory Map (continued)**

| Region                                             | Start        | End          | Size  |
|----------------------------------------------------|--------------|--------------|-------|
| ICSSM0_PR1_PDSP0_IRAM_DEBUG                        | 0x0030062400 | 0x0030062500 | 256 B |
| ICSSM0_PR1_PDSP1_IRAM                              | 0x0030064000 | 0x0030064100 | 256 B |
| ICSSM0_PR1_PDSP1_IRAM_DEBUG                        | 0x0030064400 | 0x0030064500 | 256 B |
| ICSSM0_PR1_PROT_SLV                                | 0x0030064C00 | 0x0030064D00 | 256 B |
| ICSSM0_PR1_CFG_SLV                                 | 0x0030066000 | 0x0030066200 | 512 B |
| ICSSM0_PR1_ICSS_UART_UART_SLV                      | 0x0030068000 | 0x0030068040 | 64 B  |
| ICSSM0_JEP0                                        | 0x003006E000 | 0x003006F000 | 4 KB  |
| ICSSM0_PR1_ICSS_ECAP0_ECAP_SLV                     | 0x0030070000 | 0x0030070100 | 256 B |
| ICSSM0_PR1_MII_RT_PR1_MII_RT_CFG                   | 0x0030072000 | 0x0030072100 | 256 B |
| ICSSM0_PR1_MDIO_V1P7_MDIO                          | 0x0030072400 | 0x0030072500 | 256 B |
| ICSSM0_PR1_MII_RT_PR1_MII_RT_G_CFG_REGS_G          | 0x0030073000 | 0x0030074000 | 4 KB  |
| ICSSM0_PR1_PDSP0_IRAM_RAM                          | 0x0030074000 | 0x0030078000 | 16 KB |
| ICSSM0_PR1_PDSP1_IRAM_RAM                          | 0x0030078000 | 0x003007C000 | 16 KB |
| CSI_RX_IF0_CP_INTD_CFG_INTD_CFG                    | 0x0030100000 | 0x0030101000 | 4 KB  |
| CSI_RX_IF0_VBUS2APB_WRAP_VBUSP_APB_CSI2RX          | 0x0030101000 | 0x0030102000 | 4 KB  |
| CSI_RX_IF0_RX_SHIM_VBUSP_MMR_CSI2RXIF              | 0x0030102000 | 0x0030103000 | 4 KB  |
| DPHY_RX0_VBUS2APB_WRAP_VBUSP_K3_DPHY_RX            | 0x0030110000 | 0x0030111000 | 4 KB  |
| DPHY_RX0_MMR_SLV_K3_DPHY_WRAP                      | 0x0030111000 | 0x0030111100 | 256 B |
| DSS0_COMMON                                        | 0x0030200000 | 0x0030201000 | 4 KB  |
| DSS0_COMMON1                                       | 0x0030201000 | 0x0030202000 | 4 KB  |
| DSS0_VIDL1                                         | 0x0030202000 | 0x0030203000 | 4 KB  |
| DSS0_VID                                           | 0x0030206000 | 0x0030207000 | 4 KB  |
| DSS0_OVR1                                          | 0x0030207000 | 0x0030208000 | 4 KB  |
| DSS0_OVR2                                          | 0x0030208000 | 0x0030209000 | 4 KB  |
| DSS0_VP1                                           | 0x003020A000 | 0x003020B000 | 4 KB  |
| DSS0_VP2                                           | 0x003020B000 | 0x003020C000 | 4 KB  |
| MCRC64_0_REGS                                      | 0x0030300000 | 0x0030301000 | 4 KB  |
| GPU_WS_BW_LIMITER3_REGS                            | 0x0030400000 | 0x0030401000 | 4 KB  |
| GPU_RS_BW_LIMITER2_REGS                            | 0x0030401000 | 0x0030402000 | 4 KB  |
| A53_WS_BW_LIMITER1_REGS                            | 0x0030402000 | 0x0030403000 | 4 KB  |
| A53_RS_BW_LIMITER0_REGS                            | 0x0030403000 | 0x0030404000 | 4 KB  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_CAP     | 0x0031000000 | 0x0031000020 | 32 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_OPER    | 0x0031000020 | 0x0031000060 | 64 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_PORT    | 0x0031000420 | 0x0031000440 | 32 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_RUNTIME | 0x0031000440 | 0x0031000460 | 32 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_INTR    | 0x0031000460 | 0x00310004A0 | 64 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DB      | 0x0031000560 | 0x0031000760 | 512 B |

Table 2-1. Memory Map (continued)

| Region                                                 | Start        | End          | Size  |
|--------------------------------------------------------|--------------|--------------|-------|
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_EXTCAP      | 0x0031000960 | 0x0031000970 | 16 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_SUPPRTCA P2 | 0x0031000970 | 0x0031000980 | 16 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_SUPPRTCA P3 | 0x0031000980 | 0x00310009A0 | 32 B  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_GBL         | 0x003100C100 | 0x003100C900 | 2 KB  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DEV         | 0x003100C700 | 0x003100CF00 | 2 KB  |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_LINK        | 0x003100D000 | 0x003100D080 | 128 B |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DEBUG       | 0x003100D800 | 0x003100DA00 | 512 B |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DEBUG_RA M0 | 0x0031040000 | 0x0031050000 | 64 KB |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_CAP         | 0x0031100000 | 0x0031100020 | 32 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_OPER        | 0x0031100020 | 0x0031100060 | 64 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_PORT        | 0x0031100420 | 0x0031100440 | 32 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_RUNTIME     | 0x0031100440 | 0x0031100460 | 32 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_INTR        | 0x0031100460 | 0x00311004A0 | 64 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DB          | 0x0031100560 | 0x0031100760 | 512 B |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_EXTCAP      | 0x0031100960 | 0x0031100970 | 16 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_SUPPRTCA P2 | 0x0031100970 | 0x0031100980 | 16 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_SUPPRTCA P3 | 0x0031100980 | 0x00311009A0 | 32 B  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_GBL         | 0x003110C100 | 0x003110C900 | 2 KB  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DEV         | 0x003110C700 | 0x003110CF00 | 2 KB  |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_LINK        | 0x003110D000 | 0x003110D080 | 128 B |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DEBUG       | 0x003110D800 | 0x003110DA00 | 512 B |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_USB3_CORE_DEBUG_RA M0 | 0x0031140000 | 0x0031150000 | 64 KB |
| CBASS0_ERR                                             | 0x003A000000 | 0x003A000400 | 1 KB  |
| GPMC0_CFG                                              | 0x003B000000 | 0x003B000400 | 1 KB  |
| R5FSS0_EVNT_BUS_VBUSB_MMRS                             | 0x003C018000 | 0x003C018100 | 256 B |
| PSRAMECC_16K0_ECC_AGGR                                 | 0x003F001000 | 0x003F001400 | 1 KB  |
| GICSS0_REGS                                            | 0x003F004000 | 0x003F004400 | 1 KB  |
| DMASS0_ECCAGGR                                         | 0x003F005000 | 0x003F005400 | 1 KB  |
| ICSSM0_ECC_AGGR                                        | 0x003F00C000 | 0x003F00C400 | 1 KB  |
| R5FSS0_CORE0_ECC_AGGR                                  | 0x003F00D000 | 0x003F00D400 | 1 KB  |
| ECC_AGGR0_ECC_AGGR                                     | 0x003F00F000 | 0x003F00F400 | 1 KB  |
| CBASS_CENTRAL2_ERR                                     | 0x003F012000 | 0x003F012400 | 1 KB  |
| PBIST0                                                 | 0x003F110000 | 0x003F110400 | 1 KB  |
| SA3_SS0_REGS                                           | 0x0040900000 | 0x0040901000 | 4 KB  |
| SA3_SS0_MMRA                                           | 0x0040901000 | 0x0040901200 | 512 B |
| SA3_SS0_EIP_76                                         | 0x0040910000 | 0x0040910080 | 128 B |
| SA3_SS0_EIP_29T2                                       | 0x0040920000 | 0x0040930000 | 64 KB |

**Table 2-1. Memory Map (continued)**

| Region                            | Start        | End          | Size   |
|-----------------------------------|--------------|--------------|--------|
| DEBUGSS0_SYS                      | 0x0041000000 | 0x0041001000 | 4 KB   |
| WKUP_ROM                          | 0x0041800000 | 0x0041840000 | 256 KB |
| STM0_STIMULUS                     | 0x0042000000 | 0x0043000000 | 16 MB  |
| WKUP_CTRL_MMR0_CFG0               | 0x0043000000 | 0x0043020000 | 128 KB |
| SA3_SS0_SEC_PROXY_SRC_TARGET_DATA | 0x0043600000 | 0x0043610000 | 64 KB  |
| SA3_SS0_ECCAGGR_CFG               | 0x0043702000 | 0x0043702400 | 1 KB   |
| hsm_sram0_1                       | 0x004406C000 | 0            | 16 KB  |
| hsm_sram1                         | 0x0044070000 | 0            | 64 KB  |
| hsm_sram0_0                       | 0x0044080000 | 0            | 128 KB |
| hsm_sram0_1                       | 0x00440A0000 | 0            | 32 KB  |
| hsm_sram0_1                       | 0x00440A8000 | 0            | 16 KB  |
| SA3_SS0_PSILCFG_CFG_PROXY         | 0x0044801000 | 0x0044801200 | 512 B  |
| SA3_SS0_PSILSS_CFG_MMRS           | 0x0044802000 | 0x0044803000 | 4 KB   |
| SA3_SS0_IPCSS_SEC_PROXY_CFG_MMRS  | 0x0044804000 | 0x0044804100 | 256 B  |
| SA3_SS0_IPCSS_RINGACC_CFG_GCFG    | 0x0044805000 | 0x0044805400 | 1 KB   |
| SA3_SS0_INTAGGR_CFG               | 0x0044808000 | 0x0044808020 | 32 B   |
| SA3_SS0_INTAGGR_CFG_IMAP          | 0x0044809000 | 0x0044809400 | 1 KB   |
| SA3_SS0_INTAGGR_CFG_MCAST         | 0x004480A000 | 0x004480A400 | 1 KB   |
| SA3_SS0_INTAGGR_CFG_GCNTCFG       | 0x004480B000 | 0x004480B400 | 1 KB   |
| SA3_SS0_INTAGGR_CFG_INTR          | 0x0044810000 | 0x0044818000 | 32 KB  |
| SA3_SS0_INTAGGR_CFG_GCNTRTI       | 0x0044820000 | 0x0044840000 | 128 KB |
| SA3_SS0_INTAGGR_CFG_UNMAP         | 0x0044840000 | 0x0044850000 | 64 KB  |
| SA3_SS0_IPCSS_SEC_PROXY_CFG_SCFG  | 0x0044860000 | 0x0044880000 | 128 KB |
| SA3_SS0_IPCSS_SEC_PROXY_CFG_RT    | 0x0044880000 | 0x00448A0000 | 128 KB |
| SA3_SS0_IPCSS_RINGACC_CFG         | 0x00448C0000 | 0x0044900000 | 256 KB |
| SA3_SS0_PKTDMA_CFG_GCFG           | 0x0044910000 | 0x0044910100 | 256 B  |
| SA3_SS0_PKTDMA_CFG_RFLOW          | 0x0044911000 | 0x0044911400 | 1 KB   |
| SA3_SS0_PKTDMA_CFG_RCHAN          | 0x0044912000 | 0x0044912400 | 1 KB   |
| SA3_SS0_PKTDMA_CFG_TCHAN          | 0x0044913000 | 0x0044913200 | 512 B  |
| SA3_SS0_PKTDMA_CFG_RCHANRT        | 0x0044914000 | 0x0044918000 | 16 KB  |
| SA3_SS0_PKTDMA_CFG_TCHANRT        | 0x0044918000 | 0x004491A000 | 8 KB   |
| SA3_SS0_PKTDMA_CFG_RING           | 0x004491A000 | 0x004491C000 | 8 KB   |
| SA3_SS0_PKTDMA_CFG_RINGRT         | 0x0044940000 | 0x0044980000 | 256 KB |
| SA3_SS0_IPCSS_RINGACC_CFG_RT      | 0x0044C00000 | 0x0045000000 | 4 MB   |
| CBASS0_FW                         | 0x0045000000 | 0x0045004000 | 16 KB  |
| WKUP_CBASS0_FW                    | 0x0045008000 | 0x0045009000 | 4 KB   |
| CBASS_CENTRAL2_FW                 | 0x0045010000 | 0x0045011000 | 4 KB   |

**Table 2-1. Memory Map (continued)**

| Region                  | Start        | End          | Size   |
|-------------------------|--------------|--------------|--------|
| PSC0_FW                 | 0x0045020000 | 0x0045020400 | 1 KB   |
| CBASS_IPCSS0_FW         | 0x0045028000 | 0x0045028800 | 2 KB   |
| CBASS_CENTRAL2_ISC      | 0x0045804000 | 0x0045804800 | 2 KB   |
| DMASS0_PKTDMA_CRED      | 0x0045810000 | 0x0045811000 | 4 KB   |
| DMASS0_BCDMA_CRED       | 0x0045812000 | 0x0045812800 | 2 KB   |
| WKUP_CBASS0_ISC         | 0x0045814000 | 0x0045815000 | 4 KB   |
| MCU_CBASS0_ISC          | 0x0045818000 | 0x0045818400 | 1 KB   |
| CBASS0_ISC              | 0x0045820000 | 0x0045828000 | 32 KB  |
| MAIN_SEC_MMR0_CFG2      | 0x0045900000 | 0x0045920000 | 128 KB |
| WKUP_WKUP_SEC_MMR0_CFG2 | 0x0045920000 | 0x0045940000 | 128 KB |
| MAIN_SEC_MMR0_CFG0      | 0x0045A00000 | 0x0045A20000 | 128 KB |
| WKUP_WKUP_SEC_MMR0_CFG0 | 0x0045A20000 | 0x0045A40000 | 128 KB |
| CBASS_IPCSS0_GLB        | 0x0045B01000 | 0x0045B01400 | 1 KB   |
| MCU_CBASS0_GLB          | 0x0045B02000 | 0x0045B02400 | 1 KB   |
| WKUP_CBASS0_GLB         | 0x0045B03000 | 0x0045B03400 | 1 KB   |
| CBASS_CENTRAL2_GLB      | 0x0045B04000 | 0x0045B04400 | 1 KB   |
| CBASS0_GLB              | 0x0045B08000 | 0x0045B08400 | 1 KB   |
| PSC0_GLB                | 0x0045B09000 | 0x0045B09400 | 1 KB   |
| CBASS_CENTRAL2_QOS      | 0x0045D04000 | 0x0045D04800 | 2 KB   |
| WKUP_CBASS0_QOS         | 0x0045D14000 | 0x0045D15000 | 4 KB   |
| MCU_CBASS0_QOS          | 0x0045D18000 | 0x0045D18400 | 1 KB   |
| CBASS0_QOS              | 0x0045D20000 | 0x0045D28000 | 32 KB  |
| DMASS0_INTAGGR_INTR     | 0x0048000000 | 0x0048100000 | 1 MB   |
| DMASS0_INTAGGR_IMAP     | 0x0048100000 | 0x0048104000 | 16 KB  |
| DMASS0_INTAGGR_CFG      | 0x0048110000 | 0x0048110020 | 32 B   |
| DMASS0_INTAGGR_L2G      | 0x0048120000 | 0x0048120400 | 1 KB   |
| DMASS0_PSILCFG_PROXY    | 0x0048130000 | 0x0048130200 | 512 B  |
| DMASS0_PSILSS_MMRS      | 0x0048140000 | 0x0048141000 | 4 KB   |
| DMASS0_INTAGGR_UNMAP    | 0x0048180000 | 0x00481A0000 | 128 KB |
| DMASS0_INTAGGR_MCAST    | 0x0048210000 | 0x0048211000 | 4 KB   |
| DMASS0_INTAGGR_GCNTCFG  | 0x0048220000 | 0x0048222000 | 8 KB   |
| DMASS0_ETLSW_MMRS       | 0x0048230000 | 0x0048231000 | 4 KB   |
| DMASS0_RINGACC_GCFG     | 0x0048240000 | 0x0048240400 | 1 KB   |
| DMASS0_SEC_PROXY_MMRS   | 0x0048250000 | 0x0048250100 | 256 B  |
| DMASS0_BCDMA_BCHAN      | 0x0048420000 | 0x0048422000 | 8 KB   |
| DMASS0_PKTDMA_RFLOW     | 0x0048430000 | 0x0048431000 | 4 KB   |
| DMASS0_PKTDMA_TCHAN     | 0x00484A0000 | 0x00484A2000 | 8 KB   |

**Table 2-1. Memory Map (continued)**

| Region                           | Start        | End          | Size   |
|----------------------------------|--------------|--------------|--------|
| DMASS0_BCDMA_TCHAN               | 0x00484A4000 | 0x00484A6000 | 8 KB   |
| DMASS0_PKTDMA_RCHAN              | 0x00484C0000 | 0x00484C2000 | 8 KB   |
| DMASS0_BCDMA_RCHAN               | 0x00484C2000 | 0x00484C4000 | 8 KB   |
| DMASS0_PKTDMA_GCFG               | 0x00485C0000 | 0x00485C0100 | 256 B  |
| DMASS0_BCDMA_GCFG                | 0x00485C0100 | 0x00485C0200 | 256 B  |
| DMASS0_PKTDMA_RING               | 0x00485E0000 | 0x00485F0000 | 64 KB  |
| DMASS0_BCDMA_RING                | 0x0048600000 | 0x0048608000 | 32 KB  |
| DMASS0_RINGACC_RT                | 0x0049000000 | 0x0049400000 | 4 MB   |
| DMASS0_RINGACC_CFG               | 0x0049800000 | 0x0049840000 | 256 KB |
| DMASS0_INTAGGR_GCNTRTI           | 0x004A000000 | 0x004A100000 | 1 MB   |
| DMASS0_SEC_PROXY_SCFG            | 0x004A400000 | 0x004A480000 | 512 KB |
| DMASS0_SEC_PROXY_RT              | 0x004A600000 | 0x004A680000 | 512 KB |
| DMASS0_PKTDMA_RCHANRT            | 0x004A800000 | 0x004A820000 | 128 KB |
| DMASS0_BCDMA_RCHANRT             | 0x004A820000 | 0x004A840000 | 128 KB |
| DMASS0_PKTDMA_TCHANRT            | 0x004AA00000 | 0x004AA20000 | 128 KB |
| DMASS0_BCDMA_TCHANRT             | 0x004AA40000 | 0x004AA60000 | 128 KB |
| DMASS0_PKTDMA_RINGRT             | 0x004B800000 | 0x004BA00000 | 2 MB   |
| DMASS0_BCDMA_RINGRT              | 0x004BC00000 | 0x004BD00000 | 1 MB   |
| DMASS0_BCDMA_BCHANRT             | 0x004C000000 | 0x004C020000 | 128 KB |
| DMASS0_SEC_PROXY_SRC_TARGET_DATA | 0x004D000000 | 0x004D080000 | 512 KB |
| GPMC0_DATA                       | 0x0050000000 | 0x0058000000 | 128 MB |
| FSS0_DAT_REG1                    | 0x0060000000 | 0x0068000000 | 128 MB |
| PSRAMECC_16K0_RAM                | 0x0070000000 | 0x0070010000 | 64 KB  |
| R5FSS0_CORE0_ICACHE              | 0x0074000000 | 0x0074800000 | 8 MB   |
| R5FSS0_CORE0_DCACHE              | 0x0074800000 | 0x0075000000 | 8 MB   |
| R5FSS0_CORE0_ATCM                | 0x0078000000 | 0x0078008000 | 32 KB  |
| R5FSS0_CORE0_BTMC                | 0x0078100000 | 0x0078108000 | 32 KB  |
| DDR16SS0_SDRAM                   | 0x0080000000 | 0x0100000000 | 2 GB   |
| FSS0_DAT_REG0                    | 0x0400000000 | 0x0500000000 | 4 GB   |
| FSS0_DAT_REG3                    | 0x0500000000 | 0x0600000000 | 4 GB   |
| DEBUGSS_WRAP0_ROM_TABLE_0_0      | 0x0700000000 | 0x0700001000 | 4 KB   |
| DEBUGSS_WRAP0_RESV0_0            | 0x0700001000 | 0x0700002000 | 4 KB   |
| DEBUGSS_WRAP0_CFGAP0             | 0x0700002000 | 0x0700002100 | 256 B  |
| DEBUGSS_WRAP0_APBAP0             | 0x0700002100 | 0x0700002200 | 256 B  |
| DEBUGSS_WRAP0_AXIAP0             | 0x0700002200 | 0x0700002300 | 256 B  |
| DEBUGSS_WRAP0_PWRAP0             | 0x0700002300 | 0x0700002400 | 256 B  |
| DEBUGSS_WRAP0_PVIEW0             | 0x0700002400 | 0x0700002500 | 256 B  |

**Table 2-1. Memory Map (continued)**

| Region                      | Start        | End          | Size   |
|-----------------------------|--------------|--------------|--------|
| DEBUGSS_WRAP0_JTAGAP0       | 0x0700002500 | 0x0700002600 | 256 B  |
| DEBUGSS_WRAP0_SECAP0        | 0x0700002600 | 0x0700002700 | 256 B  |
| DEBUGSS_WRAP0_CORTEX0_CFG0  | 0x0700002700 | 0x0700002800 | 256 B  |
| DEBUGSS_WRAP0_CORTEX1_CFG0  | 0x0700002800 | 0x0700002900 | 256 B  |
| DEBUGSS_WRAP0_CORTEX2_CFG0  | 0x0700002900 | 0x0700002A00 | 256 B  |
| DEBUGSS_WRAP0_CORTEX3_CFG0  | 0x0700002A00 | 0x0700002B00 | 256 B  |
| DEBUGSS_WRAP0_CORTEX4_CFG0  | 0x0700002B00 | 0x0700002C00 | 256 B  |
| DEBUGSS_WRAP0_CORTEX5_CFG0  | 0x0700002C00 | 0x0700002D00 | 256 B  |
| DEBUGSS_WRAP0_CORTEX6_CFG0  | 0x0700002D00 | 0x0700002E00 | 256 B  |
| DEBUGSS_WRAP0_CORTEX7_CFG0  | 0x0700002E00 | 0x0700002F00 | 256 B  |
| DEBUGSS_WRAP0_CORTEX8_CFG0  | 0x0700002F00 | 0x0700003000 | 256 B  |
| DEBUGSS_WRAP0_RESV1_0       | 0x0700003000 | 0x0700004000 | 4 KB   |
| DEBUGSS_WRAP0_RESV2_0       | 0x0700004000 | 0x072004000  | 32 MB  |
| DEBUGSS_WRAP0_ROM_TABLE_1_0 | 0x0720000000 | 0x0720001000 | 4 KB   |
| DEBUGSS_WRAP0_CSCTI0        | 0x0720001000 | 0x0720002000 | 4 KB   |
| DEBUGSS_WRAP0_DRM0          | 0x0720002000 | 0x0720003000 | 4 KB   |
| DEBUGSS_WRAP0_RESV3_0       | 0x0720003000 | 0x0720004000 | 4 KB   |
| DEBUGSS_WRAP0_CSTPIU0       | 0x0720004000 | 0x0720005000 | 4 KB   |
| DEBUGSS_WRAP0_CTF0          | 0x0720005000 | 0x0720006000 | 4 KB   |
| DEBUGSS_WRAP0_RESV4_0       | 0x0720006000 | 0x0721006000 | 16 MB  |
| COMPUTE_CLUSTER0_SS_ROM     | 0x0730000000 | 0x0730010000 | 64 KB  |
| DEBUGSS_WRAP0_EXT_APB0      | 0x0730000000 | 0x0740000000 | 256 MB |
| COMPUTE_CLUSTER0_CORE0_DBG  | 0x0730010000 | 0x0730020000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE0_CTI  | 0x0730020000 | 0x0730030000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE0_PMU  | 0x0730030000 | 0x0730040000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE0_ETM  | 0x0730040000 | 0x0730050000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE1_DBG  | 0x0730110000 | 0x0730120000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE1_PMU  | 0x0730120000 | 0x0730130000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE1_ETM  | 0x0730130000 | 0x0730140000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE1_CTI  | 0x0730140000 | 0x0730150000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE2_DBG  | 0x0730210000 | 0x0730220000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE2_PMU  | 0x0730220000 | 0x0730230000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE2_ETM  | 0x0730230000 | 0x0730240000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE2_CTI  | 0x0730240000 | 0x0730250000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE3_DBG  | 0x0730310000 | 0x0730320000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE3_PMU  | 0x0730320000 | 0x0730330000 | 64 KB  |
| COMPUTE_CLUSTER0_CORE3_ETM  | 0x0730330000 | 0x0730340000 | 64 KB  |

**Table 2-1. Memory Map (continued)**

| Region                                          | Start        | End          | Size  |
|-------------------------------------------------|--------------|--------------|-------|
| COMPUTE_CLUSTER0_CORE3_CTL                      | 0x0730340000 | 0x0730350000 | 64 KB |
| DEBUGSS0_ROM                                    | 0x073C020000 | 0x073C021000 | 4 KB  |
| DEBUGSS0_CTSET2_WRAP_CFG_CTSET2_CFG             | 0x073C022000 | 0x073C024000 | 8 KB  |
| DEBUGSS0_ATB_REPLICATOR_CFG_CXATBREPLICATOR_CFG | 0x073C024000 | 0x073C025000 | 4 KB  |
| DEBUGSS0_TBR_VBUSB_WRAP_TBR_CFG_TBR_CFG         | 0x073C025000 | 0x073C026000 | 4 KB  |
| DEBUGSS0_ARM_CTL_0_CFG_CSCTI_CFG                | 0x073C026000 | 0x073C027000 | 4 KB  |
| DEBUGSS0_ARM_CTL_1_CFG_CSCTI_CFG                | 0x073C028000 | 0x073C029000 | 4 KB  |
| DEBUGSS0_ARM_CTL_2_CFG_CSCTI_CFG                | 0x073C029000 | 0x073C02A000 | 4 KB  |
| DEBUGSS0_ARM_CTL_3_CFG_CSCTI_CFG                | 0x073C02A000 | 0x073C02B000 | 4 KB  |
| DEBUGSS0_ARM_CTL_4_CFG_CSCTI_CFG                | 0x073C02B000 | 0x073C02C000 | 4 KB  |
| DEBUGSS0_ARM_CTL_5_CFG_CSCTI_CFG                | 0x073C02C000 | 0x073C02D000 | 4 KB  |
| DEBUGSS0_ARM_CTL_6_CFG_CSCTI_CFG                | 0x073C02D000 | 0x073C02E000 | 4 KB  |
| DEBUGSS0_ARM_CTL_7_CFG_CSCTI_CFG                | 0x073C02E000 | 0x073C02F000 | 4 KB  |
| DEBUGSS0_ARM_CTL_8_CFG_CSCTI_CFG                | 0x073C02F000 | 0x073C030000 | 4 KB  |
| STM0_CXSTM                                      | 0x073D200000 | 0x073D201000 | 4 KB  |
| STM0_CTL_CSCTI                                  | 0x073D201000 | 0x073D202000 | 4 KB  |
| DBGSUSPENDROUTER0_INTR_ROUTER_CFG               | 0x073D300000 | 0x073D300800 | 2 KB  |
| 0                                               | 0x073D400000 | 0            | 0     |
| CPT2_AGGR0_MMR                                  | 0x073E100000 | 0x073E100100 | 256 B |
| CPT2_AGGR0_STP2ATB_CFG                          | 0x073E100100 | 0x073E100200 | 256 B |
| CPT2_AGGR0_MEM0                                 | 0x073E120000 | 0x073E121000 | 4 KB  |
| CPT2_AGGR0_MEM1                                 | 0x073E121000 | 0x073E122000 | 4 KB  |
| CPT2_AGGR0_MEM2                                 | 0x073E122000 | 0x073E123000 | 4 KB  |
| CPT2_AGGR0_MEM3                                 | 0x073E123000 | 0x073E124000 | 4 KB  |
| CPT2_AGGR0_MEM4                                 | 0x073E124000 | 0x073E125000 | 4 KB  |
| CPT2_AGGR0_MEM5                                 | 0x073E125000 | 0x073E126000 | 4 KB  |
| CPT2_AGGR0_MEM6                                 | 0x073E126000 | 0x073E127000 | 4 KB  |
| CPT2_AGGR0_MEM7                                 | 0x073E127000 | 0x073E128000 | 4 KB  |
| CPT2_AGGR0_MEM8                                 | 0x073E128000 | 0x073E129000 | 4 KB  |
| CPT2_AGGR0_MEM9                                 | 0x073E129000 | 0x073E12A000 | 4 KB  |
| CPT2_AGGR0_MEM10                                | 0x073E12A000 | 0x073E12B000 | 4 KB  |
| CPT2_AGGR0_MEM11                                | 0x073E12B000 | 0x073E12C000 | 4 KB  |
| CPT2_AGGR0_MEM12                                | 0x073E12C000 | 0x073E12D000 | 4 KB  |
| CPT2_AGGR0_MEM13                                | 0x073E12D000 | 0x073E12E000 | 4 KB  |
| CPT2_AGGR0_MEM14                                | 0x073E12E000 | 0x073E12F000 | 4 KB  |
| CPT2_AGGR0_MEM15                                | 0x073E12F000 | 0x073E130000 | 4 KB  |
| CPT2_AGGR0_MEM16                                | 0x073E130000 | 0x073E131000 | 4 KB  |

Table 2-1. Memory Map (continued)

| Region                 | Start        | End          | Size  |
|------------------------|--------------|--------------|-------|
| CPT2_AGGR0_MEM17       | 0x073E131000 | 0x073E132000 | 4 KB  |
| CPT2_AGGR0_MEM18       | 0x073E132000 | 0x073E133000 | 4 KB  |
| CPT2_AGGR0_MEM19       | 0x073E133000 | 0x073E134000 | 4 KB  |
| CPT2_AGGR0_MEM20       | 0x073E134000 | 0x073E135000 | 4 KB  |
| CPT2_AGGR0_MEM21       | 0x073E135000 | 0x073E136000 | 4 KB  |
| CPT2_AGGR0_MEM22       | 0x073E136000 | 0x073E137000 | 4 KB  |
| CPT2_AGGR0_MEM23       | 0x073E137000 | 0x073E138000 | 4 KB  |
| CPT2_AGGR0_MEM24       | 0x073E138000 | 0x073E139000 | 4 KB  |
| CPT2_AGGR0_MEM25       | 0x073E139000 | 0x073E13A000 | 4 KB  |
| CPT2_AGGR0_MEM26       | 0x073E13A000 | 0x073E13B000 | 4 KB  |
| CPT2_AGGR0_MEM27       | 0x073E13B000 | 0x073E13C000 | 4 KB  |
| CPT2_AGGR0_MEM28       | 0x073E13C000 | 0x073E13D000 | 4 KB  |
| CPT2_AGGR0_MEM29       | 0x073E13D000 | 0x073E13E000 | 4 KB  |
| CPT2_AGGR0_MEM30       | 0x073E13E000 | 0x073E13F000 | 4 KB  |
| CPT2_AGGR0_MEM31       | 0x073E13F000 | 0x073E140000 | 4 KB  |
| CPT2_AGGR1_MMR         | 0x073E140000 | 0x073E140100 | 256 B |
| CPT2_AGGR1_STP2ATB_CFG | 0x073E140100 | 0x073E140200 | 256 B |
| CPT2_AGGR1_MEM0        | 0x073E160000 | 0x073E161000 | 4 KB  |
| CPT2_AGGR1_MEM1        | 0x073E161000 | 0x073E162000 | 4 KB  |
| CPT2_AGGR1_MEM2        | 0x073E162000 | 0x073E163000 | 4 KB  |
| CPT2_AGGR1_MEM3        | 0x073E163000 | 0x073E164000 | 4 KB  |
| CPT2_AGGR1_MEM4        | 0x073E164000 | 0x073E165000 | 4 KB  |
| CPT2_AGGR1_MEM5        | 0x073E165000 | 0x073E166000 | 4 KB  |
| CPT2_AGGR1_MEM6        | 0x073E166000 | 0x073E167000 | 4 KB  |
| CPT2_AGGR1_MEM7        | 0x073E167000 | 0x073E168000 | 4 KB  |
| CPT2_AGGR1_MEM8        | 0x073E168000 | 0x073E169000 | 4 KB  |
| CPT2_AGGR1_MEM9        | 0x073E169000 | 0x073E16A000 | 4 KB  |
| CPT2_AGGR1_MEM10       | 0x073E16A000 | 0x073E16B000 | 4 KB  |
| CPT2_AGGR1_MEM11       | 0x073E16B000 | 0x073E16C000 | 4 KB  |
| CPT2_AGGR1_MEM12       | 0x073E16C000 | 0x073E16D000 | 4 KB  |
| CPT2_AGGR1_MEM13       | 0x073E16D000 | 0x073E16E000 | 4 KB  |
| CPT2_AGGR1_MEM14       | 0x073E16E000 | 0x073E16F000 | 4 KB  |
| CPT2_AGGR1_MEM15       | 0x073E16F000 | 0x073E170000 | 4 KB  |
| CPT2_AGGR1_MEM16       | 0x073E170000 | 0x073E171000 | 4 KB  |
| CPT2_AGGR1_MEM17       | 0x073E171000 | 0x073E172000 | 4 KB  |
| CPT2_AGGR1_MEM18       | 0x073E172000 | 0x073E173000 | 4 KB  |
| CPT2_AGGR1_MEM19       | 0x073E173000 | 0x073E174000 | 4 KB  |

**Table 2-1. Memory Map (continued)**

| Region                      | Start        | End          | Size  |
|-----------------------------|--------------|--------------|-------|
| CPT2_AGGR1_MEM20            | 0x073E174000 | 0x073E175000 | 4 KB  |
| CPT2_AGGR1_MEM21            | 0x073E175000 | 0x073E176000 | 4 KB  |
| CPT2_AGGR1_MEM22            | 0x073E176000 | 0x073E177000 | 4 KB  |
| CPT2_AGGR1_MEM23            | 0x073E177000 | 0x073E178000 | 4 KB  |
| CPT2_AGGR1_MEM24            | 0x073E178000 | 0x073E179000 | 4 KB  |
| CPT2_AGGR1_MEM25            | 0x073E179000 | 0x073E17A000 | 4 KB  |
| CPT2_AGGR1_MEM26            | 0x073E17A000 | 0x073E17B000 | 4 KB  |
| CPT2_AGGR1_MEM27            | 0x073E17B000 | 0x073E17C000 | 4 KB  |
| CPT2_AGGR1_MEM28            | 0x073E17C000 | 0x073E17D000 | 4 KB  |
| CPT2_AGGR1_MEM29            | 0x073E17D000 | 0x073E17E000 | 4 KB  |
| CPT2_AGGR1_MEM30            | 0x073E17E000 | 0x073E17F000 | 4 KB  |
| CPT2_AGGR1_MEM31            | 0x073E17F000 | 0x073E180000 | 4 KB  |
| DEBUGSS_WRAP0_ROM_TABLE_0_1 | 0x0740000000 | 0x0740001000 | 4 KB  |
| DEBUGSS_WRAP0_RESV0_1       | 0x0740001000 | 0x0740002000 | 4 KB  |
| DEBUGSS_WRAP0_CFGAP1        | 0x0740002000 | 0x0740002100 | 256 B |
| DEBUGSS_WRAP0_APBAP1        | 0x0740002100 | 0x0740002200 | 256 B |
| DEBUGSS_WRAP0_AXIAP1        | 0x0740002200 | 0x0740002300 | 256 B |
| DEBUGSS_WRAP0_PWRAP1        | 0x0740002300 | 0x0740002400 | 256 B |
| DEBUGSS_WRAP0_PVIEW1        | 0x0740002400 | 0x0740002500 | 256 B |
| DEBUGSS_WRAP0_JTAGAP1       | 0x0740002500 | 0x0740002600 | 256 B |
| DEBUGSS_WRAP0_SECAP1        | 0x0740002600 | 0x0740002700 | 256 B |
| DEBUGSS_WRAP0_CORTEX0_CFG1  | 0x0740002700 | 0x0740002800 | 256 B |
| DEBUGSS_WRAP0_CORTEX1_CFG1  | 0x0740002800 | 0x0740002900 | 256 B |
| DEBUGSS_WRAP0_CORTEX2_CFG1  | 0x0740002900 | 0x0740002A00 | 256 B |
| DEBUGSS_WRAP0_CORTEX3_CFG1  | 0x0740002A00 | 0x0740002B00 | 256 B |
| DEBUGSS_WRAP0_CORTEX4_CFG1  | 0x0740002B00 | 0x0740002C00 | 256 B |
| DEBUGSS_WRAP0_CORTEX5_CFG1  | 0x0740002C00 | 0x0740002D00 | 256 B |
| DEBUGSS_WRAP0_CORTEX6_CFG1  | 0x0740002D00 | 0x0740002E00 | 256 B |
| DEBUGSS_WRAP0_CORTEX7_CFG1  | 0x0740002E00 | 0x0740002F00 | 256 B |
| DEBUGSS_WRAP0_CORTEX8_CFG1  | 0x0740002F00 | 0x0740003000 | 256 B |
| DEBUGSS_WRAP0_RESV1_1       | 0x0740003000 | 0x0740004000 | 4 KB  |
| DEBUGSS_WRAP0_RESV2_1       | 0x0740004000 | 0x0742004000 | 32 MB |
| DEBUGSS_WRAP0_ROM_TABLE_1_1 | 0x0760000000 | 0x0760001000 | 4 KB  |
| DEBUGSS_WRAP0_CSCTI1        | 0x0760001000 | 0x0760002000 | 4 KB  |
| DEBUGSS_WRAP0_DRM1          | 0x0760002000 | 0x0760003000 | 4 KB  |
| DEBUGSS_WRAP0_RESV3_1       | 0x0760003000 | 0x0760004000 | 4 KB  |
| DEBUGSS_WRAP0_CSTPIU1       | 0x0760004000 | 0x0760005000 | 4 KB  |

**Table 2-1. Memory Map (continued)**

| Region                 | Start        | End          | Size   |
|------------------------|--------------|--------------|--------|
| DEBUGSS_WRAP0_CTF1     | 0x0760005000 | 0x0760006000 | 4 KB   |
| DEBUGSS_WRAP0_RESV4_1  | 0x0760006000 | 0x0761006000 | 16 MB  |
| DEBUGSS_WRAP0_EXT_APB1 | 0x0770000000 | 0x0780000000 | 256 MB |
| DDR16SS0_SDRAM         | 0x0880000000 | 0x0900000000 | 2 GB   |
| DDR16SS0_SDRAM         | 0x0900000000 | 0x0A00000000 | 4 GB   |

## 2.2 SoC Address Aliasing

In general, a single end point has a unique address assignment in the common SoC memory map. However, there are some exceptions.

The I/D RAM for HSM M4F has two sets of the SoC level address assignments shown in [Table 2-2](#). The purpose of this SoC level address aliasing is to provide a single continuous memory view for TIFS core, if the TIFS code is more than 276KB by utilizing the HSM's I/D RAM.

**Table 2-2. AM62 SoC Level Address Aliasing**

| Memory End Points | Size | SoC address | Aliased address in the common 36b SoC address map |
|-------------------|------|-------------|---------------------------------------------------|
| hsm_sram0_0       | 128K | 0x43C0_0000 | 0x4408_0000                                       |
| hsm_sram0_1       | 32K  | 0x43C2_0000 | 0x440A_0000                                       |
| hsm_sram0_2       | 16K  | 0x43C2_8000 | 0x440A_8000                                       |
| hsm_sram0_3       | 16K  | 0x43C2_c000 | 0x4406_c000                                       |
| hsm_sram1         | 64K  | 0x43C3_0000 | 0x4407_0000                                       |

## 2.3 Processor Memory Map View

Since AM62 is built on 36b physical address, there are memory regions beyond 4GB address, such as DDR data space and debug configuration space. This is not a problem for the ARM V8 core such as A53, since it supports up to 44b physical address. However, for the micro control processor such as M4F and R5, the processor only natively supports 32b physical address space. In order to allow those micro controllers accessing the full 36b physical address space, a region based remapping module is dedicated for each processor.

### 2.3.1 A53 Memory View

All the A53 cores use the common 36b SoC memory map shown in [Section 2.1](#) for its physical address map. Since A53 natively supports up to 44b physical address, if A53 issues any transaction with non-zero upper 8 physical address bits, those upper 8 address bits are ignored by SoC address decoding logic.

Sitara's SoC memory map is constructed to allow software utilizing bigger MMU page. The majority of the peripherals are put at 64KB aligned boundary. This is to allow A53 software to use 64KB MMU page to manage individual peripherals instead of using 4KB MMU page. There are a few exceptions.

Main domain GPIO is implemented by using two GPIO modules. However, these two GPIO modules are putting back to back together. Software needs to manage two GPIO modules using a single MMU page. Since each GPIO pin is managed by a single bit inside GPIO registers, there is no virtual machine or OS isolation implemented.

SoC also contains multiple DCC modules and they are put at 4KB boundary instead of 64KB. A53 software can still use 64KB MMU page to manage those DCC modules. If any of the DCC needs to be allocated for other processors, the region-based firewall can provide the additional isolation needed. The firewall granularity is at 4KB boundary, which allows each DDC is assigned individually.

Firewall, QoS, ISC configurations are not on 64KB boundary. And each individual firewall module, QoS module and ISC module are put at 1KB boundary.

### 2.3.2 HSM M4F Memory View

HSM M4F micro-controller core is natively 32b processor. A dedicated RAT module is added to allow M4F processor to access full 36b common SoC address map.

**Table 2-3. HSM M4F Memory View**

| Start Address<br>(32 bit) | End Address<br>(32 bit) | Which end points HSM M4F access?                                                                                                                                  | Additional Notes                                                         |
|---------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| 0x0000_0000               | 0x0002_FFFF             | <b>HSM SRAM –Bank0</b>                                                                                                                                            | Other initiators use address 0x43C0_0000 and aliased address 0x4408_000  |
| 0x0003_0000               | 0x0003_FFFF             | <b>HSM SRAM –Bank1</b>                                                                                                                                            | Other initiators use address 0x43C3_0000 and aliased address 0x4407_0000 |
| 0x0004_0000               | 0x00FF_FFFF             | <b>Any transactions hitting this address range go through RAT address re-mapping to 36b common SoC memory map except address range 0x4370_0000 to 0x47FF_FFFF</b> |                                                                          |
| 0x0010_0000               | 0x4370_1FFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                                          |
| 0x4370_2000               | 0x4370_23FF             | <b>DMSS_HSM ECC AGGR</b>                                                                                                                                          |                                                                          |
| 0x4370_2400               | 0x4393_4FFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                                          |
| 0x4393_5000               | 0x4393_50FF             | <b>HSM WW-RTI</b>                                                                                                                                                 |                                                                          |
| 0x4393_5100               | 0x4393_5FFF             | <b>Reserved</b>                                                                                                                                                   |                                                                          |
| 0x4393_6000               | 0x4393_6FFF             | <b>HSM CTRL</b>                                                                                                                                                   |                                                                          |
| 0x4393_7000               | 0x439F_FFFF             | <b>Reserved</b>                                                                                                                                                   |                                                                          |
| 0x43A0_0000               | 0x43A0_0FFF             | <b>HSM RAT config</b>                                                                                                                                             |                                                                          |
| 0x43A0_1000               | 0x43A0_1FFF             | <b>Reserved</b>                                                                                                                                                   |                                                                          |
| 0x43A0_2000               | 0x43A0_23FF             | <b>HSM ECC Aggregator</b>                                                                                                                                         | Other initiators use address 0x4370_1000                                 |
| 0x43A0_2400               | 0x4403_FFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                                          |
| 0x4413_3000               | 0x4413_33FF             | <b>Timer0</b>                                                                                                                                                     |                                                                          |
| 0x4413_3400               | 0x4413_3FFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                                          |
| 0x4413_4000               | 0x4413_43FF             | <b>Timer1</b>                                                                                                                                                     |                                                                          |
| 0x4413_4400               | 0x4413_51FF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                                          |
| 0x4423_0000               | 0x4423_0FFF             | <b>Security control Registers</b>                                                                                                                                 |                                                                          |
| 0x4423_4000               | 0x4423_7FFF             | <b>Security Manager (KS3)</b>                                                                                                                                     |                                                                          |
| 0x4423_8000               | 0x4423_83FF             | <b>Timer2</b>                                                                                                                                                     |                                                                          |
| 0x4423_8400               | 0x4433_8FFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                                          |
| 0x4423_9000               | 0x4423_93FF             | <b>Timer3</b>                                                                                                                                                     |                                                                          |

Table 2-3. HSM M4F Memory View (continued)

| Start Address<br>(32 bit) | End Address<br>(32 bit) | Which end points HSM M4F access?                                                                                                                                  | Additional Notes                                |
|---------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| 0x4423_9400               | 0x4423_AFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                 |
| 0x4423_C000               | 0x4423_DFFF             | <b>AES Module</b>                                                                                                                                                 |                                                 |
| 0x4423_E000               | 0x442F_FFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                 |
| 0x4430_0000               | 0x443F_FFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                 |
| 0x4440_0000               | 0x4440_FFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                 |
| 0x4441_0000               | 0x4441_FFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                 |
| 0x4442_0000               | 0x447F_FFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                 |
| 0x4480_0000               | 0x44FF_FFFF             | <b>DMSS_HSM Interface</b>                                                                                                                                         |                                                 |
| 0x4500_0000               | 0x45FF_FFFF             | <b>Firewall /ISC/QoS configuration</b>                                                                                                                            |                                                 |
| 0x4600_0000               | 0x5FFF_FFFF             | transaction will be gracefully terminated. M4F receives an exception.                                                                                             |                                                 |
| 0x6000_0000               | 0xDFFF_FFFF             | <b>Any transactions hitting this address range go through RAT address re-mapping to 36b common SoC memory map except address range 0x4370_0000 to 0x47FF_FFFF</b> |                                                 |
| 0xE000_0000               | 0xE000_0FFF             | <b>HSM M4F ITM</b>                                                                                                                                                | Other initiators can't access those end points. |
| 0xE000_1000               | 0xE000_1FFF             | <b>HSM M4F DWT</b>                                                                                                                                                |                                                 |
| 0xE000_2000               | 0xE000_2FFF             | <b>HSM M4F FBP</b>                                                                                                                                                |                                                 |
| 0xE000_E000               | 0xE000_EFFF             | <b>HSM M4F SCS</b>                                                                                                                                                |                                                 |
| 0xE004_1000               | 0xE004_1FFF             | <b>HSM M4F ETM</b>                                                                                                                                                |                                                 |
| 0xE004_2000               | 0xE004_2FFF             | <b>HSM M4F CTI</b>                                                                                                                                                |                                                 |
| 0xE004_3000               | 0xE004_0003             | <b>HSM M4F REVID</b>                                                                                                                                              |                                                 |
| 0xE00F_F000               | 0xE010_0000             | <b>HSM M4F ROM Table</b>                                                                                                                                          |                                                 |
| 0xE010_0000               | 0xFFFF_FFFF             | <b>Reserved</b>                                                                                                                                                   |                                                 |

The address aliasing implemented on the SoC level allows HSM M4F and other initiators uses the I/D SRAM for both HSM and TIFS as a single continuous memory block.

### 2.3.3 MCU M4F Memory View

MCU domain has a M4F micro-controller core, which is natively 32b processor. A dedicated RAT module is added to allow M4F processor to access full 36b common SoC address map.

**Table 2-4. MCU M4F Memory Map View**

| CortexM4 Start Address (32 bit) | CortexM4 End Address (32 bit) | Which end points MCU M4F will access                                                                                                                | Additional Description                                                                                               |
|---------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| 0x0000_0000                     | 0x0002_FFFF                   | <b>MCU M4F's I-RAM</b>                                                                                                                              | Other initiator access MCU M4F's I-RAM using address 0x0500_0000                                                     |
| 0x0003_0000                     | 0x0003_FFFF                   | MCU M4F's D-RaM                                                                                                                                     | Other initiator access MCU M4F's I-RAM using address 0x0504_0000                                                     |
| 0x0004_0000                     | 0x0083_FFFF                   | <b>Any transactions hitting this address range coming from MCU M4F will go through RAT for address re-mapping before reaching other end points.</b> | Can be mapped to any memory regions in the SoC common memory map except MCU M4F's I/D RAM.                           |
| 0x0084_0000                     | 0x441F_FFFF                   | <b>Reserved region. Any transaction coming from M4F hitting this region will be gracefully terminated</b>                                           |                                                                                                                      |
| 0x4420_0000                     | 0x4420_0FFF                   | <b>MCU M4F core's RAT config</b>                                                                                                                    | Other initiators access this end point using the SoC common memory map place MCU M4F's RAT config at 0x05FF_0000     |
| 0x4420_1000                     | 0x4420_13FF                   | MCU M4F core's ECC Aggregator                                                                                                                       | Other initiators access this end point using the SoC common memory map place MCU M4F's ECC aggregator at 0x05FF_1000 |
| 0x4420_1400                     | 0x5FFF_FFFF                   | <b>Reserved region. Any transaction coming from M4F hitting this region will be gracefully terminated</b>                                           |                                                                                                                      |
| 0x6000_0000                     | 0xDFFF_FFFF                   | <b>Any transactions hitting this address range coming from MCU M4F will go through RAT for address re-mapping before reaching other end points.</b> | Can be mapped to any memory regions in the SoC common memory map except MCU M4F's I/D RAM.                           |
| 0xE000_0000                     | 0xE000_0FFF                   | <b>MCU M4F core's ITM</b>                                                                                                                           | Only visible by MCU M4F core itself.                                                                                 |
| 0xE000_1000                     | 0xE000_1FFF                   | <b>MCU M4F core's DWT</b>                                                                                                                           |                                                                                                                      |
| 0xE000_2000                     | 0xE000_2FFF                   | <b>MCU M4F core's FBP</b>                                                                                                                           |                                                                                                                      |
| 0xE000_E000                     | 0xE000_EFFF                   | <b>MCU M4F core's SCS</b>                                                                                                                           |                                                                                                                      |
| 0xE004_2000                     | 0xE004_2FFF                   | <b>MCU M4F core's CTI</b>                                                                                                                           |                                                                                                                      |
| 0xE000_E000                     | 0xE000_E4EF                   | <b>MCU M4F core's NVIC config region</b>                                                                                                            |                                                                                                                      |
| 0xE00F_F000                     |                               | <b>MCU M4F core's ROM Table</b>                                                                                                                     |                                                                                                                      |
| 0xE010_0000                     | 0xFFFF_FFFF                   | <b>Any transactions hitting this address range coming from MCU M4F will go through RAT for address re-mapping before reaching other end points.</b> |                                                                                                                      |

### 2.3.4 WKUP R5 Memory View

AM62 has one single R5 core in the wakeup domain. R5 is a native 32b processor, which R5 core itself can only generate transactions using 32b address. A dedicated RAT module is integrated for this single core R5 to allow R5 software to remap the 32b R5 address into the common 36b SoC address.

In addition, R5 core has its own TCM, which R5 core can access with its TCM with a single R5 core cycle. Those TCM memories have two sets of address, one set address is used for R5 core for a single cycle access to those TCM. The second set of address is used by other initiators outside this R5 subsystem to access those TCM. R5

core shall always uses the first set of address to access its TCM. If R5 core utilizes the second set of address to those TCM, R5 core will receives an exception, since those transactions will be routed to be terminated by sending them to the null end point.

While the SoC level address for TCM is fixed, the address used by R5 to access to its own TCM can be remapped by software. By default, AM62 puts R5's ATCM at address 0x0 and the BTM address at 0x4101\_0000.

R5 also has one section of the region dedicated for peripheral access from address 0x2000\_0000 to 0x2FFF\_FFFF. This memory region is treated as normally memory, which can't be cached. R5 accesses this memory region through a dedicated single-issue interface, and none of the transactions accessing this memory region can be remapped by using RAT module.

R5 core accesses its own ATCM and BTM memory directly, and there is no address remapping for those access. All the other access than ATCM, BTM and address range 0x2000\_0000 to 0x2FFF\_FFFF from R5 core go through RAT module, which could be remapped into different address to access the rest of the SoC using the common 36b SoC memory map.



**Figure 2-1. WKUP R5 32b Address Map View (Default)**

The common SoC memory map assigns R5's ATCM and BTM to address 0x7800\_0000 and 0x7810\_0000. R5 software can optionally reprogram its internal ATCM and BTM address to match the address assigned by the common SoC memory map as well. Regardless where R5 puts its own ATCM and BTM, R5 accesses its own ATCM and BTM directly without going through RAT.

ATCM is by default disabled at address 0x0. BTM is by default enabled and the default address for BTM is 0x4101\_0000. The base address of VIM is at 0x2FFF\_0000 and the base address for RAT configuration is at 0x2FFE\_0000.

All the R5 transactions can go through RAT for address re-mapping function except the transactions targeted to address range 0x2000\_0000 to 0x2FFF\_FFFF and its own ATCM and BTM. It is highly recommended only remap R5's address range from 0x8000\_0000 to 0xFFFF\_FFFF to access the target region located at the common memory map between 0x8000\_0000 and 0xF\_FFFF\_FFFF.

## 2.4 Memory Map Summary

Since different type of the processors have different memory map views, this section provides a summary on how each type of processor and initiator access various target end points within the SoC.

**Table 2-5. Memory Map Summary**

| Memory Region Name                 | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|------------------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| PSRAMECC0_RAM                      | 0x00000000                               | via RAT        | via RAT               | via RAT              |
| PADCCTRL0_CFG0                     | 0x000F0000                               | via RAT        | via RAT               | via RAT              |
| CTRL_MMR0_CFG0                     | 0x00100000                               | via RAT        | via RAT               | via RAT              |
| CBASS_DBG0_ERR                     | 0x00200000                               | via RAT        | via RAT               | via RAT              |
| CBASS_INFRA1_ERR                   | 0x00210000                               | via RAT        | via RAT               | via RAT              |
| CBASS_FW0_ERR                      | 0x00220000                               | via RAT        | via RAT               | via RAT              |
| CBASS_IPCSS0_ERR                   | 0x00230000                               | via RAT        | via RAT               | via RAT              |
| CBASS_MCASPO_ERR                   | 0x00240000                               | via RAT        | via RAT               | via RAT              |
| EFUSE0                             | 0x00300000                               | via RAT        | via RAT               | via RAT              |
| PBIST1                             | 0x00310000                               | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_PBIST             | 0x00330000                               | via RAT        | via RAT               | via RAT              |
| PSC0                               | 0x00400000                               | via RAT        | via RAT               | via RAT              |
| PLLCTRL0                           | 0x00410000                               | via RAT        | via RAT               | via RAT              |
| ESM0_CFG                           | 0x00420000                               | via RAT        | via RAT               | via RAT              |
| DFTSS0                             | 0x00500000                               | via RAT        | via RAT               | via RAT              |
| DDPA0                              | 0x00580000                               | via RAT        | via RAT               | via RAT              |
| GPIO0                              | 0x00600000                               | via RAT        | via RAT               | via RAT              |
| GPIO1                              | 0x00601000                               | via RAT        | via RAT               | via RAT              |
| PLL0_CFG                           | 0x00680000                               | via RAT        | via RAT               | via RAT              |
| PSRAMECC0_ECC_AGG_R                | 0x00700000                               | via RAT        | via RAT               | via RAT              |
| PSC0_REGS                          | 0x00700400                               | via RAT        | via RAT               | via RAT              |
| USB0_DEBUG_TRACE_MMR_TRACE_VBUSP_U | 0x00703000                               | via RAT        | via RAT               | via RAT              |
| SB2SS_DEBUG_TRACE                  |                                          |                |                       |                      |
| CPSW0_ECC                          | 0x00704000                               | via RAT        | via RAT               | via RAT              |
| MMCSD0_ECC_AGG_R_XMEM              | 0x00706000                               | via RAT        | via RAT               | via RAT              |
| MMCSD0_ECC_AGG_T_XMEM              | 0x00707000                               | via RAT        | via RAT               | via RAT              |
| MMCSD1_ECC_AGG_R_XMEM              | 0x00708000                               | via RAT        | via RAT               | via RAT              |
| MMCSD1_ECC_AGG_T_XMEM              | 0x00709000                               | via RAT        | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name                                 | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|----------------------------------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| MMCSD2_ECC_AGGR_T_XMEM                             | 0x0070A000                               | via RAT        | via RAT               | via RAT              |
| MMCSD2_ECC_AGGR_R_XMEM                             | 0x0070B000                               | via RAT        | via RAT               | via RAT              |
| USB1_DEBUG_TRACE_MMR_TRACE_VBUSB_UB2SS_DEBUG_TRACE | 0x0070C000                               | via RAT        | via RAT               | via RAT              |
| CSI_RX_IF0_ECC_AGGR_CFG                            | 0x0070E000                               | via RAT        | via RAT               | via RAT              |
| SA3_SS0_ECC_AGGR                                   | 0x00712000                               | via RAT        | via RAT               | via RAT              |
| FSS0_OSP10_ECC_ANGER                               | 0x00716000                               | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_SS_ECC_AGGR                       | 0x00718000                               | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE0_ECC_AGGR                    | 0x00718400                               | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE1_ECC_AGGR                    | 0x00718800                               | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE2_ECC_AGGR                    | 0x00718C00                               | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE3_ECC_AGGR                    | 0x00719000                               | via RAT        | via RAT               | via RAT              |
| DCC0                                               | 0x00800000                               | via RAT        | via RAT               | via RAT              |
| DCC1                                               | 0x00804000                               | via RAT        | via RAT               | via RAT              |
| DCC2                                               | 0x00808000                               | via RAT        | via RAT               | via RAT              |
| DCC3                                               | 0x0080C000                               | via RAT        | via RAT               | via RAT              |
| DCC4                                               | 0x00810000                               | via RAT        | via RAT               | via RAT              |
| DCC5                                               | 0x00814000                               | via RAT        | via RAT               | via RAT              |
| DCC6                                               | 0x00818000                               | via RAT        | via RAT               | via RAT              |
| MAIN_GPIOMUX_INTRO_UTER0_INTR_ROUTER_CFG           | 0x00A00000                               | via RAT        | via RAT               | via RAT              |
| CMP_EVENT_INTRROUTE_R0_INTR_ROUTER_CFG             | 0x00A30000                               | via RAT        | via RAT               | via RAT              |
| TIMESYNC_EVENT_ROUTER0_INTR_ROUTER_CFG             | 0x00A40000                               | via RAT        | via RAT               | via RAT              |
| WKUP_GTC0_GTC_CFG_0                                | 0x00A80000                               | via RAT        | via RAT               | via RAT              |
| WKUP_GTC0_GTC_CFG_1                                | 0x00A90000                               | via RAT        | via RAT               | via RAT              |
| WKUP_GTC0_GTC_CFG_2                                | 0x00AA0000                               | via RAT        | via RAT               | via RAT              |
| WKUP_GTC0_GTC_CFG_3                                | 0x00AB0000                               | via RAT        | via RAT               | via RAT              |
| WKUP_VTM0_MMR_VBUSTSP_CFG1                         | 0x00B00000                               | via RAT        | via RAT               | via RAT              |
| WKUP_VTM0_MMR_VBUSTSP_CFG2                         | 0x00B01000                               | via RAT        | via RAT               | via RAT              |
| WKUP_VTM0_ECCAGGR_CFG                              | 0x00B02000                               | via RAT        | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name                           | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|----------------------------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| PDMA0                                        | 0x00C00000                               | via RAT        | via RAT               | via RAT              |
| PDMA1                                        | 0x00C01000                               | via RAT        | via RAT               | via RAT              |
| GICSS0_GIC_TRANSLATER                        | 0x01000000                               | via RAT        | via RAT               | via RAT              |
| GICSS0_GIC                                   | 0x01800000                               | via RAT        | via RAT               | via RAT              |
| TIMER0_CFG                                   | 0x02400000                               | via RAT        | via RAT               | via RAT              |
| TIMER1_CFG                                   | 0x02410000                               | via RAT        | via RAT               | via RAT              |
| TIMER2_CFG                                   | 0x02420000                               | via RAT        | via RAT               | via RAT              |
| TIMER3_CFG                                   | 0x02430000                               | via RAT        | via RAT               | via RAT              |
| TIMER4_CFG                                   | 0x02440000                               | via RAT        | via RAT               | via RAT              |
| TIMER5_CFG                                   | 0x02450000                               | via RAT        | via RAT               | via RAT              |
| TIMER6_CFG                                   | 0x02460000                               | via RAT        | via RAT               | via RAT              |
| TIMER7_CFG                                   | 0x02470000                               | via RAT        | via RAT               | via RAT              |
| UART0                                        | 0x02800000                               | via RAT        | via RAT               | via RAT              |
| UART1                                        | 0x02810000                               | via RAT        | via RAT               | via RAT              |
| UART2                                        | 0x02820000                               | via RAT        | via RAT               | via RAT              |
| UART3                                        | 0x02830000                               | via RAT        | via RAT               | via RAT              |
| UART4                                        | 0x02840000                               | via RAT        | via RAT               | via RAT              |
| UART5                                        | 0x02850000                               | via RAT        | via RAT               | via RAT              |
| UART6                                        | 0x02860000                               | via RAT        | via RAT               | via RAT              |
| MCASP0_CFG                                   | 0x02B00000                               | via RAT        | via RAT               | via RAT              |
| MCASP0_DMA                                   | 0x02B08000                               | via RAT        | via RAT               | via RAT              |
| MCASP1_CFG                                   | 0x02B10000                               | via RAT        | via RAT               | via RAT              |
| MCASP1_DMA                                   | 0x02B18000                               | via RAT        | via RAT               | via RAT              |
| MCASP2_CFG                                   | 0x02B20000                               | via RAT        | via RAT               | via RAT              |
| MCASP2_DMA                                   | 0x02B28000                               | via RAT        | via RAT               | via RAT              |
| WKUP_PSC0                                    | 0x04000000                               | via RAT        | via RAT               | via RAT              |
| MCU_PLLCTRL0                                 | 0x04020000                               | via RAT        | via RAT               | via RAT              |
| WKUP_SAFE_ECC_ARRY_ECC_AGGR                  | 0x04030000                               | via RAT        | via RAT               | via RAT              |
| WKUP_PLL0_CFG                                | 0x04040000                               | via RAT        | via RAT               | via RAT              |
| WKUP_PADCFG_CTRL0_CFG0                       | 0x04080000                               | via RAT        | via RAT               | via RAT              |
| WKUP_ESM0_CFG                                | 0x04100000                               | via RAT        | via RAT               | via RAT              |
| MCU_GPIO0                                    | 0x04201000                               | via RAT        | via RAT               | via RAT              |
| WKUP_MCU_GPIOMUX_INTRROUTER0_INTR_ROUTER_CFG | 0x04210000                               | via RAT        | via RAT               | via RAT              |
| MCU_TIMEOUT0_CFG                             | 0x04300000                               | via RAT        | via RAT               | via RAT              |
| MCU_TIMEOUT1_CFG                             | 0x04301000                               | via RAT        | via RAT               | via RAT              |
| MCU_CTRL_MMR0_CFG0                           | 0x04500000                               | via RAT        | via RAT               | via RAT              |
| WKUP_CBASS_SAFE1_ERR                         | 0x04600000                               | via RAT        | via RAT               | via RAT              |
| MCU_MCAN0_ECC_ARRY                           | 0x04701000                               | via RAT        | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name                   | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access                            |
|--------------------------------------|------------------------------------------|----------------|-----------------------|-------------------------------------------------|
| MCU_MCAN1_ECC_AGG_R                  | 0x04702000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_ECC_AGGR0_ECC_AGGR               | 0x04703000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_CBASS0_ERR                       | 0x04720000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_TIMER0_CFG                       | 0x04800000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_TIMER1_CFG                       | 0x04810000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_TIMER2_CFG                       | 0x04820000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_TIMER3_CFG                       | 0x04830000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_RTI0_CFG                         | 0x04880000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_I2C0_CFG                         | 0x04900000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_UART0                            | 0x04A00000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCSPI0_CFG                       | 0x04B00000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCSPI1_CFG                       | 0x04B10000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_DCC0                             | 0x04C00000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCRC64_0_REGS                    | 0x04D00000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCAN0_MSGMEM_RAM                 | 0x04E00000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCAN0_CFG                        | 0x04E08000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCAN0_SS                         | 0x04E09000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCAN1_MSGMEM_RAM                 | 0x04E10000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCAN1_CFG                        | 0x04E18000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_MCAN1_SS                         | 0x04E19000                               | via RAT        | via RAT               | via RAT                                         |
| MCU_M4FSS0_IRAM                      | 0x05000000                               | via RAT        | via RAT               | No RAT configuration Address 0x0                |
| MCU_M4FSS0_DRAM                      | 0x05040000                               | via RAT        | via RAT               | No RAT configuration. Address 0x4_0000          |
| MCU_M4FSS0_RAT                       | 0x05FF0000                               | via RAT        | via RAT               | No RAT configuration. Using address 0x4420_0000 |
| MCU_M4FSS0_ECC_AGGR                  | 0x05FF1000                               | via RAT        | via RAT               | No RAT configuration. Using address 0x4420_1000 |
| CPSW0_NUSS                           | 0x08000000                               | via RAT        | via RAT               | via RAT                                         |
| RTI0_CFG                             | 0x0E000000                               | via RAT        | via RAT               | via RAT                                         |
| RTI1_CFG                             | 0x0E010000                               | via RAT        | via RAT               | via RAT                                         |
| RTI2_CFG                             | 0x0E020000                               | via RAT        | via RAT               | via RAT                                         |
| RTI3_CFG                             | 0x0E030000                               | via RAT        | via RAT               | via RAT                                         |
| RTI15_CFG                            | 0x0E0F0000                               | via RAT        | via RAT               | via RAT                                         |
| DDR16SS0_REGS_SS_CFG_SSCFG           | 0x0F300000                               | via RAT        | via RAT               | via RAT                                         |
| DDR16SS0_CTLPHY_WR_AP_CTL_CFG_CTLCFG | 0x0F308000                               | via RAT        | via RAT               | via RAT                                         |
| USB0_MMR_MMRVBP_U_SB2SS_CFG          | 0x0F900000                               | via RAT        | via RAT               | via RAT                                         |
| USB0_PHY2                            | 0x0F908000                               | via RAT        | via RAT               | via RAT                                         |
| USB1_MMR_MMRVBP_U_SB2SS_CFG          | 0x0F910000                               | via RAT        | via RAT               | via RAT                                         |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name    | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access               | How MCU MCUSS access |
|-----------------------|------------------------------------------|----------------|-------------------------------------|----------------------|
| USB1_PHY2             | 0x0F918000                               | via RAT        | via RAT                             | via RAT              |
| USB0_ECC_AGGR         | 0x0F980000                               | via RAT        | via RAT                             | via RAT              |
| USB1_ECC_AGGR         | 0x0F990000                               | via RAT        | via RAT                             | via RAT              |
| MMCSD1_CTL_CFG        | 0x0FA00000                               | via RAT        | via RAT                             | via RAT              |
| MMCSD1_SS_CFG         | 0x0FA08000                               | via RAT        | via RAT                             | via RAT              |
| MMCSD0_CTL_CFG        | 0x0FA10000                               | via RAT        | via RAT                             | via RAT              |
| MMCSD0_SS_CFG         | 0x0FA18000                               | via RAT        | via RAT                             | via RAT              |
| MMCSD2_CTL_CFG        | 0x0FA20000                               | via RAT        | via RAT                             | via RAT              |
| MMCSD2_SS_CFG         | 0x0FA28000                               | via RAT        | via RAT                             | via RAT              |
| FSS0_CFG              | 0x0FC00000                               | via RAT        | via RAT                             | via RAT              |
| FSS0_FSAS_CFG         | 0x0FC10000                               | via RAT        | via RAT                             | via RAT              |
| FSS0_OTFA_CFG         | 0x0FC20000                               | via RAT        | via RAT                             | via RAT              |
| FSS0_OSP10_CTRL       | 0x0FC40000                               | via RAT        | via RAT                             | via RAT              |
| FSS0_OSP10_SS_CFG     | 0x0FC44000                               | via RAT        | via RAT                             | via RAT              |
| GPU0_RGX_CR           | 0x0FD00000                               | via RAT        | via RAT                             | via RAT              |
| I2C0_CFG              | 0x20000000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| I2C1_CFG              | 0x20010000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| I2C2_CFG              | 0x20020000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| I2C3_CFG              | 0x20030000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MCSPI0_CFG            | 0x20100000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MCSPI1_CFG            | 0x20110000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MCSPI2_CFG            | 0x20120000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| CBASS_MISC_PERI0_ER_R | 0x201F0000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MCAN0_SS              | 0x20700000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MCAN0_CFG             | 0x20701000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MCAN0_MSGMEM_RAM      | 0x20708000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| EPWM0_EPWM            | 0x23000000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| EPWM1_EPWM            | 0x23010000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| EPWM2_EPWM            | 0x23020000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| ECAP0_CTL_STS         | 0x23100000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| ECAP1_CTL_STS         | 0x23110000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| ECAP2_CTL_STS         | 0x23120000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name             | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access               | How MCU MCUSS access |
|--------------------------------|------------------------------------------|----------------|-------------------------------------|----------------------|
| EQEP0_REG                      | 0x23200000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| EQEP1_REG                      | 0x23210000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| EQEP2_REG                      | 0x23220000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MCAN0_ECC_AGGR                 | 0x24018000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| ELM0                           | 0x25010000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| MAILBOX0_REGS0                 | 0x29000000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| SPINLOCK0                      | 0x2A000000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_RTI0_CFG                  | 0x2B000000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_TIMER0_CFG                | 0x2B100000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_TIMER1_CFG                | 0x2B110000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_RTCSS0_RTC                | 0x2B1F0000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_I2C0_CFG                  | 0x2B200000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_UART0                     | 0x2B300000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_CBASS0_ERR                | 0x2B400000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_PBIST0                    | 0x2B500000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| WKUP_ECC_AGGR0_ECC_AGGR        | 0x2B600000                               | via RAT        | No RAT configuration for wkup R5FSS | via RAT              |
| ICSSM0_DRAM0_SLV_RAM           | 0x30040000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_DRAM1_SLV_RAM           | 0x30042000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_RAT_SLICE0_CFG          | 0x30048000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_RAT_SLICE1_CFG          | 0x30049000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_RAM_SLV_RAM             | 0x30050000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_PR1_ICSS_INT_C_INTC_SLV | 0x30060000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_PR1_PDSP0_IRAM          | 0x30062000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_PR1_PDSP0_IRAM_DEBUG    | 0x30062400                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_PR1_PDSP1_IRAM          | 0x30064000                               | via RAT        | via RAT                             | via RAT              |
| ICSSM0_PR1_PDSP1_IRAM_DEBUG    | 0x30064400                               | via RAT        | via RAT                             | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name                              | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|-------------------------------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| ICSSM0_PR1_PROT_SL_V                            | 0x30064C00                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_CFG_SLV                              | 0x30066000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_ICSS_UART_UART_SLV                   | 0x30068000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_IEP0                                     | 0x3006E000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_ICSS_ECA_P0_ECAP_SLV                 | 0x30070000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_MII_RT_P_R1_MII_RT_CFG               | 0x30072000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_MDIO_V1P7_MDIO                       | 0x30072400                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_MII_RT_P_R1_MII_RT_G_CFG_REG_S_G     | 0x30073000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_PDSP0_IR_AM_RAM                      | 0x30074000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_PR1_PDSP1_IR_AM_RAM                      | 0x30078000                               | via RAT        | via RAT               | via RAT              |
| CSI_RX_IF0_CP_INTD_C_FG_INTD_CFG                | 0x30100000                               | via RAT        | via RAT               | via RAT              |
| CSI_RX_IF0_VBUS2APB_WRAP_VBUSB_APB_C_SI2RX      | 0x30101000                               | via RAT        | via RAT               | via RAT              |
| CSI_RX_IF0_RX_SHIM_V_BUSP_MMR_CSI2RXIF          | 0x30102000                               | via RAT        | via RAT               | via RAT              |
| DPHY_RX0_VBUS2APB_WRAP_VBUSB_K3_DPHY_Y_RX       | 0x30110000                               | via RAT        | via RAT               | via RAT              |
| DPHY_RX0_MMR_SLV_K3_DPHY_WRAP                   | 0x30111000                               | via RAT        | via RAT               | via RAT              |
| DSS0_COMMON                                     | 0x30200000                               | via RAT        | via RAT               | via RAT              |
| DSS0_COMMON1                                    | 0x30201000                               | via RAT        | via RAT               | via RAT              |
| DSS0_VIDL1                                      | 0x30202000                               | via RAT        | via RAT               | via RAT              |
| DSS0_VID                                        | 0x30206000                               | via RAT        | via RAT               | via RAT              |
| DSS0_OVR1                                       | 0x30207000                               | via RAT        | via RAT               | via RAT              |
| DSS0_OVR2                                       | 0x30208000                               | via RAT        | via RAT               | via RAT              |
| DSS0_VP1                                        | 0x3020A000                               | via RAT        | via RAT               | via RAT              |
| DSS0_VP2                                        | 0x3020B000                               | via RAT        | via RAT               | via RAT              |
| MCRC64_0_REGS                                   | 0x30300000                               | via RAT        | via RAT               | via RAT              |
| GPU_WS_BW_LIMITER3_REGS                         | 0x30400000                               | via RAT        | via RAT               | via RAT              |
| GPU_RS_BW_LIMITER2_REGS                         | 0x30401000                               | via RAT        | via RAT               | via RAT              |
| A53_WS_BW_LIMITER1_REGS                         | 0x30402000                               | via RAT        | via RAT               | via RAT              |
| A53_RS_BW_LIMITER0_REGS                         | 0x30403000                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_CAP | 0x31000000                               | via RAT        | via RAT               | via RAT              |

Table 2-5. Memory Map Summary (continued)

| Memory Region Name                                      | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|---------------------------------------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_OPER        | 0x31000020                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_PORT        | 0x31000420                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_RUNTIME     | 0x31000440                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_INTR        | 0x31000460                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DB          | 0x31000560                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_EXTCAP      | 0x31000960                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_SUPRTCA_P2  | 0x31000970                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_SUPRTCA_P3  | 0x31000980                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_GBL         | 0x3100C100                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DEV         | 0x3100C700                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_LINK        | 0x3100D000                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DEBUG       | 0x3100D800                               | via RAT        | via RAT               | via RAT              |
| USB0_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DEBUG_RA_M0 | 0x31040000                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_CAP         | 0x31100000                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_OPER        | 0x31100020                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_PORT        | 0x31100420                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_RUNTIME     | 0x31100440                               | via RAT        | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name                                      | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|---------------------------------------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_INTR        | 0x31100460                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DB          | 0x31100560                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_EXTCAP      | 0x31100960                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_SUPRTCA_P2  | 0x31100970                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_SUPRTCA_P3  | 0x31100980                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_GBL         | 0x3110C100                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DEV         | 0x3110C700                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_LINK        | 0x3110D000                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DEBUG       | 0x3110D800                               | via RAT        | via RAT               | via RAT              |
| USB1_VBP2AHB_WRAP_CONTROLLER_VBP_US_B3_CORE_DEBUG_RA_M0 | 0x31140000                               | via RAT        | via RAT               | via RAT              |
| CBASS0_ERR                                              | 0x3A000000                               | via RAT        | via RAT               | via RAT              |
| GPMC0_CFG                                               | 0x3B000000                               | via RAT        | via RAT               | via RAT              |
| R5FSS0_EVNT_BUS_VB_USP_MMRS                             | 0x3C018000                               | via RAT        | via RAT               | via RAT              |
| PSRAMECC_16K0_ECC_AGGR                                  | 0x3F001000                               | via RAT        | via RAT               | via RAT              |
| GICSS0_REGS                                             | 0x3F004000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_ECCAGGR                                          | 0x3F005000                               | via RAT        | via RAT               | via RAT              |
| ICSSM0_ECC_AGGR                                         | 0x3F00C000                               | via RAT        | via RAT               | via RAT              |
| R5FSS0_CORE0_ECC_A_GGR                                  | 0x3F00D000                               | via RAT        | via RAT               | via RAT              |
| ECC_AGGR0_ECC_AGG_R                                     | 0x3F00F000                               | via RAT        | via RAT               | via RAT              |
| CBASS_CENTRAL2_ERR                                      | 0x3F012000                               | via RAT        | via RAT               | via RAT              |
| PBIST0                                                  | 0x3F110000                               | via RAT        | via RAT               | via RAT              |
| SA3_SS0_REGS                                            | 0x40900000                               | via RAT        | via RAT               | via RAT              |
| SA3_SS0_MMRA                                            | 0x40901000                               | via RAT        | via RAT               | via RAT              |
| SA3_SS0_EIP_76                                          | 0x40910000                               | via RAT        | via RAT               | via RAT              |
| SA3_SS0_EIP_29T2                                        | 0x40920000                               | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_SYS                                            | 0x41000000                               | via RAT        | via RAT               | via RAT              |

Table 2-5. Memory Map Summary (continued)

| Memory Region Name                | Address used by A53 and other initiators | How HSM access                    | How wkup R5FSS access | How MCU MCUSS access |
|-----------------------------------|------------------------------------------|-----------------------------------|-----------------------|----------------------|
| WKUP_ROM0                         | 0x41800000                               | via RAT                           | via RAT               | via RAT              |
| STM0_STIMULUS                     | 0x42000000                               | via RAT                           | via RAT               | via RAT              |
| WKUP_CTRL_MMR0_CF_G0              | 0x43000000                               | via RAT                           | via RAT               | via RAT              |
| SA3_SS0_SEC_PROXY_SRC_TARGET_DATA | 0x43600000                               | via RAT                           | via RAT               | via RAT              |
| SA3_SS0_ECCAGGR_CFG               | 0x43702000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PSILOCFG_CFG_PROXY        | 0x44801000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PSILOSS_CFG_MMRS          | 0x44802000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_IPCSS_SEC_P_ROXY_CFG_MMRS | 0x44804000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_IPCSS_RINGA_CC_CFG_GCFG   | 0x44805000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_INTAGGR_CFG               | 0x44808000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_INTAGGR_CFG_IMAP          | 0x44809000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_INTAGGR_CFG_MCAST         | 0x4480A000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_INTAGGR_CFG_G_CNTCFG      | 0x4480B000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_INTAGGR_CFG_INTR          | 0x44810000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_INTAGGR_CFG_G_GCNTRTI     | 0x44820000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_INTAGGR_CFG_G_UNMAP       | 0x44840000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_IPCSS_SEC_P_ROXY_CFG_SCFG | 0x44860000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_IPCSS_SEC_P_ROXY_CFG_RT   | 0x44880000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_IPCSS_RINGA_CC_CFG        | 0x448C0000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_GCFG           | 0x44910000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_RFLOW          | 0x44911000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_RCHAN          | 0x44912000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_TCHAN          | 0x44913000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_RCHANRT        | 0x44914000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_TCHANRT        | 0x44918000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_RING           | 0x4491A000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| SA3_SS0_PKTDMA_CFG_RINGRT         | 0x44940000                               | No RAT configuration for HSM core | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name            | Address used by A53 and other initiators | How HSM access                    | How wkup R5FSS access | How MCU MCUSS access |
|-------------------------------|------------------------------------------|-----------------------------------|-----------------------|----------------------|
| SA3_SS0_IPCSS_RINGA_CC_CFG_RT | 0x44C00000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS0_FW                     | 0x45000000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| WKUP_CBASS0_FW                | 0x45008000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS_CENTRAL2_FW             | 0x45010000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| PSC0_FW                       | 0x45020000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS_IPCSS0_FW               | 0x45028000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS_CENTRAL2_ISC            | 0x45804000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| DMASS0_PKTDMA_CRED            | 0x45810000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| DMASS0_BCDMA_CRED             | 0x45812000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| WKUP_CBASS0_ISC               | 0x45814000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| MCU_CBASS0_ISC                | 0x45818000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS0_ISC                    | 0x45820000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| MAIN_SEC_MMR0_CFG2            | 0x45900000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| WKUP_WKUP_SEC_MM_R0_CFG2      | 0x45920000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| MAIN_SEC_MMR0_CFG0            | 0x45A00000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| WKUP_WKUP_SEC_MM_R0_CFG0      | 0x45A20000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS_IPCSS0_GLB              | 0x45B01000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| MCU_CBASS0_GLB                | 0x45B02000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| WKUP_CBASS0_GLB               | 0x45B03000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS_CENTRAL2_GLB            | 0x45B04000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS0_GLB                    | 0x45B08000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| PSC0_GLB                      | 0x45B09000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS_CENTRAL2_QOS            | 0x45D04000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| WKUP_CBASS0_QOS               | 0x45D14000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| MCU_CBASS0_QOS                | 0x45D18000                               | No RAT configuration for HSM core | via RAT               | via RAT              |
| CBASS0_QOS                    | 0x45D20000                               | via RAT                           | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name      | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|-------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| DMASS0_INTAGGR_INT_R    | 0x48000000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_INTAGGR_IMA_P    | 0x48100000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_INTAGGR_CFG      | 0x48110000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_INTAGGR_L2G      | 0x48120000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PSILCFG_PROXY    | 0x48130000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PSILSS_MMRS      | 0x48140000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_INTAGGR_UNMAP    | 0x48180000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_INTAGGR_MCAST    | 0x48210000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_INTAGGR_GC_NTCFG | 0x48220000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_ETLSW_MMRS       | 0x48230000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_RINGACC_GCFG     | 0x48240000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_SEC_PROXY_MMRS   | 0x48250000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_BCDMA_BCHAN      | 0x48420000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PKTDMA_RFL_OW    | 0x48430000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PKTDMA_TCHAN     | 0x484A0000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_BCDMA_TCHAN      | 0x484A4000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PKTDMA_RCHAN     | 0x484C0000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_BCDMA_RCHAN      | 0x484C2000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PKTDMA_GCFG      | 0x485C0000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_BCDMA_GCFG       | 0x485C0100                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PKTDMA_RING      | 0x485E0000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_BCDMA_RING       | 0x48600000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_RINGACC_RT       | 0x49000000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_RINGACC_CFG      | 0x49800000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_INTAGGR_GCNTRTI  | 0x4A000000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_SEC_PROXY_SCFG   | 0x4A400000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_SEC_PROXY_RT     | 0x4A600000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_PKTDMA_RCHANRT   | 0x4A800000                               | via RAT        | via RAT               | via RAT              |
| DMASS0_BCDMA_RCHANRT    | 0x4A820000                               | via RAT        | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name               | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access                                                                                                  | How MCU MCUSS access |
|----------------------------------|------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------|----------------------|
| DMASS0_PKTDMA_TCH_ANRT           | 0x4AA00000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| DMASS0_BCDMA_TCHA_NRT            | 0x4AA40000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| DMASS0_PKTDMA_RING_RT            | 0x4B800000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| DMASS0_BCDMA_RING_RT             | 0x4BC00000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| DMASS0_BCDMA_BCHA_NRT            | 0x4C000000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| DMASS0_SEC_PROXY_SRC_TARGET_DATA | 0x4D000000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| GPMC0_DATA                       | 0x50000000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| FSS0_DAT_REG1                    | 0x60000000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| PSRAMECC_16K0_RAM                | 0x70000000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| R5FSS0_CORE0_ICACHE              | 0x74000000                               | via RAT        | Not accessible by wkup R5FSS                                                                                           | via RAT              |
| R5FSS0_CORE0_DCACHE              | 0x74800000                               | via RAT        | Not accessible by wkup R5FSS                                                                                           | via RAT              |
| R5FSS0_CORE0_ATCM                | 0x78000000                               | via RAT        | No RAT config is needed. By default ATCM is located at 0x0. It can be remapped to a different memory location.         | via RAT              |
| R5FSS0_CORE0_BTMC                | 0x78100000                               | via RAT        | No RAT config is needed. By default BTMC is located at 0x4101_0000. It can be remapped to a different memory location. | via RAT              |
| DDR16SS0_SDRAM                   | 0x80000000                               | via RAT        | via RAT                                                                                                                | via RAT              |
| FSS0_DAT_REG0                    | 0x400000000                              | via RAT        | via RAT                                                                                                                | via RAT              |
| FSS0_DAT_REG3                    | 0x500000000                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_ROM_TABLE_0_0      | 0x700000000                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_RES_V0_0           | 0x700001000                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_CFG_AP0            | 0x700002000                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_APB_AP0            | 0x700002100                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_AXIA_AP0           | 0x700002200                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_PWR_AP0            | 0x700002300                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_PVIE_W0            | 0x700002400                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_JTA_GAP0           | 0x700002500                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_SEC_AP0            | 0x700002600                              | via RAT        | via RAT                                                                                                                | via RAT              |
| DEBUGSS_WRAP0_CORTEX0_CFG0       | 0x700002700                              | via RAT        | via RAT                                                                                                                | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name          | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|-----------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| DEBUGSS_WRAP0_COR_TEX1_CFG0 | 0x700002800                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX2_CFG0 | 0x700002900                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX3_CFG0 | 0x700002A00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX4_CFG0 | 0x700002B00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX5_CFG0 | 0x700002C00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX6_CFG0 | 0x700002D00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX7_CFG0 | 0x700002E00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX8_CFG0 | 0x700002F00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V1_0      | 0x700003000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V2_0      | 0x700004000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_ROM_TABLE_1_0 | 0x720000000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_CSC_T10       | 0x720001000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_DRM_0         | 0x720002000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V3_0      | 0x720003000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_CST_PIU0      | 0x720004000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_CTF_0         | 0x720005000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V4_0      | 0x720006000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_SS_ROM     | 0x730000000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_EXT_APB0      | 0x730000000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE0_DBG  | 0x730010000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE0_CTI  | 0x730020000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE0_PMU  | 0x730030000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE0_ETM  | 0x730040000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE1_DBG  | 0x730110000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE1_PMU  | 0x730120000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE1_ETM  | 0x730130000                              | via RAT        | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name                              | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|-------------------------------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| COMPUTE_CLUSTER0_CORE1_CTI                      | 0x730140000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE2_DBG                      | 0x730210000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE2_PMU                      | 0x730220000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE2_ETM                      | 0x730230000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE2_CTI                      | 0x730240000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE3_DBG                      | 0x730310000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE3_PMU                      | 0x730320000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE3_ETM                      | 0x730330000                              | via RAT        | via RAT               | via RAT              |
| COMPUTE_CLUSTER0_CORE3_CTI                      | 0x730340000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ROM                                    | 0x73C020000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_CTSET2_WRAP_CFG_CTSET2_CFG             | 0x73C022000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ATB_REPLICATOR_CFG_CXATBREPLICATOR_CFG | 0x73C024000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_TBR_VBUS_P_WRAP_TBR_CFG_TBR_CFG        | 0x73C025000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_0_CFG_CSCTI_CFG                | 0x73C026000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_1_CFG_CSCTI_CFG                | 0x73C028000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_2_CFG_CSCTI_CFG                | 0x73C029000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_3_CFG_CSCTI_CFG                | 0x73C02A000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_4_CFG_CSCTI_CFG                | 0x73C02B000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_5_CFG_CSCTI_CFG                | 0x73C02C000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_6_CFG_CSCTI_CFG                | 0x73C02D000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_7_CFG_CSCTI_CFG                | 0x73C02E000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS0_ARM_CTI_8_CFG_CSCTI_CFG                | 0x73C02F000                              | via RAT        | via RAT               | via RAT              |
| STM0_CXSTM                                      | 0x73D200000                              | via RAT        | via RAT               | via RAT              |
| STM0_CTI_CSCTI                                  | 0x73D201000                              | via RAT        | via RAT               | via RAT              |
| DBGSSUSPENDROUTER0_INTR_ROUTER_CFG              | 0x73D300000                              | via RAT        | via RAT               | via RAT              |
| 0                                               | 0x73D400000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MMR                                  | 0x73E100000                              | via RAT        | via RAT               | via RAT              |

Table 2-5. Memory Map Summary (continued)

| Memory Region Name     | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| CPT2_AGGR0_STP2ATB_CFG | 0x73E100100                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM0        | 0x73E120000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM1        | 0x73E121000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM2        | 0x73E122000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM3        | 0x73E123000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM4        | 0x73E124000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM5        | 0x73E125000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM6        | 0x73E126000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM7        | 0x73E127000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM8        | 0x73E128000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM9        | 0x73E129000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM10       | 0x73E12A000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM11       | 0x73E12B000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM12       | 0x73E12C000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM13       | 0x73E12D000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM14       | 0x73E12E000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM15       | 0x73E12F000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM16       | 0x73E130000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM17       | 0x73E131000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM18       | 0x73E132000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM19       | 0x73E133000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM20       | 0x73E134000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM21       | 0x73E135000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM22       | 0x73E136000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM23       | 0x73E137000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM24       | 0x73E138000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM25       | 0x73E139000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM26       | 0x73E13A000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM27       | 0x73E13B000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM28       | 0x73E13C000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM29       | 0x73E13D000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM30       | 0x73E13E000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR0_MEM31       | 0x73E13F000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MMR         | 0x73E140000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_STP2ATB_CFG | 0x73E140100                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM0        | 0x73E160000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM1        | 0x73E161000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM2        | 0x73E162000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM3        | 0x73E163000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM4        | 0x73E164000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM5        | 0x73E165000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM6        | 0x73E166000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM7        | 0x73E167000                              | via RAT        | via RAT               | via RAT              |

**Table 2-5. Memory Map Summary (continued)**

| Memory Region Name          | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|-----------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| CPT2_AGGR1_MEM8             | 0x73E168000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM9             | 0x73E169000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM10            | 0x73E16A000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM11            | 0x73E16B000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM12            | 0x73E16C000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM13            | 0x73E16D000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM14            | 0x73E16E000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM15            | 0x73E16F000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM16            | 0x73E170000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM17            | 0x73E171000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM18            | 0x73E172000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM19            | 0x73E173000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM20            | 0x73E174000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM21            | 0x73E175000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM22            | 0x73E176000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM23            | 0x73E177000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM24            | 0x73E178000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM25            | 0x73E179000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM26            | 0x73E17A000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM27            | 0x73E17B000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM28            | 0x73E17C000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM29            | 0x73E17D000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM30            | 0x73E17E000                              | via RAT        | via RAT               | via RAT              |
| CPT2_AGGR1_MEM31            | 0x73E17F000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_ROM_TABLE_0_1 | 0x740000000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V0_1      | 0x740001000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_CFG_AP1       | 0x740002000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_APB_AP1       | 0x740002100                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_AXIA_P1       | 0x740002200                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_PWR_AP1       | 0x740002300                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_PVIE_W1       | 0x740002400                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_JTA_GAP1      | 0x740002500                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_SEC_AP1       | 0x740002600                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX0_CFG1 | 0x740002700                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX1_CFG1 | 0x740002800                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX2_CFG1 | 0x740002900                              | via RAT        | via RAT               | via RAT              |

Table 2-5. Memory Map Summary (continued)

| Memory Region Name          | Address used by A53 and other initiators | How HSM access | How wkup R5FSS access | How MCU MCUSS access |
|-----------------------------|------------------------------------------|----------------|-----------------------|----------------------|
| DEBUGSS_WRAP0_COR_TEX3_CFG1 | 0x740002A00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX4_CFG1 | 0x740002B00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX5_CFG1 | 0x740002C00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX6_CFG1 | 0x740002D00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX7_CFG1 | 0x740002E00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_COR_TEX8_CFG1 | 0x740002F00                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V1_1      | 0x740003000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V2_1      | 0x740004000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_ROM_TABLE_1_1 | 0x760000000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_CSC_TI1       | 0x760001000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_DRM_1         | 0x760002000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V3_1      | 0x760003000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_CST_PIU1      | 0x760004000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_CTF_1         | 0x760005000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_RES_V4_1      | 0x760006000                              | via RAT        | via RAT               | via RAT              |
| DEBUGSS_WRAP0_EXT_APB1      | 0x770000000                              | via RAT        | via RAT               | via RAT              |
| DDR16SS0_SDRAM              | 0x880000000                              | via RAT        | via RAT               | via RAT              |
| DDR16SS0_SDRAM              | 0x900000000                              | via RAT        | via RAT               | via RAT              |

## 2.5 MMU Optimization Note

The SoC memory map is constructed to enable using a larger MMU page to be 64KB and above. The system resource which can be owned by each individual software process is put at 64KB aligned memory boundary to provide the isolation among processes through MMU. Most of the simple end point peripherals are put at 64KB boundary for this purpose. The following are a few exceptions.

The debugSS\_wrap contains multiple small mregions than 64KB. The main use case is to have a single SW process will own debug configuration.

GPIO modules are another exception. Each LVCMS pin for SoC can be configured as a GPIO pin. Currently each GPIO module can provide up to 144 GPIO pins. The main domain and wkupmcu domain have separate LVCMS IO control. In the main domain, it requires two GPIO modules to cover all the LVCMS pins. These two GPIO modules are treated as a single entity from software point of view and these two GPIO modules are put at 4KB boundary instead of 64KB.

On the mcu domain, only one GPIO module needed to cover all the LVCMS pins.

SoC also contains multiple DCC modules, and they are put at back to back on the memory map instead of spacing out at 64KB boundary. The reason is that DCC modules should be owned by a single safety processor.

Firewall and Initiator Secure Control(ISC) configurations are not on 64KB boundary. The configuration for those three items is at 1KB boundary, since the security initiator owns the configuration for them. QoS block is also put at 1KB boundary instead of 64KB, since the device manager owns the configuration of the QoS block.

Chapter 3  
**System Interconnect**

---



This chapter describes the device system interconnect.

|                                              |           |
|----------------------------------------------|-----------|
| <b>3.1 System Interconnect Overview.....</b> | <b>71</b> |
|----------------------------------------------|-----------|

### 3.1 System Interconnect Overview

The SoC level interconnect consists of multiple types of components:

- CBASS: this is a crossbar module to provide physical connection among the initiators and targets
- VBUSP interface: a single-issue interface
- VBUSM interface: a multi-issue interface
- Channel ID: channel ID for interface indicates a logical flow. All the transactions with the same channel ID coming from the same initiator interface are considered orthogonal and independent flow.
- RoutID: a unique identification of a particular initiator interface
- OrderID: a 4 bits value associated with each transaction. All the transactions from the same initiator to the same target end point with the same orderID needs to be executed in order. OrderID is also to be used to select real-time and non-real time path for the transaction. OrderID 8-15 reserved for real-time path.
- Asel: Address Selection. Asel can be either used for select a unique memory map or be used to indicate the IO coherent transactions.
- PrivID: indicates the security access group. PrivID is assigned by the ISC block.
- ISC: stands for Initiator Security Control. It is a part of the CBASS configuration parameter. Each initiator port can optionally enable ISC feature in the CBASS configuration. It provides privID and secure side band signal overwrite value for the transactions sent by the initiator. ISC can provide the overwrite value either based on the memory address or channel ID value the transaction carries. The configuration of the ISC is done through the VBUSP configuration port from the CBASS IP.
- Region based firewall: this is firewall block based on address region.
- Channelized firewall: firewall block with finer granularity down to register level with fixed region size.
- QoS: Quality of Service block is a feature which can be enabled for each CBA initiator port connecting to the CBASS. Each initiator can choose to enable the QoS feature in the CBA configuration file. The QoS block provides some QoS related sideband signals if the initiator does not provide, such as orderID, priority, epriority and etc. If the initiator port supports channel ID, the QoS block provides priority and order ID for each channel, otherwise all the transactions from that initiator port share the same priority and order ID value.

**CAUTION**

Since OrderID is used for ordering purpose in CBASS, changing the order ID when the system is running can cause system deadlock. Therefore, QoS configuration shall be part of the initialization steps, if the application wants to change the QoS setting from the default value.

- Initiator timeout gasket: Initiator timeout gasket is to prevent the fault propagation from the upstream interconnect, which can't provide transaction completion notification.
- Target timeout gasket: target timeout gasket is used to prevent the fault propagation from the downstream interconnect, which enters into a fault state and no longer is able to accept any new transactions.

#### 3.1.1 Domain Partition

SoC is partition into several domains, which are connected by CBASS modules:

- MAIN domain: there are multiple CBASS components providing the connectivity among initiators and target interfaces for the processors and peripherals in the main domain. The main application processor such as A53SS is located.
- WKUP domain: this is where the device manager R5FSS is located. This is the domain active during deepsleep mode.
- MCU domain: this is where the MCU M4FSS is located. MCU domain can be isolated from the rest of SoC during safety use case

All the modules connected to CBASS\_wkup\_infra can belong to both MCU domain and the wkup domain depending on the use case. For the deep sleep low power mode, it is in WKUP domain. However, when the mcu domain is running safety use case, all the modules connect to CBASS\_wkup\_safe are in the MCU domain.



Figure 3-1. System Interconnect Overview

### 3.1.2 IO Coherency Support

There are 4 bits for Asel sideband signals, which enables a single SoC to support up to 16 different memory maps. Asel=0 is default to the regular SoC memory map, which CBASS is used for address decoding purpose. Non-zero Asel value is assigned to the target end point, which can be bypass the normal address decoding. All the transactions with asel 0 go through address decoding based on the address the transactions carry. However, the non-zero Asel value can be assigned to the transactions through either DMA configuration for both BCDMA and pktDMA transaction or through the QoS block inserted for each initiator interface. Asel value 14 and 15 are dedicated to route any transactions requiring IO coherency to A53SS's ACP interface. The transactions with Asel value 1-13 will be routed to the null end point for graceful termination.

Transactions with asel=14 and 15 are routed to ACP port

- Write transaction with Asel=14 causes A53SS L2 cache allocation: for cache warming feature
- Write transactions with Asel=15 does not cause A53SS L2 cache allocation
- Read transactions with Asel=14 and 15 does not cause L2 cache allocation
- All the transactions to ACP port can be protected by firewall if firewall is inserted by the SoC level CBASS

A53SS cluster checks security on the transactions from the ACP port. However, it does not have the supervisor and user mode check. If different permission is needed for supervisor and user mode transactions, the region-based firewall logic should be used to grant different access permission.

The transaction from the following processor do not have IO coherency support:

- HSM
- R5FSS in WKUP domain
- PRUSS-M
- MCU M4FSS

### **3.1.3 Timeout Gasket**

In the system with mixture level of safety requirements, it is important to isolation the impact from the fault from the lower safety level spreading to the domain with higher safety level. When there are non-recoverable faults in the domain with lower safety level, the safety processor should either have the capability to diagnostic the fault and/or reset the fault components.

When the fault happens on the target interface side, the target time out gasket provides the capability to gracefully terminate the transactions and return error status back to the initiator, so the interconnect is not stalled due to the fault at the target side.

When the fault happens on the initiator interface side, the initiator time out gasket shall provide the capability to flush out all the pending transactions while prevent the fault initiator interface issues more transactions. It also has logic to track the idle state when all the pending transactions are completed. The IP can't be brought down or reset unless the initiator time out gaskets enters idle state. All the control mechanism for the initiator side time out gasket comes from chip level MMR. By default, the time out gasket is disabled. It requires safety processor to enable it.

All the time out gaskets assert interrupt when there are any time out happen, and those interrupts are routed to ESM and further routed to safety processor MCU M4FSS.

MCU M4FSS is designed to be a safety processor and it is responsible to manage all the time out events from the timeout gasket logic.

When MCU M4FSS is running safety application, the components connected to CBASS\_MCU and CBASS\_wkup\_safe are part of the safety domain, which can be isolated from the rest of SoC. The timeout gaskets are inserted around CBASS\_MCU and CBASS\_wkup\_safe to prevent the fault outside these two CBASS propagated into the safety domain.



**Figure 3-2. Timeout Module to Prevent Fault Propagation**

- Target side time out gasket: it is inserted to protect the path from MCU M4FSS to access the end points outside safety domain. The configuration of the target side timeout module is done through a dedicated configuration interface.
- Initiator side time out gasket: it is inserted to protect the path from the initiator interfaces outside of the safety domain to access the safety domain (the modules connected to cbass\_mcu and cbass\_wkup\_safe). If any fault outside the safety domain causes either data or status could no longer return back, the initiator timeout gasket can flush this data/status return to allow safety domain progress. This initiator gasket is reset when the domain it connects to goes through reset. The configuration of the initiator side timeout gasket is through the registers in mcu\_ctrl\_mmr.

By default, the timeout gasket is not enabled. Before MCU M4FSS runs safety application, MCU M4FSS needs to enable the timeout gasket functionality.

### 3.1.3.1 Software Sequence to Enable Timeout Gasket

MCU M4FSS shall be the only processor to enable the timeout gasket function.

The following software sequence shall be followed to enable the target timeout gasket inserted between cbass\_mcu and cbass\_central.

1. Check whether LPSC\_mcu2main\_ISO in mcu\_psc is disable state or not. If this LPSC is not in the disable state, MCU M4FSS configures LPSC\_mcu2main to be OFF.
2. After LPSC\_mcu2main is in disable state,
  - a. If main domain is under reset, MCU M4FSS waits until the main domain out of reset
  - b. MCU M4FSS triggers a software flush to the target timeout gasket
3. MCU M4FSS configures mcu\_PSC to enable LPSC\_mcu2main\_ISO. This allows the transactions from mcu domain can reach main domain.
4. MCU M4FSS enables target timeout gasket

The above SW sequence needs to be repeated to enable the target side timeout gasket inserted from cbass\_mcu to cbass\_wkup\_dm path controlled by LPSC\_mcu2DM\_ISO

The following software sequence shall be followed by enabling the initiator side timeout gasket:

1. MCU M4FSS check whether LPSC\_main2mcu\_ISO is in disable state. If it is not in disable state, configure mcu\_psc to put LPSC\_main2mcu in disable state
2. Wait until LPSC\_main2mcu\_ISO in disable state ( which means no pending transactions from main domain to mcu domain)
3. MCU M4FSS triggers a flush operation in initiator timeout gasket through mcu\_ctrl\_mmr
4. MCU M4FSS configure/enable initiator timeout gasket by defining proper timeout period through mcu\_ctrl\_mmr.
5. MCU M4FSS enables LPSC\_main2mcu\_ISO

The initiator side timeout gasket inserted between Cbass\_wkup\_dm and cbass\_wkup\_safe shall follow the similar steps.

### 3.1.4 Route ID Allocation

Each transaction in the system carries a 12 bits route ID value. The route ID is used by the CBASS to route return status/data back to transaction initiator. The transaction with the same route ID indicates the originator of the transaction in the system. And each originator of the transaction in the SoC has a unique route ID value. Route ID value is also used by ddr16ss to remap the arbitration priority inside ddr16ss.

**Table 3-1. Route ID Table**

| Module Name | Initiator Interface               | Which CBASS it is connected to | RouteID value | Able to access ACP port for IO coherency |
|-------------|-----------------------------------|--------------------------------|---------------|------------------------------------------|
| A53SS       | A53 core 0 non-cacheable read     | cbass0                         | 16            | N                                        |
|             | A53 core 1 non-cacheable read     | cbass0                         | 17            | N                                        |
|             | A53 core 2 non-cacheable read     | cbass0                         | 18            | N                                        |
|             | A53 core 3 non-cacheable read     | cbass0                         | 19            | N                                        |
|             | Cacheable read from all A53 cores | cbass0                         | 20            | N                                        |
|             | A53 core 0 non-cacheable write    | cbass0                         | 0             | N                                        |
|             | A53 core 1 non-cacheable write    | cbass0                         | 1             | N                                        |
|             | A53 core 2 non-cacheable write    | cbass0                         | 2             | N                                        |
|             | A53 core 3 non-cacheable write    | cbass0                         | 3             | N                                        |
|             | Cacheable read from all A53 write | cbass0                         | 4             | N                                        |
| MMCSDO      | write interface                   | cbass0                         | 269           | Y                                        |
|             | read interface                    | cbass0                         | 270           | Y                                        |

Table 3-1. Route ID Table (continued)

| Module Name    | Initiator Interface                                  | Which CBASS it is connected to | RouteID value | Able to access ACP port for IO coherency |
|----------------|------------------------------------------------------|--------------------------------|---------------|------------------------------------------|
| MMCSD1         | write interface                                      | cbass0                         | 271           | Y                                        |
|                | read interface                                       | cbass0                         | 272           | Y                                        |
| MMCSD2         | write interface                                      | cbass0                         | 256           | Y                                        |
|                | read interface                                       | cbass0                         | 257           | Y                                        |
| ICSSM_0        | pru0                                                 | cbass_central                  | 456           | N                                        |
|                | pru1                                                 | cbass_central                  | 457           | N                                        |
| GIC            | write interface                                      | cbass0                         | 302           | Y                                        |
|                | read interface                                       | cbass0                         | 303           | Y                                        |
| USB_0          | read interface                                       | cbass0                         | 304           | Y                                        |
| USB_0          | write interface                                      | cbass0                         | 305           | Y                                        |
| USB_1          | read interface                                       | cbass0                         | 306           | Y                                        |
| USB_1          | write interface                                      | cbass0                         | 307           | Y                                        |
| LED            |                                                      | cbass0                         | 334           | N                                        |
| debugss        | read interface                                       | cbass0                         | 258           | Y                                        |
| debugss        | write interface                                      | cbass0                         | 259           | Y                                        |
| R5FSS          | read interface                                       | cbass_wkup_dm                  | 4088          | Y                                        |
|                | write interface                                      | cbass_wkup_dm                  | 4089          | Y                                        |
|                | Dedicated Peripheral Interface( both read and write) | cbass_wkup_dm                  | 4090          | N                                        |
| dmss0          | read interface from BCDMA                            | cbass0                         | 128           | Y                                        |
|                | write interface from BCDMA                           | cbass0                         | 129           | Y                                        |
|                | pktDMA interface                                     | cbass0                         | 130           | Y                                        |
| PDMA0          | write interface                                      | cbass_misc_peri                | 3010          | N                                        |
|                | read interface                                       | cbass_misc_peri                | 3011          | N                                        |
| PDMA1          | write interface                                      | cbass_misc_peri                | 3012          | N                                        |
|                | read interface                                       | cbass_misc_peri                | 3013          | N                                        |
| PDMA2          | write interface                                      | cbass_mcasp                    | 3001          | N                                        |
|                | read interface                                       | cbass_mcasp                    | 3002          | N                                        |
| MCU M4FSS      | Both read and write                                  | cbass_mcu                      | 4092          | N                                        |
| TIFS           | Both read and write                                  | cbass_central                  | 448-451       | N                                        |
| HSM            | Both read and write                                  | cbass_central                  | 452-455       | N                                        |
| DSS            | Both read and write                                  | cbass0                         | 160           | Y                                        |
| GPU            | write interface                                      | cbass0                         | 64            | Y                                        |
|                | read interface                                       | cbass0                         | 65            | Y                                        |
| sa3_SS_sa_ul_0 | Both read and write                                  | cbass0                         | 277           | Y                                        |
| sa3ss_pktdma_0 | Both read and write                                  | cbass_ipcss                    | 481           | Y                                        |

### 3.1.5 Quality of Service (QoS)

Majority of the initiator has a dedicated QoS block to provide the configurability of the transaction characteristic, such as orderID, priority/epriority, asel and etc.

OrderID is a 4 bits value, which is associated with each transaction. By default, all the transactions have orderID value set to 0x0. The orderID is used as a mechanism to load balance the traffic to DDR through two

parallel paths. The transactions with order ID 0-7 share one path, while transactions with 8-15 share a separate path. The OrderID value can be changed through QoS block for the initiators or through BCDMA and pktDMA configuration.

Each transaction in the system carries 3 bits priority information. The priority information is used for cbass for arbitration decision, which implements typical priority based round robin. Priority value 0x0 is the highest priority, while 0x7 is the lowest priority. By default, QoS has priority value set to 0x7 (lowest priority).

Some of the modules such as DSS is able to adjust the priority of the transaction based on the system congestion condition. But majority of the transactions have static priority level set by the QoS block. But the priority setting through QoS block can be tuned to fit certain use case scenarios.

**CAUTION**

Priority, orderID and asel value from the QoS block shall only be modified as part of the initialization steps, when the SoC is idle. Changing the QoS block configuration during the run time is prohibited, and may cause system error or other undefined behavior.

Each QoS block has a unique identification, which is correspondent to the configuration address for that QoS block. If the QoS block's index is x, then the configuration address for that QoS block is 0x45D0\_0000+ 1KB\*x.

Table 3-2. QoS Summary Table

| Module Name | Initiator Interface               | QoS Index | Config address for QoS block | # of Channels the initiator support | Atype can be overwritten? | Can Virtid be overwritten? | Can Asel be overwritten? | Can Orderid be overwritten? | Can Epriority be overwritten |
|-------------|-----------------------------------|-----------|------------------------------|-------------------------------------|---------------------------|----------------------------|--------------------------|-----------------------------|------------------------------|
| A53SS       | A53 core 0 non-cacheable read     | 129       | 0X45D20400                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
|             | A53 core 1 non-cacheable read     |           |                              |                                     |                           |                            |                          |                             |                              |
|             | A53 core 2 non-cacheable read     |           |                              |                                     |                           |                            |                          |                             |                              |
|             | A53 core 3 non-cacheable read     |           |                              |                                     |                           |                            |                          |                             |                              |
|             | Cacheable read from all A53 cores |           |                              |                                     |                           |                            |                          |                             |                              |
|             | A53 core 0 non-cacheable write    | 130       | 0X45D20800                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
|             | A53 core 1 non-cacheable write    |           |                              |                                     |                           |                            |                          |                             |                              |
|             | A53 core 2 non-cacheable write    |           |                              |                                     |                           |                            |                          |                             |                              |
|             | A53 core 3 non-cacheable write    |           |                              |                                     |                           |                            |                          |                             |                              |
|             | Cacheable read from all A53 write |           |                              |                                     |                           |                            |                          |                             |                              |
| MMCSD0      | write interface                   | 138       | 0X45D22800                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
|             | read interface                    | 139       | 0X45D22C00                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
| MMCSD1      | write interface                   | 140       | 0X45D23000                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
|             | read interface                    | 141       | 0X45D23400                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
| MMCSD2      | write interface                   | 142       | 0X45D23800                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
|             | read interface                    | 143       | 0X45D23C00                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
| ICSSM_0     | pru0                              | 16        | 0X45D04000                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |
|             | pru1                              | 17        | 0X45D04400                   | 1                                   | No                        | No                         | Yes                      | Yes                         | Yes                          |

**Table 3-2. QoS Summary Table (continued)**

| Module Name | Initiator Interface                                  | QoS Index                                                                                   | Config address for QoS block | # of Channels the initiator support | Atype can be overwritten ? | Can Virtid be overwritten ? | Can Asel be overwritten ? | Can Orderid be overwritten ? | Can Epriority be overwritten |
|-------------|------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------|-------------------------------------|----------------------------|-----------------------------|---------------------------|------------------------------|------------------------------|
| GIC         | write interface                                      | 136                                                                                         | 0X45D22000                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
|             | read interface                                       | 137                                                                                         | 0X45D22400                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
| USB_0       | read interface                                       | 145                                                                                         | 0X45D24400                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
|             | write interface                                      | 144                                                                                         | 0X45D24000                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
| USB_1       | read interface                                       | 146                                                                                         | 0X45D24800                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
|             | write interface                                      | 147                                                                                         | 0X45D24C00                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
| debugss     | read interface                                       | 135                                                                                         | 0X45D21C00                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
|             | write interface                                      | 134                                                                                         | 0X45D21800                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
| R5FSS       | read interface                                       | 80                                                                                          | 0X45D14000                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
|             | write interface                                      | 81                                                                                          | 0X45D14400                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
|             | Dedicated Peripheral Interface (both read and write) | 82                                                                                          | 0X45D14800                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
| dmss0       | read interface from BCDMA                            | Do not have QoS. The configuration is done through DMA configuration for the transfer       |                              |                                     |                            |                             |                           |                              |                              |
|             | write interface from BCDMA                           | Do not have QoS. The configuration is done through DMA configuration for the transfer       |                              |                                     |                            |                             |                           |                              |                              |
|             | pktDMA interface                                     | Do not have QoS. The configuration is done through DMA configuration for the transfer       |                              |                                     |                            |                             |                           |                              |                              |
| PDMA0       | write interface                                      | Do not have QoS block. The configuration is done through DMA configuration for the transfer |                              |                                     |                            |                             |                           |                              |                              |
|             | read interface                                       |                                                                                             |                              |                                     |                            |                             |                           |                              |                              |
| PDMA1       | write interface                                      |                                                                                             |                              |                                     |                            |                             |                           |                              |                              |
|             | read interface                                       |                                                                                             |                              |                                     |                            |                             |                           |                              |                              |
| PDMA2       | write interface                                      |                                                                                             |                              |                                     |                            |                             |                           |                              |                              |
|             | read interface                                       |                                                                                             |                              |                                     |                            |                             |                           |                              |                              |
| MCU M4FSS   | Both read and write                                  | 96                                                                                          | 0X45D18000                   | 1                                   | No                         | No                          | Yes                       | No                           | Yes                          |
| HSM         | Both read and write                                  | Do not have QoS block. The priority is 0x7 and all the other above sideband signal is 0x0   |                              |                                     |                            |                             |                           |                              |                              |

Table 3-2. QoS Summary Table (continued)

| Module Name     | Initiator Interface | QoS Index                                                                             | Config address for QoS block | # of Channels the initiator support | Atype can be overwritten ? | Can Virtid be overwritten ? | Can Asel be overwritten ? | Can Orderid be overwritten ? | Can Epriority be overwritten |
|-----------------|---------------------|---------------------------------------------------------------------------------------|------------------------------|-------------------------------------|----------------------------|-----------------------------|---------------------------|------------------------------|------------------------------|
| DSS             | Both read and write | 148                                                                                   | 0X45D25000                   | 4                                   | No                         | No                          | Yes                       | Yes                          | No                           |
| GPU             | write interface     | 132                                                                                   | 0X45D21000                   | 6                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
|                 | read interface      | 133                                                                                   | 0X45D21400                   | 6                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
| sa3_SS_sa_ul_0  | Both read and write | 149                                                                                   | 0X45D25400                   | 1                                   | No                         | No                          | Yes                       | Yes                          | Yes                          |
| sa3ss_pktd_ma_0 | Both read and write | Do not have QoS. The configuration is done through DMA configuration for the transfer |                              |                                     |                            |                             |                           |                              |                              |

### 3.1.6 Initiator-Side Security Controls and Firewalls

Firewalls (FW) and Initiator-side Security Controls (ISC) are important interconnect components that enable hardware isolation for freedom from interference or security uses. ISC enable every transaction to be identified and tagged to precisely assign the source ID. Firewalls are downstream (target) components that provide the ability to filter transactions based on the sideband information.

The device protection depends on firewalls. They are used to protect data and configuration spaces by managing the accesses to these memory regions. There are two types of firewalls - region based and channelized. There are no channelized firewalls on system level. Only LPSC\_SMS, LPSC\_HSM\_ISO, LPSC\_SA3\_UL, LPSC\_TIFS, and LPSC\_HSM have channelized firewalls for MDCTL MMRs. Only region based firewalls are available on system level. See [Section 3.1.6.2.1.1](#) and [Section 3.1.6.2.2.1](#) for description of the region based and channelized firewalls.

On devices supporting secure boot, these components allow the SoC to support multi-tier security and provide segregation of secure and non-secure worlds. All configuration of ISC and FWs are under exclusive control of Device Manager, using a dedicated interconnect.

The number of ISC and Firewall blocks and placement of these blocks are based on the topology of each device. ISC and Firewall blocks are placed in host modules (AXI to VBUSM.C Bridge); or part of the interconnect (for example: CBASS).

Figure 3-3 presents a generic view of ISC and Firewalls in SoC.



**Figure 3-3. ISC and Firewall in SoC**

### 3.1.6.1 Initiator-Side Security Controls (ISC)

Initiator-Side Security Control (ISC) modules are hosted at the initiator side where the transactions are sourced. ISC controls the security sideband attributes that are applied to outgoing transactions and have ability to override security values under exclusive control of the SMS.

ISC Capabilities:

- Attach Priv-ID to each bus transaction.
- Priv-ID is a source ID attached to identify the source of a transaction in the system.
- By default, each initiator in the system has a unique Priv-ID.
- Multiple modules can be assigned the same Priv-ID to form logical groups.
- Assert, De-assert or pass-through secure bit.
- Assert, De-assert or pass through Priv-bits.

ISCs are connected to the dedicated security VBUSP interconnect and can be exclusively configured by SMS. ISC optionally can support region and channel number based security control, where, based on incoming channel or address, the associated security controls, are applied.

Figure 3-4 presents ISC config registers per region.

ISC Control Regs **per** region



SA-SPRUIM0-014

**Figure 3-4. ISC Config Registers per Region**

#### 3.1.6.1.1 **Priv-ID**

Priv-ID is used to identify the logical source of transaction and is attached by ISC. The Priv-IDs are allocated based on subsystem as part of platform definition.

**Table 3-3. Priv-ID**

| Initiator        | Reset Priv-ID |
|------------------|---------------|
| COMPUTE_CLUSTER0 | 4             |
| MCU_M4FSS0       | 100           |
| MMCSD0           | 128           |
| MMCSD1           | 129           |
| MMCSD2           | 130           |
| ICSSM0           | 138           |
| SA3_SS0          | 152           |
| GICSS0           | 154           |
| USB0             | 155           |
| USB1             | 156           |
| DSS0             | 173           |
| DEBUGSS_WRAP0    | 177           |
| GPU0             | 187           |
| WKUP_R5FSS0      | 212           |

#### 3.1.6.1.2 **Special System Level Priv-ID**

This section describes Special Priv-IDs. These Priv-ID when encountered by various blocks like firewall have special meaning.

Table 3-4 presents Special Priv-IDs.

**Table 3-4. Special Priv-IDs**

| Special Priv-IDs        | Hex Value                    | Decimal Value           |
|-------------------------|------------------------------|-------------------------|
| System Reserved Priv-ID | 0xC1, 0xC2, 0xC4, 0xC6, 0xC7 | 193, 194, 196, 198, 199 |

**Table 3-4. Special Priv-IDs (continued)**

| Special Priv-IDs     | Hex Value | Decimal Value |
|----------------------|-----------|---------------|
| Wild card Priv ID    | 0xC3      | 195           |
| Block Priv ID        | 0xC5      | 197           |
| DMA Reserved Priv-ID | 0xC0      | 192           |

### 3.1.6.2 Firewalls (FW)

Firewalls play an important role in implementing overall SoC security by providing a means to allow or restrict access to device resources to any given controller entity or Secure/Non-Secure/Priv/User world. Firewalls are placed at various data path points throughout the SoC to control access to protected asset (Peripheral, memory and so forth).

Firewalls ensure that assets can be protected and are only accessible by allowed controller and in selected operation mode (Secure, Non-Secure, Priv, User, write, read and so forth). In case of firewall violations, the transaction is dropped and the appropriate violation code is registered with associated parameters.

There are three types of firewalls, Peripheral firewalls, Memory firewalls (referred as one group **Region Based Firewall** in the device-specific TRM) and Channelized firewalls.

Each Firewall module in the SoC has a unique Firewall ID that allows software to decode the source of each violation. The Firewall IDs are allocated based on subsystem as part of platform definition. The full SoC view of Firewall IDs for various Firewall modules are captured in [Section 3.1.6.2.1.2](#).

#### 3.1.6.2.1 Region-based Firewalls

Region-based firewalls are designed to protect peripherals, Memory (SRAM/DDR and so forth) and data regions (GPMC and so forth). Region-based firewalls have a defined firewall region count so that the peripheral/memory can be partitioned into multiple firewall regions.

Region-based firewalls can have either 1 or 3 Priv-ID slots per region, with associated permissions. The number of Priv-ID slots is determined based on placement of firewall block. Each region in this type of firewall is defined by a physical start and end address.

[Figure 3-5](#) presents Region-based firewall config registers with 3 Priv-ID slots per region.

**Firewall Control Regs per region**


E = Enable Region (4-bits), 0xA = Enabled  
 L = Lock Config  
 B = Background Region  
 C = Cache Mode



W = Write  
 R = Read  
 C = Cacheable  
 D = Debug



W = Write  
 R = Read  
 C = Cacheable  
 D = Debug



W = Write  
 R = Read  
 C = Cacheable  
 D = Debug

**Figure 3-5. Region-based Firewall Config Registers with 3 Priv-ID slot per Region**

SA-SPRUIM0-018

Figure 3-6 presents Region-based firewall config registers with 1 Priv-ID slot per region.

Firewall Control Regs **per** region



E = Enable Region (4-bits), 0xA = Enabled  
 L = Lock Config  
 B = Background Region  
 C = Cache Mode



W = Write  
 R = Read  
 C = Cacheable  
 D = Debug

SA-SPRUIJ0-019

**Figure 3-6. Region-based Firewall Config Registers with 1 Priv-ID slot per Region**

Figure 3-7 presents firewall regions.



**Figure 3-7. Firewall Regions**

The Region-based firewall is configured using dedicated VBUSP port to CBASS/AXI to VBUSM.C Bridge/DRU that connects to the SMS private VBUSP interconnect.

#### 3.1.6.2.1.1 Region Based Firewall Functional Description

The region based firewall provides a memory region based protection and isolation mechanism. For each defined memory region, it checks the transaction attributes such as secure vs non-secure, debug vs non-debug, supervisor vs user mode, read vs write and so on. The transaction is dropped, if it does not match the configuration and appropriate violation code is registered with offending parameters.

Host modules (for example, AXI2VBUZMC bridge or CBASSes) provide transaction attributes that are checked by the firewalls, which then determine if the transaction should be blocked or passed. The firewall implements filtering algorithm that compares these host incoming transaction parameters against the region policy to give block indication to the host. Firewall region registers configure the filtering mechanism which includes setting region address range, region permission registers and region control register. There are also firewall exception registers used for violation reporting and logging.

The region based firewall supports multiple regions. Each one is defined by address range and associated access permission. The minimum memory region size is 4KB. The firewall concurrently checks the incoming transaction against all enabled regions looking for violations.

Each firewall is associated with the following registers:

- CBASS\_FW\_REGION\_i\_CONTROL
- CBASS\_FW\_REGION\_i\_PERMISSION\_0 to CBASS\_FW\_REGION\_i\_PERMISSION\_2
- CBASS\_FW\_REGION\_i\_START\_ADDRESS\_L and CBASS\_FW\_REGION\_i\_START\_ADDRESS\_H
- CBASS\_FW\_REGION\_i\_END\_ADDRESS\_L and CBASS\_FW\_REGION\_i\_END\_ADDRESS\_H

Each region is defined by start and end physical address and associated permission and control registers. A firewall can have 1-24 regions. In case there is more than 1 region, then these registers are duplicated for all regions. Setting the CBASS\_FW\_REGION\_i\_CONTROL[3-0] ENABLE field to 0xA enables the region and makes firewall check active for this region. Setting to 0x1 the CBASS\_FW\_REGION\_i\_CONTROL[8] BACKGROUND bit indicates to the firewall that the region is background region. Setting to 0x1 the CBASS\_FW\_REGION\_i\_CONTROL[9] CACHE\_MODE bit

ignores cacheable check, so that it cannot fail. In this case the access check is performed based on the READ and WRITE bits in CBASS\_FW\_REGION\_i\_PERMISSION\_x. Clearing CACHE\_MODE enables the cacheable check, so that cacheable transactions are allowed only when the corresponding cacheable permission bit (CBASS\_FW\_REGION\_i\_PERMISSION\_x[y\_CACHEABLE]) is set. If the CBASS\_FW\_REGION\_i\_CONTROL[4] LOCK bit is set to 0x1, then the region configuration cannot be changed at all. This is one-time change. This bit is typically used for primary controller to consume and lock its resources and then pass firewall control to secondary controller.

In case two regions overlap, the CBASS\_FW\_REGION\_i\_CONTROL[8] BACKGROUND bit is used to select the appropriate permission to be used. The region whose BACKGROUND bit is 0x0 (foreground) takes precedence and its permissions are taken into effect. The background region is ignored.

---

**Note**

There can be only one background region per firewall. Foreground regions can have overlapping addresses only with the background region.

It is a software mistake to have overlapping regions with the BACKGROUND bit set to the same value (either background or foreground). Software must be careful to not configure two overlapping regions with the BACKGROUND bit set to the same value.

---

The firewall also checks if the transaction crosses a 4KB boundary. If so, the transaction is blocked regardless of any matching regions.

When a region is set to be debugable through the corresponding CBASS\_FW\_REGION\_i\_PERMISSION\_x [y\_DEBUG] bit, the firewall ignores the read and write checks for any debug transactions, so that it cannot fail. This allows debug breakpoints to be written out to code even in read-only regions.

When a region is set to be cacheable through the corresponding CBASS\_FW\_REGION\_i\_PERMISSION\_x [y\_CACHEABLE] bit and CACHE\_MODE = 0x0, the firewall ignores the read and write checks for any transaction (cacheable or not), so that it cannot fail due to these checks. This allows a write allocated cache to read a cache line even in write-only regions. Due to caches not protecting user and supervisor data from each other, the firewall allows cacheable access to the region when either the user cacheable permission or the supervisor cacheable permission is set.

The firewall notifies the host that the transaction is blocked in case of the following violation conditions:

- All regions are disabled.
- Incoming address does not hit any region.
- Non-secure incoming read transaction attempting to access configured secure-only write/read region.
- Non-secure incoming write transaction attempting to access configured secure-only write/read region.
- Secure incoming read transaction attempting to access configured non-secure-only write/read region.
- Secure incoming write transaction attempting to access configured non-secure region.
- Incoming secure write transaction attempting to access configured secure read region. This check is ignored if the region is configured as cacheable.
- Incoming secure read transaction attempting to access configured secure write region. This check is ignored if the region is configured as cacheable.
- Incoming non-secure write transaction attempting to access configured non-secure read region. This check is ignored if the region is configured as cacheable.
- Incoming non-secure read transaction attempting to access configured non-secure write region. This check is ignored if the region is configured as cacheable.
- Incoming non-secure debug access to non-debugable secure region.
- Incoming non-secure debug access to non-debugable non-secure region.
- Incoming secure debug access to non-debugable secure region.
- Incoming secure debug access to non-debugable non-secure region.
- Incoming cacheable transaction attempting to access non-cacheable configured region.

All violation parameters caused the exception are logged in the firewall exception registers described in *Firewall Exception Registers*. Table 3-5 shows the mapping between the register fields and violation parameters. If the CBASS\_EXCEPTION\_LOGGING\_CONTROL[0] DISABLE\_F bit is set to 0x1, logging is disabled.

If violation occurs, the corresponding firewall notifies the Security Manager (SMS) driving high a dedicated signal. The notification (that is, the signal) can be masked by setting to 0x1 the CBASS\_EXCEPTION\_LOGGING\_CONTROL[1] DISABLE\_PEND bit. The firewall exception notification signal gets automatically cleared when the CBASS\_EXCEPTION\_LOGGING\_DATA3 register is read. That signal can be manually set via the CBASS\_EXCEPTION\_PEND\_SET[0] PEND\_SET bit and cleared via the CBASS\_EXCEPTION\_PEND\_CLEAR[0] PEND\_CLR bit. Reading one of these two bits returns the status of the signal (that is, violation occurred or not).

**Table 3-5. Firewall Violation Parameters**

| Field                                            | Value           | Description                                                                                                                                                           |
|--------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CBASS_EXCEPTION_LOGGING_HEADER0[31-24]<br>TYPE_F | 0x1             | Exception type for firewall violation. This is fixed for the SoC firewalls and is used by software to detect that this corresponding violation comes from a firewall. |
| CBASS_EXCEPTION_LOGGING_HEADER0[23-8]<br>SRC_ID  | 0x-             | Firewall ID. Unique for each firewall. This is used to identify the exact firewall that issued violation so that software detects the precise source.                 |
| CBASS_EXCEPTION_LOGGING_HEADER0[7-0]<br>DEST_ID  | 0x-             | Destination ID of node where the firewall violation has to be routed.                                                                                                 |
| CBASS_EXCEPTION_LOGGING_HEADER1[31-24]<br>GROUP  | 0x0             | Exception group. This is used to group exceptions to category. All firewall exceptions are in one group.                                                              |
| CBASS_EXCEPTION_LOGGING_HEADER1[23-16]<br>CODE   | Exception code: |                                                                                                                                                                       |
|                                                  | 0x0             | Reserved.                                                                                                                                                             |
|                                                  | 0x1             | No region enabled.                                                                                                                                                    |
|                                                  | 0x2             | Incoming address does not hit any active region and transaction is dropped.                                                                                           |
|                                                  | 0x3             | Reserved.                                                                                                                                                             |
|                                                  | 0x4             | Cacheable error. A cacheable transaction attempting to read/write non-cached marked region.                                                                           |
|                                                  | 0x5             | Debug error. A debug transaction attempting to read/write a non-allowed debug region.                                                                                 |
|                                                  | 0x6             | Read error. A Read transaction attempting to read from non-allowed read region.                                                                                       |
|                                                  | 0x7             | Write error. A Write transaction attempting to write from non-allowed write region.                                                                                   |
|                                                  | 0x8             | 4KB crossing error. A transaction attempting to cross a 4KB boundary.                                                                                                 |
| CBASS_EXCEPTION_LOGGING_DATA0[31-0] ADDR_L       | 0x-             | Lower 32 address bits (31:0) of the incoming transaction                                                                                                              |
| CBASS_EXCEPTION_LOGGING_DATA1[15-0]<br>ADDR_H    | 0x-             | Upper 16 address bits (47:32) of the incoming transaction                                                                                                             |

**Table 3-5. Firewall Violation Parameters (continued)**

| Field                                        | Value    | Description                            |
|----------------------------------------------|----------|----------------------------------------|
| CBASS_EXCEPTION_LOGGING_DATA2[7-0] PRIV_ID   | Not used | Incoming transaction parameters        |
| CBASS_EXCEPTION_LOGGING_DATA2[8] SECURE      | 0x-      |                                        |
| CBASS_EXCEPTION_LOGGING_DATA2[9] PRIV        | 0x-      |                                        |
| CBASS_EXCEPTION_LOGGING_DATA2[10] CACHEABLE  | 0x-      |                                        |
| CBASS_EXCEPTION_LOGGING_DATA2[11] DEBUG      | 0x-      |                                        |
| CBASS_EXCEPTION_LOGGING_DATA2[12] READ       | 0x-      |                                        |
| CBASS_EXCEPTION_LOGGING_DATA2[13] WRITE      | 0x-      |                                        |
| CBASS_EXCEPTION_LOGGING_DATA2[27-16] ROUTEID | 0x-      |                                        |
| CBASS_EXCEPTION_LOGGING_DATA3[9-0] BYTECNT   | 0x-      |                                        |
|                                              |          | Byte count of the incoming transaction |

### 3.1.6.2.1.2 Region Based Firewalls

**Table 3-6. Region Based Firewalls**

| Firewall ID | Firewall Physical Address | Firewall Regions | Number of Priv IDs per Region | Protected Instance  | Start Address | Region Size | ASEL Capable |
|-------------|---------------------------|------------------|-------------------------------|---------------------|---------------|-------------|--------------|
| 1           | 0x45000400                | 8                | 3                             | DDR16SS0            | 0x80000000    | 0x80000000  | No           |
| 2           | 0x45000800                | 8                | 3                             | COMPUTE_CLUSTER0    |               |             | Yes          |
| 3           | 0x45000C00                | 56               | 3                             | DEBUGSS_WRAP0       | 0x700000000   | 0x1000      | No           |
| 8           | 0x45002000                | 16               | 3                             | PDMA0               | 0xC00000      | 0x400       | No           |
| 9           | 0x45002400                | 24               | 3                             | DMASS0_ECC_AGGR_0   | 0x3F005000    | 0x400       | No           |
| 10          | 0x45002800                | 8                | 3                             | CBASS_DBG0          | 0x200000      | 0x400       | No           |
| 11          | 0x45002C00                | 16               | 3                             | CBASS_MCASP0        | 0x240000      | 0x400       | No           |
| 32          | 0x45008000                | 4                | 3                             | WKUP_R5FSS0_CORE0   | 0x74000000    | 0x800000    | No           |
| 33          | 0x45008400                | 16               | 3                             | PSRAMECC0           | 0x0           | 0x400       | No           |
| 34          | 0x45008800                | 8                | 3                             | WKUP_GTC0           | 0xA80000      | 0x400       | No           |
| 35          | 0x45008C00                | 16               | 3                             | WKUP_PSC0           | 0x4000000     | 0x1000      | No           |
| 64          | 0x45010000                | 4                | 3                             | PSRAMECC_16K0       | 0x70000000    | 0x10000     | No           |
| 65          | 0x45010400                | 8                | 3                             | MCU_TIMEOUT0        | 0x4300000     | 0x400       | No           |
| 66          | 0x45010800                | 4                | 3                             | CBASS_FW0           | 0x220000      | 0x400       | No           |
| 160         | 0x45028000                | 8                | 3                             | DMASS0_SEC_PROXY_0  | 0x4D000000    | 0x80000     | No           |
| 161         | 0x45028400                | 8                | 3                             | SA3_SSO_SEC_PROXY_0 | 0x43600000    | 0x10000     | No           |

### 3.1.6.2.2 Channelized Firewalls

A Channelized firewall is designed to protect modules that have logical channels (Ring Accelerator and so forth, for example). These firewalls operate at the resolution of a channel and have no association with physical addresses. Each channel is defined as a logical control entity.

In case of channelized firewalls, the number of regions are less than or equal to number of logical channels and each typical channel/region is very small memory space (typically in Bytes, like 16 bytes). A channel is owned by one processing entity, hence only 1 Priv-ID slot is provided for each Channelized firewall along with associated permissions.

Figure 3-8 presents Channelized firewall config registers with 1 Priv-ID slot per region.



SA-SPRUIV0-020

**Figure 3-8. Channelized Firewall Config Registers with 1 Priv-ID slot per Region**

The Channelized firewall is configured using dedicated VBUSP port to CBASS/Bridges that connects to the Device Manager private VBUSP interconnect.

---

#### Note

For more information about the interconnect firewalls, see *Interconnect Firewalls*.

---

#### 3.1.6.2.2.1 Channelized Firewall Functional Description

The channelized firewall protects an address space that consists of multiple channels where each channel needs its own permissions. This is in contrast to the region based firewall which implements a number of regions that can protect a programmed address range. The channelized firewall extends this to a larger number of ranges that can be protected, but each range is no longer programmable and is instead fixed to a particular channel address range. This allows each channel to be owned and protected individually. The channels within same memory region have same size. The system can allocate each channel to a particular owner or owner groups with certain permissions and guarantee that others cannot access that channel. This protection is useful for either accessing data resources, or control for each resource. The channelized firewall provides an efficient way to implement access protection and isolation requiring finer granularity than the region based firewall.

Same as the region based firewall, the channelized firewall may also support multiple regions. Each region contains a number of channels that need to be protected individually and has size in bytes equal to the channel's data to protect. This allows multiple regions so that the firewall can protect a module containing multiple sets of registers that are each channelized and need separate protections, such as data access as well as control setup.

The transaction addresses are compared against region addresses to identify which region is being accessed. Then the offset within the region is used to identify the particular channel being accessed. If a valid channelized region is not decoded during the firewall check, then the transaction is passed through unmodified because the module may have other regions which are not channelized, but accesses to them are already protected by a region based firewall so the channelized one should not block them.

The permission check is performed just like for a region based firewall. The channelized firewall checks for user or supervisor privilege levels. It also checks for transactions that cross important boundaries and gives errors if violated. The first check is for a transaction crossing a 4KB address boundary. This is illegal on the bus, so the firewall checks for compliance. The second check is if the transaction crosses a channel boundary. The channelized firewall blocks a transaction accessing multiple channels in the same burst, as it cannot check the permission for the entire range of channels. The channelized firewall also supports error logging when a transaction fails the checks. It sends information about the type of error and the transaction that caused it.

The channelized firewall is associated with the following registers:

- \*\_CH\_i\_CONTROL, where "i" can be from 0 to 63 and denotes the channel.
- \*\_CH\_i\_PERMISSION\_x, where "i" can be from 0 to 63 and denotes the channel and "x" can be 0 to 2.

**Table 3-7. Channelized Firewall Configuration**

| Channelized Region | which register inside PSC0 is protected                 |
|--------------------|---------------------------------------------------------|
| 0                  | MDCTL27 register inside PSC0 to control LPSC_SMS_common |
| 2                  | MDCTL30 register inside PSC0 to control LPSC_HSM        |
| 3                  | MDCTL31 register inside PSC0 to control LPSC_Sa3ul      |
| 4                  | MDCTL32 register inside PSC0 to control LPSC_HSM_ISO    |

### 3.1.7 Interconnect Error Reporting Feature

CBASS routes the transaction to null end point for graceful termination under the following situation:

- There is no physical connection between initiator and target end points
- Or target interface is in disabled state
- Or the transaction is sent to an unpopulated address

The null end point returns the error status back to the initiator to prevent the interconnect hang. At the same time, CBASS module logs this transaction information in err\_reg region and issues an error interrupt (default\_err\_intr). This default\_err\_intr is sent to all the application processors for debug purpose.

If the transaction is sent to a valid target interface, however the firewall in front of the target interface can prohibit the transaction, the transaction will be logged in the glb\_regs region and cbass will assert a default\_exp interrupt.

### 3.1.8 Connectivity Table

Whether an initiator can access certain target or not depends on following factors:

- Whether there is a physical connection between the initiator and the target end point, which is identified with unique memory address.
- For MCU MCUSand R5FSS: those native 32bit processors have slightly different memory map view. And RAT block may need to be programmed to be able to access some target endpoints
- Majority of the target end points are protected by firewall. The firewall needs to be proper configured to make sure that transactions from the initiator can reach the final target end point.

Table 3-8 shows the physical connectivity between initiator and the target end points.

**Table 3-8. Connectivity Table among Initiators and Targets**

| Target Interfaces       | Initiators |            |           |      |     |     |           |        |     |        |              |                          |            |             |              |     |                |              |
|-------------------------|------------|------------|-----------|------|-----|-----|-----------|--------|-----|--------|--------------|--------------------------|------------|-------------|--------------|-----|----------------|--------------|
|                         | A53SS      | WKUP R5FSS | MCU M4FSS | TIFS | HSM | GPU | MMCSO/1/2 | ICSSM0 | GIC | USB0/1 | debugss_wrap | dmss0 (BCDMA and pktDMA) | PDMA0(SPI) | PDMA1(UART) | PDMA2(MCASP) | DSS | sa3_SS_sa_ul_0 | sa3ss_pktdma |
| A53's ACP               | N          | N          | N         | N    | N   | Y   | Y         | N      | Y   | Y      | Y            | N                        | N          | N           | Y            | Y   | Y              |              |
| Compute_cluster0 config | Y          | Y          | Y         | Y    | Y   | Y   | N         | Y      | N   | N      | Y            | Y                        | N          | N           | N            | Y   | Y              |              |
| UART0/1/2/3/4/5/6       | Y          | Y          | Y         | Y    | Y   | Y   | N         | Y      | N   | N      | Y            | Y                        | N          | Y           | N            | N   | Y              | Y            |
| MCU_UART0               | Y          | Y          | Y         | Y    | Y   | Y   | N         | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| WKUP_UART0              | Y          | Y          | Y         | Y    | Y   | Y   | N         | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |

**Table 3-8. Connectivity Table among Initiators and Targets (continued)**

| Target Interfaces    | Initiators |            |           |      |     |     |            |        |     |        |              |                          |            |             |              |     |                |              |
|----------------------|------------|------------|-----------|------|-----|-----|------------|--------|-----|--------|--------------|--------------------------|------------|-------------|--------------|-----|----------------|--------------|
|                      | A53SS      | WKUP R5FSS | MCU M4FSS | TIFS | HSM | GPU | MMCSDO/1/2 | ICSSM0 | GIC | USB0/1 | debugss_wrap | dmss0 (BCDMA and pktDMA) | PDMA0(SPI) | PDMA1(UART) | PDMA2(MCASP) | DSS | sa3_SS_sa_ul_0 | sa3ss_pktdma |
| SPI0/1/2             | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | Y          | N           | N            | N   | Y              | Y            |
| MCU_SPI0/1           | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| TIMEOUT0             | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_TIMEOUT0/1       | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| Wkup_TIMEOUT0        | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_MCRC64_0         | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCRC64_0             | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DCC0/1/2/3/4/5/6     | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_DCC0             | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| TIMER0/1/2/3/4/5/6/7 | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCUTIMER0/1/2/3      | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| WKUP_TIMER0/1        | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_M4FSS            | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| I2C0/1/2/3           | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_I2C0             | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| WKUP_I2C0            | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCANSS0              | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | Y          | N           | N            | N   | Y              | Y            |
| MCU_MCANSS0/1        | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| All ECC_AGGR         | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| ELM0                 | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| Y                    | Y          | Y          | Y         | Y    | Y   | Y   | Y          | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| CPSW                 | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| ddr16ss              | Y          | Y          | Y         | Y    | Y   | Y   | Y          | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| MMCSDO/1/2           | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| GIC                  | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| RTI                  | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | Y      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_RTI              | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| WKUP_RTI             | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| ALL cbass            | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DEBUGSS0             | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DEBUGSS_WRAP0        | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| FSS0 Data            | Y          | Y          | Y         | Y    | Y   | Y   | Y          | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| FSS0 Config          | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DMASS0 cfg           | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| STM0                 | Y          | Y          | Y         | Y    | Y   | Y   | Y          | Y      | N   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| USB0/1               | Y          | Y          | Y         | Y    | Y   | Y   | N          | Y      | N   | Y      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |

**Table 3-8. Connectivity Table among Initiators and Targets (continued)**

| Target Interfaces      | Initiators |            |           |      |     |     |             |        |     |        |              |                          |            |             |              |     |                |              |
|------------------------|------------|------------|-----------|------|-----|-----|-------------|--------|-----|--------|--------------|--------------------------|------------|-------------|--------------|-----|----------------|--------------|
|                        | A53SS      | WKUP R5FSS | MCU M4FSS | TIFS | HSM | GPU | MMCCSD0/1/2 | ICSSM0 | GIC | USB0/1 | debugss_wrap | dmss0 (BCDMA and pktdMA) | PDMA0(SPI) | PDMA1(UART) | PDMA2(MCASP) | DSS | sa3_SS_sa_ul_0 | sa3ss_pktdma |
| all PBIST CFG          | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DSS                    | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| CSI_RX                 | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DPHY_RX                | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| TIFS                   | Y          | Y          | Y         | Y    | Y   | Y   | Y           | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| HSM                    | Y          | Y          | Y         | Y    | Y   | Y   | Y           | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| GPU                    | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| BW_LIMITERS            | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| ROM                    | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| WKUP_R5FSS TCM         | Y          | Y          | Y         | Y    | Y   | Y   | Y           | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| WKUP_R5FSS config      | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_M4FSS              | Y          | Y          | Y         | Y    | Y   | Y   | Y           | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| ICSSM0                 | Y          | Y          | Y         | Y    | Y   | Y   | Y           | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| GTC                    | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| PSRAMECC               | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| PSRAMECC_16k           | Y          | Y          | Y         | Y    | Y   | Y   | Y           | Y      | Y   | Y      | Y            | Y                        | N          | N           | N            | Y   | Y              | Y            |
| MAILBOX                | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| SA_UL                  | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| all INTR_routers       | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| PSC0                   |            | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_PSC0               | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| CTRL_MMR               | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_CTRL_MMR           | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| WKUP_CTRL_MMR          | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| EFUSE0                 | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| PLL0                   | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_PLL                | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| PADCFG_CTRL            | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_PADCFG_CTRL        | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DDPA0                  | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DFTSS0                 | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| GPIO0/1                | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_GPIO0              | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| PLLCTRL0               | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_PLLCTRL0           | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| PDMA0/1/2 ECC_AGGR CFG | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |

**Table 3-8. Connectivity Table among Initiators and Targets (continued)**

| Target Interfaces | Initiators |            |           |      |     |     |             |        |     |        |              |                          |            |             |              |     |                |              |
|-------------------|------------|------------|-----------|------|-----|-----|-------------|--------|-----|--------|--------------|--------------------------|------------|-------------|--------------|-----|----------------|--------------|
|                   | A53SS      | WKUP R5FSS | MCU M4FSS | TIFS | HSM | GPU | MMCCSD0/1/2 | ICSSM0 | GIC | USB0/1 | debugss_wrap | dmss0 (BCDMA and pktDMA) | PDMA0(SPI) | PDMA1(UART) | PDMA2(MCASP) | DSS | sa3_SS_sa_ul_0 | sa3ss_pktdma |
| ECAP0/1/2         | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| EQEP0/1/2         | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| EPWM0/1/2         | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| McASP0/1/2        | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | Y            | N   | Y              | Y            |
| sa3ss_DMSS_HSM0   | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| DMSS0             | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| ESM               | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |
| MCU_ESM           | Y          | Y          | Y         | Y    | Y   | Y   | N           | Y      | N   | N      | Y            | Y                        | N          | N           | N            | N   | Y              | Y            |

### 3.1.9 QoS Programming Guide

The QoS MMR is integrated as part of data plane CBASS to provide programmability of priority, orderID and CoS sideband signals for each initiator port in the data plane. Currently CoS sideband signal is not used for any routing or schedule purpose. For most of the initiator ports, it has only one setting of the orderID and CoS field. For the initiator port supports with multiple channels, the transactions in each channel can be programmed to have different sets of priority, orderID and CoS. The orderID is a four-bit field value. All the transactions coming from the same initiator ports with the same orderID expect to receive the read data in order.

In the previous generation of the CBASS, how the traffic is split among parallel paths to the same end points is hard coded. The traffic from a certain initiator port is hard coded to choose one of the parallel paths. Due to the nature of hard coded, the system can't do load balancing based on the use case. Keystone3 removes this limitation through splitting traffic using OrderID value. Since the orderID value for the traffic from each initiator port is programmable, the user can load balance based on the use case scenario.

Each target port in each SCR has its own arbiter. The SoC CBASS arbitration is based on epriority. For the ports with equal epriority, the arbiter uses round robin to break the tie.

DDR EMIF also uses orderID to maintain transaction ordering. All the transactions with the same orderID sent to EMIF will be executed in order. In order to maximize the EMIF performance, user shall carefully use the full range of 16 orderID values. Therefore, EMIF can utilize its re-ordering mechanism to improve the EMIF utilization.

Inside EMIF controller, there are mapping register to map CBA priority to AXI priority. EMIF controller schedule transaction using strict priority scheme based on AXI priority. In order to maximize the DDR utilization to reduce the memory page open/close and read and write turn around penalty, it is suggested to map to a single AXI priority.

AM62 has two real-time peripherals DSS and CSI\_RX, both of them have real time deadline. DSS has internal mflag, which can be used to change the priority level of the transaction based on the FIFO depth. CSI\_RX is serviced by block copy DMA. In order to maintain the CSI\_RX bandwidth to prevent CSI\_RX data overflow, the high performance DMA block channel shall be used to issue up to 512B write data to DDR. In addition, the priority for the block copy DMA channel shall use the highest priority.

In addition, GPU can burst out a long back to back burst of transactions to completely exhaust the DDR bandwidth. In order to mitigate the risk of missing real-time peripheral deadline, bandwidth limiters are added to AM62 to control the transactions from both GPU and A53. User can configure and tune the bandwidth limiter parameters based on the use cases.

### 3.1.10 Performance Considerations

#### 3.1.10.1 Initiator Timeout Gasket

In the normal condition, the initiator gasket does not add additional latency to the transaction. However, if the score board which tracks the pending transaction is full, the transaction may be temporarily stalled until the previous transactions are returned.

#### 3.1.10.2 Target Timeout Gasket

Target side gasket adds latency on both forward path and return paths. On the forward path, one cycle latency is added for each command. If it is a write transaction, it also adds one cycle for the write data. On the response path, additional 2 cycles are added for read return data and 2 cycles added on write status return. In addition, the target timeout gasket also stalls the transaction if there is no free slot in the scoreboard for tracking pending transactions:

- If a write command comes in and there are no free slots in the write scoreboard, the entire command bus and write data bus will stall
- If a read command comes in and there are no free slots in the read scoreboard, the entire command bus will stall

If the target timeout gasket enters the time out condition:

- If a write transaction is being timed out, then the write status bus will stall while the write scoreboard flushes the command
- If a read transaction is being timed out, then the read data bus will stall while the read scoreboard flushes the command

Therefore, the target timeout gasket shall be configured properly to avoid stalls due to lack of scoreboard. In addition, all the target side time out gaskets are for VBUSM interface. If a VBUSP target interface needs isolation, it requires a M2P bridge added, which future increases the latency.

#### 3.1.10.3 Latency Introduced by Auto Clock Gating Control

Auto clock gating feature is also called nogate control. It is a technique to reduce the dynamic power for SoC. When nogate control is set to 1b0, it means that the CBA clock will be automatically shut off after 12 cycles idle. After the clock is auto shut off, the first future transaction will have additional pipe latency for each hop. The subsequent transaction will not have this latency penalty if it is arrived within 12 clock cycle windows. When nogate control is set to 1b1, the CBA clock will not shut off automatically.

The auto clock gating control can be modified during device initialization time through register CLKGATE\_CTRL in wkup\_ctrl\_mmr block.

## Chapter 4

# Module Integration



|                                             |     |
|---------------------------------------------|-----|
| 4.1 Memory Controllers.....                 | 98  |
| 4.2 Processors and Accelerators.....        | 100 |
| 4.3 Interprocessor Communication.....       | 110 |
| 4.4 Device Configuration.....               | 115 |
| 4.5 Data Movement Architecture.....         | 119 |
| 4.6 Audio.....                              | 122 |
| 4.7 General Connectivity.....               | 126 |
| 4.8 High-speed Serial Interfaces.....       | 146 |
| 4.9 Memory Interfaces.....                  | 151 |
| 4.10 Industrial and Control Interfaces..... | 158 |
| 4.11 Camera Subsystem.....                  | 169 |
| 4.12 Timer Modules.....                     | 172 |
| 4.13 Internal Diagnostic Modules.....       | 190 |
| 4.14 Graphics Processing Unit (GPU).....    | 466 |
| 4.15 Display Subsystem (DSS).....           | 467 |
| 4.16 Spinlock.....                          | 469 |

## 4.1 Memory Controllers

#### **4.1.1 DDR16 Subsystem (DDR16SS)**

This section contains the integration details for the 16-bit DDR module on this device. For further information, see the DDR16 Subsystem (DDR16SS) section of the Processors and Accelerators chapter.

##### **4.1.1.1 DDR16SS Not Supported Features**

The following features are not supported on this family of devices:

- DDR3, DDR3L, DDR3U, and LPDDR4x Devices
- $\frac{1}{2}$  width (8-bit) mode
- DIMMS
- Data bus obfuscation / data encryption
- Automatic periodic scrubbing of SDRAM for ECC
- Address range of greater than 8GBytes for DDR4
- Address range of greater than 4GBytes for LPDDR4
- memory devices with more than 17 row address bits
- LPDDR4 devices with byte mode die configurations

## 4.2 Processors and Accelerators

### 4.2.1 Arm Cortex A53 Subsystem (A53SS)

This section contains the integration details for the A53SS module on this device. For further information, see the Arm Cortex A53 Subsystem (A53SS) section of the Processors and Accelerators chapter

#### 4.2.1.1 A53SS Unsupported Features

The following features are not supported on this family of devices:

- There are no unsupported features

#### 4.2.1.2 Module Allocations

**Table 4-1. A53SS Modules Allocation within Device Domains**

| Instance      | Domain |     |      |
|---------------|--------|-----|------|
|               | WKUP   | MCU | Main |
| A53SS0_CORE_0 |        |     | ✓    |
| A53SS0_CORE_1 |        |     | ✓    |
| A53SS0_CORE_2 |        |     | ✓    |
| A53SS0_CORE_3 |        |     | ✓    |

#### 4.2.1.3 Resets, Interrupts, and Clocks

**Table 4-2. A53SS Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences         |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|---------------------|
| A53SS0_CORE_0   | PSC0_PSC_0             | PD_A53_0     | LPSC_A53_0    | 45    | OFF     | YES          | LPSC_A53_CL_USTER_0 |
| A53SS0_CORE_1   | PSC0_PSC_0             | PD_A53_1     | LPSC_A53_1    | 46    | OFF     | YES          | LPSC_A53_CL_USTER_0 |
| A53SS0_CORE_2   | PSC0_PSC_0             | PD_A53_2     | LPSC_A53_2    | 47    | OFF     | YES          | LPSC_A53_CL_USTER_0 |
| A53SS0_CORE_3   | PSC0_PSC_0             | PD_A53_3     | LPSC_A53_3    | 48    | OFF     | YES          | LPSC_A53_CL_USTER_0 |

**Table 4-3. A53SS Resets**

| Module Instance | Source     | Description  |
|-----------------|------------|--------------|
| A53SS0          | PSC0_PSC_0 | A53SS0 reset |

**Table 4-4. A53SS Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description              | Type  |
|-----------------|-------------------------|-----------------------------|-------------|--------------------------|-------|
| A53SS0          | A53SS0_cnthpirq0_0      | GICSS0_ppi0_0_IN_26         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cnthpirq1_0      | GICSS0_ppi0_1_IN_26         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cnthpirq2_0      | GICSS0_ppi0_2_IN_26         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cnthpirq3_0      | GICSS0_ppi0_3_IN_26         | GICSS0      | A53SS0 interrupt request | level |

**Table 4-4. A53SS Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description              | Type  |
|-----------------|-------------------------|-----------------------------|-------------|--------------------------|-------|
| A53SS0          | A53SS0_cntpnsirq0_0     | GICSS0_ppi0_0_IN_30         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cntpnsirq1_0     | GICSS0_ppi0_1_IN_30         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cntpnsirq2_0     | GICSS0_ppi0_2_IN_30         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cntpnsirq3_0     | GICSS0_ppi0_3_IN_30         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cntpsirq0_0      | GICSS0_ppi0_0_IN_29         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cntpsirq1_0      | GICSS0_ppi0_1_IN_29         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cntpsirq2_0      | GICSS0_ppi0_2_IN_29         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cntpsirq3_0      | GICSS0_ppi0_3_IN_29         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cantvirq0_0      | GICSS0_ppi0_0_IN_27         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cantvirq1_0      | GICSS0_ppi0_1_IN_27         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cantvirq2_0      | GICSS0_ppi0_2_IN_27         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_cantvirq3_0      | GICSS0_ppi0_3_IN_27         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_commirq0_0       | GICSS0_ppi0_0_IN_22         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_commirq1_0       | GICSS0_ppi0_1_IN_22         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_commirq2_0       | GICSS0_ppi0_2_IN_22         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_commirq3_0       | GICSS0_ppi0_3_IN_22         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq0_0        | GICSS0_ppi0_0_IN_24         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq0_0        | GICSS0_ppi0_1_IN_17         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq0_0        | GICSS0_ppi0_2_IN_17         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq0_0        | GICSS0_ppi0_3_IN_17         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq1_0        | GICSS0_ppi0_0_IN_18         | GICSS0      | A53SS0 interrupt request | level |

**Table 4-4. A53SS Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal                      | Destination Interrupt Input | Destination | Description              | Type  |
|-----------------|----------------------------------------------|-----------------------------|-------------|--------------------------|-------|
| A53SS0          | A53SS0_ctiirq1_0                             | GICSS0_ppi0_1_IN_24         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq1_0                             | GICSS0_ppi0_2_IN_18         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq1_0                             | GICSS0_ppi0_3_IN_18         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq2_0                             | GICSS0_ppi0_0_IN_19         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq2_0                             | GICSS0_ppi0_1_IN_19         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq2_0                             | GICSS0_ppi0_2_IN_24         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq2_0                             | GICSS0_ppi0_3_IN_19         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq3_0                             | GICSS0_ppi0_0_IN_20         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq3_0                             | GICSS0_ppi0_1_IN_20         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq3_0                             | GICSS0_ppi0_2_IN_20         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ctiirq3_0                             | GICSS0_ppi0_3_IN_24         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r0_corrected_err_level_0   | ESM0_esm_lvl_event_IN_24    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r0_uncorrected_err_level_0 | ESM0_esm_lvl_event_IN_94    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r1_corrected_err_level_0   | ESM0_esm_lvl_event_IN_25    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r1_uncorrected_err_level_0 | ESM0_esm_lvl_event_IN_93    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r2_corrected_err_level_0   | ESM0_esm_lvl_event_IN_45    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r2_uncorrected_err_level_0 | ESM0_esm_lvl_event_IN_46    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r3_corrected_err_level_0   | ESM0_esm_lvl_event_IN_47    | ESM0        | A53SS0 interrupt request | level |

**Table 4-4. A53SS Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal                             | Destination Interrupt Input | Destination | Description              | Type  |
|-----------------|-----------------------------------------------------|-----------------------------|-------------|--------------------------|-------|
| A53SS0          | A53SS0_ecc_eccagg_r3_uncorrected_err_level_0        | ESM0_esm_lvl_event_IN_48    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r_corepac_corrected_err_level_0   | ESM0_esm_lvl_event_IN_26    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_ecc_eccagg_r_corepac_uncorrected_err_level_0 | ESM0_esm_lvl_event_IN_95    | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_exterrirq_0                                  | ESM0_esm_lvl_event_IN_144   | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_interrrq_0                                   | ESM0_esm_lvl_event_IN_145   | ESM0        | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_pmuirq0_0                                    | GICSS0_ppi0_0_IN_23         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_pmuirq1_0                                    | GICSS0_ppi0_1_IN_23         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_pmuirq2_0                                    | GICSS0_ppi0_2_IN_23         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_pmuirq3_0                                    | GICSS0_ppi0_3_IN_23         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_vcpumntirq0_0                                | GICSS0_ppi0_0_IN_25         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_vcpumntirq1_0                                | GICSS0_ppi0_1_IN_25         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_vcpumntirq2_0                                | GICSS0_ppi0_2_IN_25         | GICSS0      | A53SS0 interrupt request | level |
| A53SS0          | A53SS0_vcpumntirq3_0                                | GICSS0_ppi0_3_IN_25         | GICSS0      | A53SS0 interrupt request | level |

**Table 4-5. A53SS Clocks**

| Module Instance | Module Clock Input  | Source Clock            | Source Control Register | Description |
|-----------------|---------------------|-------------------------|-------------------------|-------------|
| A53SS0          | COREPAC_ARM_CLK_CLK | MAIN_PLL8_HSDIV0_CLKOUT |                         | A53SS clock |

#### 4.2.2 Arm Cortex R5F Subsystem (WKUP\_R5FSS)

This section contains the integration details for the WKUP\_R5FSS module on this device. For further information, see the Arm Cortex R5F Subsystem (WKUP\_R5FSS) section of the Processors and Accelerators chapter

##### 4.2.2.1 WKUP\_R5FSS Unsupported Features

The following features are not supported on this family of devices:

- CPU1 is not supported. This family of devices only supports a single core R5F implementation

##### 4.2.2.2 Module Allocations

**Table 4-6. WKUP\_R5FSS Modules Allocation within Device Domains**

| Instance    | Domain |     |      |
|-------------|--------|-----|------|
|             | WKUP   | MCU | Main |
| WKUP_R5FSS0 | ✓      |     |      |

##### 4.2.2.3 Reference

**Table 4-7. R5FSS Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences        |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------------|
| A53SS0_CORE_0   | PSC0_PSC_0             | PD_A53_0     | LPSC_A53_0    | 45    | OFF     | YES          | LPSC_A53_CLKSTER_0 |

**Table 4-8. R5FSS Clocks**

| Module Instance | Module Clock Input | Source Clock | Source Control Register | Description                   |
|-----------------|--------------------|--------------|-------------------------|-------------------------------|
| R5FSS0_CORE0    | FCLK               | DM_CLK       | WKUP_CLKSEL[0:0]        | R5FSS0_CORE0 Functional Clock |
|                 | ICLK               | DM_CLK       | WKUP_CLKSEL[0:0]        | R5FSS0_CORE0 Interface Clock  |

**Table 4-9. R5FSS Integration Resets**

| Module Instance | Source     | Description        |
|-----------------|------------|--------------------|
| R5FSS0_CORE0    | PSC0_PSC_0 | R5FSS0_CORE0 reset |

**Table 4-10. R5FSS Hardware Requests**

| Module Instance | Module Interrupt Signal               | Destination Interrupt Input | Destination  | Description                    | Type  |
|-----------------|---------------------------------------|-----------------------------|--------------|--------------------------------|-------|
| R5FSS0_CORE0    | R5FSS0_CORE0_cti_0                    | R5FSS0_CORE0_intr_IN_175    | R5FSS0_CORE0 | R5FSS0_CORE0 interrupt request | level |
| R5FSS0_CORE0    | R5FSS0_CORE0_ec_c_corrected_level_0   | ESM0_esm_lvl_event_IN_30    | ESM0         | R5FSS0_CORE0 interrupt request | level |
| R5FSS0_CORE0    | R5FSS0_CORE0_ec_c_uncorrected_level_0 | ESM0_esm_lvl_event_IN_91    | ESM0         | R5FSS0_CORE0 interrupt request | level |
| R5FSS0_CORE0    | R5FSS0_CORE0_ex_p_intr_0              | ESM0_esm_lvl_event_IN_124   | ESM0         | R5FSS0_CORE0 interrupt request | level |
| R5FSS0_CORE0    | R5FSS0_CORE0_ex_p_intr_0              | R5FSS0_CORE0_intr_IN_4      | R5FSS0_CORE0 | R5FSS0_CORE0 interrupt request | level |

**Table 4-10. R5FSS Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description                    | Type  |
|-----------------|-------------------------|-----------------------------|--------------|--------------------------------|-------|
| R5FSS0_CORE0    | R5FSS0_CORE0_pm_u_0     | R5FSS0_CORE0_intr_IN_58     | R5FSS0_CORE0 | R5FSS0_CORE0 interrupt request | level |
| R5FSS0_CORE0    | R5FSS0_CORE0_val_fiq_0  | R5FSS0_CORE0_intr_IN_59     | R5FSS0_CORE0 | R5FSS0_CORE0 interrupt request | level |
| R5FSS0_CORE0    | R5FSS0_CORE0_vali_rq_0  | R5FSS0_CORE0_intr_IN_60     | R5FSS0_CORE0 | R5FSS0_CORE0 interrupt request | level |

#### 4.2.3 Arm Cortex M4F Subsystem (MCU\_M4FSS)

This section contains the integration details for the MCU\_M4FSS module on this device. For further information, see the Arm Cortex M4F Subsystem (MCU\_M4FSS) section of the Processors and Accelerators chapter

##### 4.2.3.1 MCU\_M4FSS Unsupported Features

The following features are not supported on this family of devices:

- Bit Banding
- Big Endian

##### 4.2.3.2 Module Allocations

**Table 4-11. MCU\_M4FSS Modules Allocation within Device Domains**

| Instance   | Domain |     |      |
|------------|--------|-----|------|
|            | WKUP   | MCU | Main |
| MCU_M4FSS0 |        | ✓   |      |

##### 4.2.3.3 Resets, Interrupts, and Clocks

**Table 4-12. MCU\_M4FSS Integration Attributes**

| Module Instance  | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences      |
|------------------|------------------------|--------------|---------------|-------|---------|--------------|------------------|
| MCU_M4FSS0_CORE0 | WKUP_PSC0              | PD_M4F       | LPSC MCU_M4F  | 6     | OFF     | YES          | LPSC MCU_C_OMMON |

**Table 4-13. MCU\_M4FSS Resets**

| Module Instance | Source    | Description      |
|-----------------|-----------|------------------|
| MCU_M4FSS0      | WKUP_PSC0 | MCU_M4FSS0 reset |

**Table 4-14. MCU\_M4FSS Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description | Type |
|-----------------|-------------------------|-----------------------------|-------------|-------------|------|
|                 |                         |                             |             |             |      |

**Table 4-15. A53SS Clocks**

| Module Instance  | Module Clock Input | Source Clock  | Source Control Register | Description                                                                                         |
|------------------|--------------------|---------------|-------------------------|-----------------------------------------------------------------------------------------------------|
| MCU_M4FSS0_CORE0 | DAP_CLK            | MCU_SYSCLK0   |                         | MCU_M4FSS0_CORE0 Module DAP Clock                                                                   |
|                  | VBUS_CLK           | MCU_SYSCLK0   | MCU_M4FSS_CLKSEL[0:0]   | MCU_M4FSS0_CORE0 Main module clock that drives majority of blocks including M4F in functional mode. |
|                  |                    | MCU_SYSCLK0/2 | MCU_M4FSS_CLKSEL[0:0]   |                                                                                                     |

#### 4.2.4 Programmable Real-Time Unit Subsystem (PRUSS)

This section contains the integration details for the PRUSS module on this device. For Further information, see the Programmable Real-Time Unit Subsystem(PRUSS) section of the Processors and Accelerators chapter

##### 4.2.4.1 PRUSS Unsupported Features

The following features are not supported on this family of devices:

- Industrial Communications Subsystem features
  - Ethernet (MII, MDIO, Industrial Communication Protocols are not supported)
  - Three Channel Peripheral Interface (EnDat 2.2 and BiSS not supported)
  - Sigma-Delta (SD)
  - 16550 UART supporting 12Mps

##### 4.2.4.2 Module Allocations

**Table 4-16. PRUSS Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| PRUSS    |        |     | ✓    |

##### 4.2.4.3 Resets, Interrupts, and Clocks

**Table 4-17. PRUSS Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences     |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|-----------------|
| ICSSM0          | PSC0_PSC_0             | PD_ICSSM     | LPSC_ICSSM    | 40    | OFF     | YES          | LPSC_SMS_COMMON |

**Table 4-18. PRUSS Resets**

| Module Instance | Source     | Description  |
|-----------------|------------|--------------|
| ICSSM0          | PSC0_PSC_0 | ICSSM0 reset |

**Table 4-19. PRUSS Hardware Requests**

| Module Instance | Module Interrupt Signal         | Destination Interrupt Input     | Destination            | Description              | Type  |
|-----------------|---------------------------------|---------------------------------|------------------------|--------------------------|-------|
| ICSSM0          | ICSSM0_iso_reset_pr otcol_ack_0 | MCU_M4FSS0_COR E0_nvic_IN_53    | MCU_M4FSS0_COR E0      | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_iso_reset_pr otcol_ack_0 | GICSS0_spi_IN_167               | GICSS0                 | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_iso_reset_pr otcol_ack_0 | R5FSS0_CORE0_intr _IN_170       | R5FSS0_CORE0           | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_iso_reset_pr otcol_ack_0 | TIFS0_nvic_IN_194               | TIFS0                  | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_iso_reset_pr otcol_ack_0 | HSM0_nvic_IN_194                | HSM0                   | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_edc0_s ync0_out_0    | TIMESYNC_EVENT_ROUTER0_in_IN_10 | TIMESYNC_EVENT_ROUTER0 | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_edc0_s ync1_out_0    | TIMESYNC_EVENT_ROUTER0_in_IN_9  | TIMESYNC_EVENT_ROUTER0 | ICSSM0 interrupt request | level |

**Table 4-19. PRUSS Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal             | Destination Interrupt Input        | Destination           | Description              | Type  |
|-----------------|-------------------------------------|------------------------------------|-----------------------|--------------------------|-------|
| ICSSM0          | ICSSM0_pr1_edio0_wd_trig_0          | ESM0_esm_lvl_event_IN_68           | ESM0                  | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_pend_[7:0]    | EPWM0_epwm_synci_n_IN_0            | EPWM0                 | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_pend_[7:0]    | MCU_M4FSS0_COR_E0_nvic_IN_51       | MCU_M4FSS0_COR_E0     | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_pend_[7:0]    | MCU_M4FSS0_COR_E0_nvic_IN_52       | MCU_M4FSS0_COR_E0     | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_pend_[7:0]    | GICSS0_spi_IN_[127:120]            | GICSS0                | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_pend_[7:0]    | R5FSS0_CORE0_intr_IN_[127:120]     | R5FSS0_CORE0          | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_pend_[7:0]    | TIFS0_nvic_IN_[67:60]              | TIFS0                 | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_pend_[7:0]    | HSM0_nvic_IN_[67:60]               | HSM0                  | ICSSM0 interrupt request | level |
| ICSSM0          | ICSSM0_pr1_host_int_r_req_[7:0]     | CMP_EVENT_INTRO_UTERO_in_IN_[7:0]  | CMP_EVENT_INTRO_UTERO | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_iep0_cmp_intr_req_[15:0] | CMP_EVENT_INTRO_UTERO_in_IN_[23:8] | CMP_EVENT_INTRO_UTERO | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_rx_sof_i_ntr_req_[1:0]   | GICSS0_spi_IN_244                  | GICSS0                | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_rx_sof_i_ntr_req_[1:0]   | GICSS0_spi_IN_245                  | GICSS0                | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_rx_sof_i_ntr_req_[1:0]   | R5FSS0_CORE0_intr_IN_244           | R5FSS0_CORE0          | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_rx_sof_i_ntr_req_[1:0]   | R5FSS0_CORE0_intr_IN_245           | R5FSS0_CORE0          | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_tx_sof_i_ntr_req_[1:0]   | GICSS0_spi_IN_246                  | GICSS0                | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_tx_sof_i_ntr_req_[1:0]   | GICSS0_spi_IN_247                  | GICSS0                | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_tx_sof_i_ntr_req_[1:0]   | R5FSS0_CORE0_intr_IN_246           | R5FSS0_CORE0          | ICSSM0 interrupt request | pulse |
| ICSSM0          | ICSSM0_pr1_tx_sof_i_ntr_req_[1:0]   | R5FSS0_CORE0_intr_IN_247           | R5FSS0_CORE0          | ICSSM0 interrupt request | pulse |

**Table 4-20. PRUSS Clocks**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description |
|-----------------|--------------------|-----------------------------|-------------------------|-------------|
| ICSSM0          | CORE_CLK           | MAIN_PLL2_HSDIV0_CL<br>KOUT | ICSSM0_CLKSEL[0:0]      |             |
|                 |                    | MAIN_PLL0_HSDIV9_CL<br>KOUT | ICSSM0_CLKSEL[0:0]      |             |
|                 | IEP_CLK            | MAIN_PLL2_HSDIV5_CL<br>KOUT | ICSSM0_CLKSEL[18:16]    |             |
|                 |                    | MAIN_PLL0_HSDIV6_CL<br>KOUT | ICSSM0_CLKSEL[18:16]    |             |
|                 |                    | CP_GEMAC_CPTS_REF<br>_CLK   | ICSSM0_CLKSEL[18:16]    |             |
|                 |                    | MCU_EXT_REFCLK0             | ICSSM0_CLKSEL[18:16]    |             |
|                 |                    | EXT_REFCLK1                 | ICSSM0_CLKSEL[18:16]    |             |
|                 |                    | MCU_SYSCLK0                 | ICSSM0_CLKSEL[18:16]    |             |
|                 |                    | MAIN_SYSCLK0                | ICSSM0_CLKSEL[18:16]    |             |
|                 | UCLK_CLK           | MAIN_PLL1_HSDIV0_CL<br>KOUT |                         |             |
|                 | VCLK_CLK           | MAIN_SYSCLK0/2              |                         |             |

## 4.3 Interprocessor Communication

### 4.3.1 Mailbox

This section contains the integration details for the Mailbox module on this device. For Further information, see the Deep Mailbox section of the Interprocessor Communications chapter

#### 4.3.1.1 Mailbox Unsupported Features

The following features are not supported on this family of devices:

- 'User' protection of mailbox in hardware - Must be implemented by software if required

#### 4.3.1.2 Reference

**Table 4-21. Mailbox Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain   | Index | Default | Controllable | dependences        |
|-----------------|------------------------|--------------|-----------------|-------|---------|--------------|--------------------|
| MAILBOX0        | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_SMS_COMMON | 27    | ON      | YES          | LPSC_MAIN_ALWAYSON |

**Table 4-22. Mailbox Clocks**

| Module Instance | Module Clock Input | Source Clock            | Source Control Register | Description                                                                     |
|-----------------|--------------------|-------------------------|-------------------------|---------------------------------------------------------------------------------|
| MAILBOX0        | VCLK_CLK           | MAIN_PLL15_HSDIV0CLKOUT |                         | MAILBOX0 clock. This clock is used for all interface and functional operations. |

**Table 4-23. Mailbox Integration Resets**

| Module Instance | Source | Description    |
|-----------------|--------|----------------|
| MAILBOX0        | PSC0   | MAILBOX0 reset |

**Table 4-24. Mailbox Hardware Requests**

| Module Instance | Module Interrupt Signal                    | Destination Interrupt Input | Destination         | Description                           | Type  |
|-----------------|--------------------------------------------|-----------------------------|---------------------|---------------------------------------|-------|
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_0 | MCU_M4FSS0_CORE0_nvic_IN_50 | MCU_M4FSS0_CORE0_E0 | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_0 | GICSS0_spi_IN_108           | GICSS0              | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_0 | GICSS0_spi_IN_109           | GICSS0              | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_0 | R5FSS0_CORE0_intr_IN_254    | R5FSS0_CORE0        | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_0 | R5FSS0_CORE0_intr_IN_255    | R5FSS0_CORE0        | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_0 | TIFS0_nvic_IN_77            | TIFS0               | MAILBOX0_CLUSTE_R_0 interrupt request | level |

Table 4-24. Mailbox Hardware Requests (continued)

| Module Instance | Module Interrupt Signal                    | Destination Interrupt Input  | Destination       | Description                           | Type  |
|-----------------|--------------------------------------------|------------------------------|-------------------|---------------------------------------|-------|
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_0 | HSM0_nvic_IN_77              | HSM0              | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_1 | MCU_M4FSS0_COR_E0_nvic_IN_50 | MCU_M4FSS0_COR_E0 | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_1 | GICSS0_spi_IN_108            | GICSS0            | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_1 | GICSS0_spi_IN_109            | GICSS0            | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_1 | R5FSS0_CORE0_intr_IN_254     | R5FSS0_CORE0      | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_1 | R5FSS0_CORE0_intr_IN_255     | R5FSS0_CORE0      | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_1 | TIFS0_nvic_IN_77             | TIFS0             | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_1 | HSM0_nvic_IN_77              | HSM0              | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_2 | MCU_M4FSS0_COR_E0_nvic_IN_50 | MCU_M4FSS0_COR_E0 | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_2 | GICSS0_spi_IN_108            | GICSS0            | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_2 | GICSS0_spi_IN_109            | GICSS0            | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_2 | R5FSS0_CORE0_intr_IN_254     | R5FSS0_CORE0      | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_2 | R5FSS0_CORE0_intr_IN_255     | R5FSS0_CORE0      | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_2 | TIFS0_nvic_IN_77             | TIFS0             | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_2 | HSM0_nvic_IN_77              | HSM0              | MAILBOX0_CLUSTE_R_0 interrupt request | level |

**Table 4-24. Mailbox Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal                    | Destination Interrupt Input  | Destination       | Description                           | Type  |
|-----------------|--------------------------------------------|------------------------------|-------------------|---------------------------------------|-------|
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_3 | MCU_M4FSS0_COR_E0_nvic_IN_50 | MCU_M4FSS0_COR_E0 | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_3 | GICSS0_spi_IN_108            | GICSS0            | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_3 | GICSS0_spi_IN_109            | GICSS0            | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_3 | R5FSS0_CORE0_intr_IN_254     | R5FSS0_CORE0      | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_3 | R5FSS0_CORE0_intr_IN_255     | R5FSS0_CORE0      | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_3 | TIFS0_nvic_IN_77             | TIFS0             | MAILBOX0_CLUSTE_R_0 interrupt request | level |
| MAILBOX0        | MAILBOX0_CLUSTE_R_0_mailbox_cluster_pend_3 | HSM0_nvic_IN_77              | HSM0              | MAILBOX0_CLUSTE_R_0 interrupt request | level |

### 4.3.2 Spinlock

This section contains the integration details for the Spinlock module on this device. For further information, see the Spinlock section of the Peripherals chapter

#### 4.3.2.1 SPINLOCK Unsupported Features

The following features are not supported on this family of devices:

- ARM Architectural Spinlock Instructions (LDREX, STREX)
- Any use model other than binary mutex (ex. counting semaphore, lockless programming) - Spinlock MMR is a single binary 0,1 implemented by a state machine
- 64 bit accesses - Spinlock MMRs are aligned on 32-bit boundaries meaning a 64 bit access affects the state of 2 spinlocks

#### 4.3.2.2 Module Allocations

**Table 4-25. Spinlock Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| SPINLOCK0 |        |     | ✓    |

#### 4.3.2.3 Resets, Interrupts, and Clocks

**Table 4-26. Spinlock Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain   | Index | Default | Controllable | dependences        |
|-----------------|------------------------|--------------|-----------------|-------|---------|--------------|--------------------|
| SPINLOCK0       | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_SMS_COMMON | 27    | ON      | YES          | LPSC_MAIN_ALWAYSON |

**Table 4-27. Spinlock Resets**

| Module Instance | Source | Description     |
|-----------------|--------|-----------------|
| SPINLOCK0       | PSC0   | SPINLOCK0 reset |

**Table 4-28. Spinlock Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description | Type |
|-----------------|-------------------------|-----------------------------|-------------|-------------|------|
| SPINLOCK0       |                         |                             |             |             | NONE |

**Table 4-29. Spinlock Clocks**

| Module Instance | Module Clock Input | Source Clock               | Source Control Register | Description |
|-----------------|--------------------|----------------------------|-------------------------|-------------|
| SPINLOCK0       | VBUS_FCLK          | MAIN_PLL15_HSDIV0_CLKOUT/2 |                         |             |

## 4.4 Device Configuration

### 4.4.1 Control Module (CTRL\_MMR)

This section contains the integration details for the CTRL\_MMR module on this device. For further information, see the Memory Mapped Control Register Modules (CTRL\_MMR) section of the Device Configuration chapter.

#### 4.4.1.1 Module Allocations

**Table 4-30. CTRL\_MMR Modules Allocation within Device Domains**

| Instance       | Domain |     |      |
|----------------|--------|-----|------|
|                | WKUP   | MCU | Main |
| CTRL_MMR0      |        |     | ✓    |
| MCU_CTRL_MMR0  |        | ✓   |      |
| WKUP_CTRL_MMR0 | ✓      |     |      |

#### 4.4.1.2 Resets, Interrupts, and Clocks

**Table 4-31. CTRL\_MMR Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain    | Module Domain      | Index | Default | Controllable | dependences |
|-----------------|------------------------|-----------------|--------------------|-------|---------|--------------|-------------|
| CTRL_MMR0       | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| WKUP_CTRL_MMR0  | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| MCU_CTRL_MMRO   | WKUP_PSC0              | GP_CORE_CTL_MCU | LPSC MCU ALWAYSON  | 0     | ON      | NO           | NONE        |

**Table 4-32. CTRL\_MMR Resets**

| Module Instance | Source       | Description          |
|-----------------|--------------|----------------------|
| CTRL_MMR0       | PSC0_PSC_0   | CTRL_MMR0 reset      |
| CTRL_MMR0       | PLLCTRL0     | CTRL_MMR0 reset      |
| WKUP_CTRL_MMR0  | PSC0_PSC_0   | WKUP_CTRL_MMR0 reset |
| WKUP_CTRL_MMR0  | PLLCTRL0     | WKUP_CTRL_MMR0 reset |
| MCU_CTRL_MMR0   | WKUP_PSC0    | MCU_CTRL_MMR0 reset  |
| MCU_CTRL_MMR0   | MCU_PLLCTRL0 | MCU_CTRL_MMR0 reset  |

**Table 4-33. CTRL\_MMR Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description                 | Type  |
|-----------------|-------------------------|-----------------------------|--------------|-----------------------------|-------|
| CTRL_MMR0       | CTRL_MMR0_access_err_0  | GICSS0_spi_IN_129           | GICSS0       | CTRL_MMR0 interrupt request | level |
| CTRL_MMR0       | CTRL_MMR0_access_err_0  | R5FSS0_CORE0_intr_IN_128    | R5FSS0_CORE0 | CTRL_MMR0 interrupt request | level |
| CTRL_MMR0       | CTRL_MMR0_access_err_0  | TIFS0_nvic_IN_220           | TIFS0        | CTRL_MMR0 interrupt request | level |
| CTRL_MMR0       | CTRL_MMR0_access_err_0  | HSM0_nvic_IN_220            | HSM0         | CTRL_MMR0 interrupt request | level |

Table 4-33. CTRL\_MMR Hardware Requests (continued)

| Module Instance | Module Interrupt Signal                  | Destination Interrupt Input | Destination  | Description                      | Type  |
|-----------------|------------------------------------------|-----------------------------|--------------|----------------------------------|-------|
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | GICSS0_spi_IN_129           | GICSS0       | WKUP_CTRL_MMR0 interrupt request | level |
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | R5FSS0_CORE0_intr_IN_128    | R5FSS0_CORE0 | WKUP_CTRL_MMR0 interrupt request | level |
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | TIFS0_nvic_IN_220           | TIFS0        | WKUP_CTRL_MMR0 interrupt request | level |
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | HSM0_nvic_IN_220            | HSM0         | WKUP_CTRL_MMR0 interrupt request | level |
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | GICSS0_spi_IN_129           | GICSS0       | WKUP_CTRL_MMR0 interrupt request | level |
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | R5FSS0_CORE0_intr_IN_128    | R5FSS0_CORE0 | WKUP_CTRL_MMR0 interrupt request | level |
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | TIFS0_nvic_IN_220           | TIFS0        | WKUP_CTRL_MMR0 interrupt request | level |
| WKUP_CTRL_MMR0  | WKUP_CTRL_MMR0_access_err_0              | HSM0_nvic_IN_220            | HSM0         | WKUP_CTRL_MMR0 interrupt request | level |
| MCU_CTRL_MMR0   | MCU_CTRL_MMR0_I_PC_SET0_ipc_set_ip_cfg_0 | R5FSS0_CORE0_intr_IN_0      | R5FSS0_CORE0 | MCU_CTRL_MMR0 interrupt request  | level |
| MCU_CTRL_MMR0   | MCU_CTRL_MMR0_access_err_0               | GICSS0_spi_IN_129           | GICSS0       | MCU_CTRL_MMR0 interrupt request  | level |
| MCU_CTRL_MMR0   | MCU_CTRL_MMR0_access_err_0               | R5FSS0_CORE0_intr_IN_128    | R5FSS0_CORE0 | MCU_CTRL_MMR0 interrupt request  | level |
| MCU_CTRL_MMR0   | MCU_CTRL_MMR0_access_err_0               | TIFS0_nvic_IN_220           | TIFS0        | MCU_CTRL_MMR0 interrupt request  | level |
| MCU_CTRL_MMR0   | MCU_CTRL_MMR0_access_err_0               | HSM0_nvic_IN_220            | HSM0         | MCU_CTRL_MMR0 interrupt request  | level |

Table 4-34. CTRL\_MMR Clocks

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                                   |
|-----------------|--------------------|----------------|-------------------------|-----------------------------------------------|
| CTRL_MMR0       | FICLK              | MAIN_SYSCLK0/4 |                         | CTRL_MMR0 Functional and Interface Clock      |
| WKUP_CTRL_MMR0  | FICLK              | DM_CLK/4       |                         | WKUP_CTRL_MMR0 Functional and Interface Clock |
| MCU_CTRL_MMR0   | FICLK              | MCU_SYSCLK0/4  |                         | MCU_CTRL_MMR0 Functional and Interface Clock  |

#### 4.4.2 Pad Configuration Module (PADCFC\_CTRL)

This section contains the integration details for the PADCFC\_CTRL module on this device. For further information, see the Pad Configuration Register Modules (PADCFC\_CTRL) section of the Device Configuration chapter.

#### 4.4.2.1 Module Allocations

**Table 4-35. PADC\_MMR Modules Allocation within Device Domains**

| Instance            | Domain |     |      |
|---------------------|--------|-----|------|
|                     | WKUP   | MCU | Main |
| PADC_MMR_CTRL0      |        |     | ✓    |
| WKUP_PADC_MMR_CTRL0 | ✓      |     |      |

#### 4.4.2.2 Resets, Interrupts, and Clocks

**Table 4-36. PADC\_MMR Integration Attributes**

| Module Instance     | Power Sleep Controller | Power Domain    | Module Domain      | Index | Default | Controllable | dependences |
|---------------------|------------------------|-----------------|--------------------|-------|---------|--------------|-------------|
| PADC_MMR_CTRL0      | PSC0                   | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| WKUP_PADC_MMR_CTRL0 | WKUP_PSC0              | GP_CORE_CTL_MCU | LPSC MCU ALWAYSON  | 0     | ON      | NO           | NONE        |

**Table 4-37. PADC\_MMR Resets**

| Module Instance     | Source       | Description               |
|---------------------|--------------|---------------------------|
| PADC_MMR_CTRL0      | PSC0         | PADC_MMR_CTRL0 reset      |
|                     | PLLCTRL0     | PADC_MMR_CTRL0 reset      |
| WKUP_PADC_MMR_CTRL0 | WKUP_PSC0    | WKUP_PADC_MMR_CTRL0 reset |
|                     | MCU_PLLCTRL0 | WKUP_PADC_MMR_CTRL0 reset |

**Table 4-38. PADC\_MMR Hardware Requests**

| Module Instance     | Module Interrupt Signal          | Destination Interrupt Input | Destination  | Description                           | Type  |
|---------------------|----------------------------------|-----------------------------|--------------|---------------------------------------|-------|
| PADC_MMR_CTRL0      | PADC_MMR_CTRL0_access_err_0      | GICSS0_spi_IN_129           | GICSS0       | PADC_MMR_CTRL0 interrupt request      | level |
|                     |                                  | R5FSS0_CORE0_intr_IN_128    | R5FSS0_CORE0 | PADC_MMR_CTRL0 interrupt request      | level |
|                     |                                  | TIFS0_nvic_IN_220           | TIFS0        | PADC_MMR_CTRL0 interrupt request      | level |
|                     |                                  | HSM0_nvic_IN_220            | HSM0         | PADC_MMR_CTRL0 interrupt request      | level |
| WKUP_PADC_MMR_CTRL0 | WKUP_PADC_MMR_CTRL0_access_err_0 | GICSS0_spi_IN_129           | GICSS0       | WKUP_PADC_MMR_CTRL0 interrupt request | level |
|                     |                                  | R5FSS0_CORE0_intr_IN_128    | R5FSS0_CORE0 | WKUP_PADC_MMR_CTRL0 interrupt request | level |
|                     |                                  | TIFS0_nvic_IN_220           | TIFS0        | WKUP_PADC_MMR_CTRL0 interrupt request | level |
|                     |                                  | HSM0_nvic_IN_220            | HSM0         | WKUP_PADC_MMR_CTRL0 interrupt request | level |

**Table 4-39. PADCFG\_MMR Clocks**

| Module Instance   | Module Clock Input | Source Clock   | Source Control Register | Description                                            |
|-------------------|--------------------|----------------|-------------------------|--------------------------------------------------------|
| PADCFG_CTRL0      | FICLK              | MAIN_SYSCLK0/4 |                         | PADCFG_CTRL0<br>Functional and Interface<br>Clock      |
| WKUP_PADCFG_CTRL0 | FICLK              | MCU_SYSCLK0/4  |                         | WKUP_PADCFG_CTRL0<br>Functional and Interface<br>Clock |

## 4.5 Data Movement Architecture

#### 4.5.1 Data Movement Subsystem (DMSS)

This section contains the integration details for the DMSS module on this device. For further information, see the Data Movement Subsystem (DMSS) section of the Data Movement Architecture chapter.

##### 4.5.1.1 DMSS Unsupported Features

The following features are not supported on this family of devices:

- Ring Accelerator QM and CREDENTIAL Modes

##### 4.5.1.2 Global Event Map

The global event map for all DMSS events is shown in [Table 4-40](#)

**Table 4-40. Global Event Map**

| Destination               |                     | Offset          | PSIL Routed Slots | Actual Slots |
|---------------------------|---------------------|-----------------|-------------------|--------------|
| DMSS Instance or External | Port                |                 |                   |              |
| DMSS                      | DMSS INTAGGR SEVI   | 0 (0k)          | 8192 (8k)         | 1536         |
| DMSS                      | DMSS INTAGGR MEVI   | 8192 (8k)       | 2048 (2k)         | 128          |
| DMSS                      | DMSS INTAGGR GEVI   | 10240 (10k)     | 2048 (2k)         | 256          |
| External                  | DMSC IA SEVI        | 18432 (18k)     | 2048 (2k)         | -            |
| DMSS                      | DMSS INTAGGR LEVI   | 32768 (32k)     | 32 (0.03k)        | 32           |
| External                  | PDMA_MAIN0 LEVI     | 41984 (41.000k) | 128               | -            |
| External                  | PDMA_MAIN1 LEVI     | 42112 (41.125k) | 128               | -            |
| DMSS                      | DMSS BCDMA Triggers | 50176 (49k)     | 1024 (1k)         | 164          |

##### 4.5.1.3 PSI-L System Thread Map

**Table 4-41. PSI-L System Thread Map**

| Thread Number      | NAV Instance | Endpoint        |
|--------------------|--------------|-----------------|
| 0x0000             | DMSS         | PSILCFG CFGSTRM |
| 0x0020             | DMSS         | PKTDMA CFGSTRM  |
| 0x0021             | DMSS         | BCDMA CFGSTRM   |
| 0x1000-0x1fff      | DMSS         | PKTDMA Threads  |
| 0x2000-0x2fff      | DMSS         | BCDMA Threads   |
| 0x3000-0x42ff      | DMSS         | Reserved        |
| 0x4300-0x43ff      | DMSS         | PDMA_MAIN0      |
| 0x4400-0x44ff      | DMSS         | PDMA_MAIN1      |
| 0x4500-0x45ff      | DMSS         | PDMA_MCASP      |
| tblr 0x4600-0x46ff | DMSS         | CPSW2           |
| 0x4700-0x47ff      | DMSS         | CSI             |
| 0x4800-0x74ff      | DMSS         | Reserved        |
| 0x7500-0x7506      | DMSS         | SAUL0           |

#### **4.5.2 Peripheral DMA (PDMA)**

This section contains the integration details for the PDMA module on this device. For Further information, see the Peripheral DMA (PDMA) section of the Data Movement Architecture chapter

##### **4.5.2.1 PDMA Unsupported Features**

The following features are not supported on this family of devices:

- Dynamic Transfer Requests
- Cross-Channel Triggering

## 4.6 Audio

### 4.6.1 Multichannel Audio Serial Port (MCASP)

This section contains the integration details for the McASP module on this device. For Further information, see the Multichannel Audio Serial Port (MCASP) section of the Peripherals chapter

#### 4.6.1.1 MCASP Unsupported Features

The following features are not supported on this family of devices:

- Muting output (AMUTE)
- Muting input (AMUTEIN)
- Instances may not support all pin options. See device specific datasheet for details on which McASP instance support which pins

#### 4.6.1.2 Module Allocations

**Table 4-42. MCASP Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| MCASP0   |        |     | ✓    |
| MCASP1   |        |     | ✓    |
| MCASP2   |        |     | ✓    |

#### 4.6.1.3 Resets, Interrupts, and Clocks

**Table 4-43. MCASP Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain     | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|-------------------|-------|---------|--------------|--------------|
| MCASP0          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_MCASP_0 | 17    | OFF     | YES          | LPSC_MAIN_IP |
| MCASP1          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_MCASP_1 | 18    | OFF     | YES          | LPSC_MAIN_IP |
| MCASP2          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_MCASP_2 | 19    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-44. MCASP Resets**

| Module Instance | Source     | Description  |
|-----------------|------------|--------------|
| MCASP0          | PSC0_PSC_0 | MCASP0 reset |
| MCASP1          | PSC0_PSC_0 | MCASP1 reset |
| MCASP2          | PSC0_PSC_0 | MCASP2 reset |

**Table 4-45. MCASP Hardware Requests**

| Module Instance | Module Interrupt Signal    | Destination Interrupt Input        | Destination     | Description              | Type  |
|-----------------|----------------------------|------------------------------------|-----------------|--------------------------|-------|
| MCASP0          | MCASP0_rec_dma_event_req_0 | PDMA2_mcasp_main_0_rx_IN_0         | PDMA2           | MCASP0 interrupt request | pulse |
| MCASP0          | MCASP0_rec_intr_pend_0     | GICSS0_spi_IN_267                  | GICSS0          | MCASP0 interrupt request | level |
| MCASP0          | MCASP0_rec_intr_pend_0     | ICSSM0_COMMON_0_pr1_slv_intr_IN_22 | ICSSM0_COMMON_0 | MCASP0 interrupt request | level |

**Table 4-45. MCASP Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal     | Destination Interrupt Input        | Destination     | Description              | Type  |
|-----------------|-----------------------------|------------------------------------|-----------------|--------------------------|-------|
| MCASP0          | MCASP0_rec_intr_pernd_0     | TIFS0_nvic_IN_116                  | TIFS0           | MCASP0 interrupt request | level |
| MCASP0          | MCASP0_rec_intr_pernd_0     | HSM0_nvic_IN_116                   | HSM0            | MCASP0 interrupt request | level |
| MCASP0          | MCASP0_xmit_dma_event_req_0 | PDMA2_mcasp_main_0_tx_IN_0         | PDMA2           | MCASP0 interrupt request | pulse |
| MCASP0          | MCASP0_xmit_intr_pernd_0    | GICSS0_spi_IN_268                  | GICSS0          | MCASP0 interrupt request | level |
| MCASP0          | MCASP0_xmit_intr_pernd_0    | ICSSM0_COMMON_0_pr1_slv_intr_IN_23 | ICSSM0_COMMON_0 | MCASP0 interrupt request | level |
| MCASP0          | MCASP0_xmit_intr_pernd_0    | TIFS0_nvic_IN_113                  | TIFS0           | MCASP0 interrupt request | level |
| MCASP0          | MCASP0_xmit_intr_pernd_0    | HSM0_nvic_IN_113                   | HSM0            | MCASP0 interrupt request | level |
| MCASP1          | MCASP1_rec_dma_event_req_0  | PDMA2_mcasp_main_1_rx_IN_0         | PDMA2           | MCASP1 interrupt request | pulse |
| MCASP1          | MCASP1_rec_intr_pernd_0     | GICSS0_spi_IN_269                  | GICSS0          | MCASP1 interrupt request | level |
| MCASP1          | MCASP1_rec_intr_pernd_0     | ICSSM0_COMMON_0_pr1_slv_intr_IN_2  | ICSSM0_COMMON_0 | MCASP1 interrupt request | level |
| MCASP1          | MCASP1_rec_intr_pernd_0     | TIFS0_nvic_IN_117                  | TIFS0           | MCASP1 interrupt request | level |
| MCASP1          | MCASP1_rec_intr_pernd_0     | HSM0_nvic_IN_117                   | HSM0            | MCASP1 interrupt request | level |
| MCASP1          | MCASP1_xmit_dma_event_req_0 | PDMA2_mcasp_main_1_tx_IN_0         | PDMA2           | MCASP1 interrupt request | pulse |
| MCASP1          | MCASP1_xmit_intr_pernd_0    | GICSS0_spi_IN_270                  | GICSS0          | MCASP1 interrupt request | level |
| MCASP1          | MCASP1_xmit_intr_pernd_0    | ICSSM0_COMMON_0_pr1_slv_intr_IN_1  | ICSSM0_COMMON_0 | MCASP1 interrupt request | level |
| MCASP1          | MCASP1_xmit_intr_pernd_0    | TIFS0_nvic_IN_114                  | TIFS0           | MCASP1 interrupt request | level |
| MCASP1          | MCASP1_xmit_intr_pernd_0    | HSM0_nvic_IN_114                   | HSM0            | MCASP1 interrupt request | level |
| MCASP2          | MCASP2_rec_dma_event_req_0  | PDMA2_mcasp_main_2_rx_IN_0         | PDMA2           | MCASP2 interrupt request | pulse |
| MCASP2          | MCASP2_rec_intr_pernd_0     | GICSS0_spi_IN_271                  | GICSS0          | MCASP2 interrupt request | level |
| MCASP2          | MCASP2_rec_intr_pernd_0     | ICSSM0_COMMON_0_pr1_slv_intr_IN_28 | ICSSM0_COMMON_0 | MCASP2 interrupt request | level |
| MCASP2          | MCASP2_rec_intr_pernd_0     | TIFS0_nvic_IN_118                  | TIFS0           | MCASP2 interrupt request | level |

Table 4-45. MCASP Hardware Requests (continued)

| Module Instance | Module Interrupt Signal     | Destination Interrupt Input        | Destination     | Description              | Type  |
|-----------------|-----------------------------|------------------------------------|-----------------|--------------------------|-------|
| MCASP2          | MCASP2_rec_intr_pend_0      | HSM0_nvic_IN_118                   | HSM0            | MCASP2 interrupt request | level |
| MCASP2          | MCASP2_xmit_dma_event_req_0 | PDMA2_mcasp_main_2_tx_IN_0         | PDMA2           | MCASP2 interrupt request | pulse |
| MCASP2          | MCASP2_xmit_intr_pend_0     | GICSS0_spi_IN_272                  | GICSS0          | MCASP2 interrupt request | level |
| MCASP2          | MCASP2_xmit_intr_pend_0     | ICSSM0_COMMON_0_pr1_slv_intr_IN_27 | ICSSM0_COMMON_0 | MCASP2 interrupt request | level |
| MCASP2          | MCASP2_xmit_intr_pend_0     | TIFS0_nvic_IN_115                  | TIFS0           | MCASP2 interrupt request | level |
| MCASP2          | MCASP2_xmit_intr_pend_0     | HSM0_nvic_IN_115                   | HSM0            | MCASP2 interrupt request | level |

Table 4-46. MCASP Clocks

| Module Instance | Module Clock Input | Source Clock            | Source Control Register | Description            |
|-----------------|--------------------|-------------------------|-------------------------|------------------------|
| MCASP0          | AUX_CLK            | MAIN_PLL2_HSDIV8_CLKOUT | MCASP0_CLKSEL[0:0]      |                        |
|                 |                    | MAIN_PLL1_HSDIV6_CLKOUT |                         |                        |
|                 | MCASP_AHCLKR_PIN   | EXT_REFCLK1             | MCASP0_AHCLKSEL[1:0]    |                        |
|                 |                    | HFOSC0_CLKOUT           |                         |                        |
|                 |                    | AUDIO_EXT_REFCLK0       |                         |                        |
|                 |                    | AUDIO_EXT_REFCLK1       |                         |                        |
|                 | MCASP_AHCLKX_PIN   | EXT_REFCLK1             | MCASP0_AHCLKSEL[9:8]    |                        |
|                 |                    | HFOSC0_CLKOUT           |                         |                        |
|                 |                    | AUDIO_EXT_REFCLK0       |                         |                        |
|                 |                    | AUDIO_EXT_REFCLK1       |                         |                        |
|                 | ICLK               | MAIN_SYSCLK0/2          |                         | MCASP0 Interface Clock |

**Table 4-46. MCASP Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description            |  |
|-----------------|--------------------|-----------------------------|-------------------------|------------------------|--|
| MCASP1          | AUX_CLK            | MAIN_PLL2_HSDIV8_CL<br>KOUT | MCASP1_CLKSEL[0:0]      |                        |  |
|                 |                    | MAIN_PLL1_HSDIV6_CL<br>KOUT |                         |                        |  |
|                 | MCASP_AHCLKR_PIN   | EXT_REFCLK1                 | MCASP1_AHCLKSEL[1:0]    |                        |  |
|                 |                    | HFOSC0_CLKOUT               |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK0           |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK1           |                         |                        |  |
|                 | MCASP_AHCLKX_PIN   | EXT_REFCLK1                 | MCASP1_AHCLKSEL[9:8]    |                        |  |
|                 |                    | HFOSC0_CLKOUT               |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK0           |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK1           |                         |                        |  |
|                 | ICLK               | MAIN_SYSCLK0/2              |                         | MCASP1 Interface Clock |  |
| MCASP2          | AUX_CLK            | MAIN_PLL2_HSDIV8_CL<br>KOUT | MCASP2_CLKSEL[0:0]      |                        |  |
|                 |                    | MAIN_PLL1_HSDIV6_CL<br>KOUT |                         |                        |  |
|                 | MCASP_AHCLKR_PIN   | EXT_REFCLK1                 | MCASP2_AHCLKSEL[1:0]    |                        |  |
|                 |                    | HFOSC0_CLKOUT               |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK0           |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK1           |                         |                        |  |
|                 | MCASP_AHCLKX_PIN   | EXT_REFCLK1                 | MCASP2_AHCLKSEL[9:8]    |                        |  |
|                 |                    | HFOSC0_CLKOUT               |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK0           |                         |                        |  |
|                 |                    | AUDIO_EXT_REFCLK1           |                         |                        |  |
|                 | ICLK               | MAIN_SYSCLK0/2              |                         | MCASP2 Interface Clock |  |

## 4.7 General Connectivity

### 4.7.1 General Purpose Input/Output (GPIO)

This section contains the integration details for the GPIO modules on this device. For further information, see the General Purpose Interface section of the Peripherals chapter

#### 4.7.1.1 GPIO Unsupported Features

The following features are not supported on this family of devices:

- The following apply to MCU\_GPIO0:
  - MCU\_GPIO0\_[143:24] are not pinned out.
  - Interrupts [143:24] are not pinned out.
  - Bank Interrupts [8:2] are not pinned out.
- The following apply to GPIO0:
  - GPIO0\_[143:92] are not pinned out.
  - Interrupts [143:92] are not pinned out.
  - Bank Interrupts [8:6] are not pinned out.
- The following apply to GPIO1:
  - GPIO1\_[143:72] are not pinned out.
  - Interrupts [143:72] are not pinned out.
  - Bank Interrupts [8:5] are not pinned out.

#### 4.7.1.2 Module Allocation

**Table 4-47. GPIO Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| GPIO0     |        |     | ✓    |
| GPIO1     |        |     | ✓    |
| MCU_GPIO0 |        | ✓   |      |

#### 4.7.1.3 Resets, Interrupts, and Clocks

**Table 4-48. GPIO Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain    | Module Domain      | Index | Default | Controllable | dependences |
|-----------------|------------------------|-----------------|--------------------|-------|---------|--------------|-------------|
| GPIO0           | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| GPIO1           | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| MCU_GPIO0       | WKUP_PSC0              | GP_CORE_CTL_MCU | LPSC MCU ALWAYSON  | 0     | ON      | NO           | NONE        |

**Table 4-49. GPIO Resets**

| Module Instance | Source     | Description     |
|-----------------|------------|-----------------|
| GPIO0           | PSC0_PSC_0 | GPIO0 reset     |
| GPIO1           | PSC0_PSC_0 | GPIO1 reset     |
| MCU_GPIO0       | WKUP_PSC0  | MCU_GPIO0 reset |

**Table 4-50. GPIO Hardware Requests**

| Module Instance | Module Interrupt Signal   | Destination Interrupt Input                                     | Destination                | Description                 | Type  |
|-----------------|---------------------------|-----------------------------------------------------------------|----------------------------|-----------------------------|-------|
| GPIO0           | GPIO0_gpio_[143:0]        | MAIN_GPIOMUX_IN_TROUTER0_in_IN_[8:9:0]                          | MAIN_GPIOMUX_IN_TROUTER0   | GPIO0 interrupt request     | pulse |
| GPIO0           | GPIO0_gpio_[143:0]        | MAIN_GPIOMUX_IN_TROUTER0_in_IN_[177:176]                        | MAIN_GPIOMUX_IN_TROUTER0   | GPIO0 interrupt request     | pulse |
| GPIO0           | GPIO0_gpio_bank_[8:0]     | MAIN_GPIOMUX_IN_TROUTER0_in_IN_[195:190]                        | MAIN_GPIOMUX_IN_TROUTER0   | GPIO0 interrupt request     | pulse |
| GPIO0           | GPIO0_gpio_bank_[8:0]     | R5FSS0_CORE0_intr_IN_56                                         | R5FSS0_CORE0               | GPIO0 interrupt request     | pulse |
| GPIO0           | GPIO0_gpio_bank_[8:0]     | R5FSS0_CORE0_intr_IN_57                                         | R5FSS0_CORE0               | GPIO0 interrupt request     | pulse |
| GPIO1           | GPIO1_gpio_[143:0]        | MAIN_GPIOMUX_IN_TROUTER0_in_IN_[161:90]                         | MAIN_GPIOMUX_IN_TROUTER0   | GPIO1 interrupt request     | pulse |
| GPIO1           | GPIO1_gpio_bank_[8:0]     | MAIN_GPIOMUX_IN_TROUTER0_in_IN_[184:180]                        | MAIN_GPIOMUX_IN_TROUTER0   | GPIO1 interrupt request     | pulse |
| MCU_GPIO0       | MCU_GPIO0_gpio_[143:0]    | WKUP_MCU_GPIOMUX_INROUTER0_in_IN_[23:0]                         | WKUP_MCU_GPIOMUX_INROUTER0 | MCU_GPIO0 interrupt request | pulse |
| MCU_GPIO0       | MCU_GPIO0_gpio_bank_[8:0] | WKUP_MCU_GPIOMUX_INROUTER0_in_IN_[31:30]                        | WKUP_MCU_GPIOMUX_INROUTER0 | MCU_GPIO0 interrupt request | pulse |
| MCU_GPIO0       | MCU_GPIO0_gpio_lvl_0      | R5FSS0_CORE0_intr_IN_18                                         | R5FSS0_CORE0               | MCU_GPIO0 interrupt request | level |
| MCU_GPIO0       | MCU_GPIO0_gpio_lvl_0      | WKUP_DEEPSLEEP_SOURCES0_Isam62_dm_wakeup_deepsleep_sources_IN_2 | WKUP_DEEPSLEEP_SOURCES0    | MCU_GPIO0 interrupt request | level |

**Table 4-51. A53SS Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                              |
|-----------------|--------------------|----------------|-------------------------|------------------------------------------|
| GPIO0           | FICLK              | MAIN_SYSCLK0/4 |                         | GPIO0 Functional and Interface Clock     |
| GPIO1           | FICLK              | MAIN_SYSCLK0/4 |                         | GPIO1 Functional and Interface Clock     |
| MCU_GPIO0       | FICLK              | MCU_SYSCLK0/4  | MCU_GPIO_CLKSEL[1:0]    | MCU_GPIO0 Functional and Interface Clock |
|                 |                    | LFOSC0_CLKOUT  | MCU_GPIO_CLKSEL[1:0]    |                                          |
|                 |                    | CLK_32K        | MCU_GPIO_CLKSEL[1:0]    |                                          |
|                 |                    | CLK_12M_RC     | MCU_GPIO_CLKSEL[1:0]    |                                          |

#### 4.7.1.4 GPIO0 Register/Pin Mapping

| Signal   | Bank   | GPIO0_*_DATA | Register Bit | Signal    | Bank   | GPIO0_*_DATA | Register Bit | Signal    | Bank   | GPIO0_*_DATA | Register Bit |
|----------|--------|--------------|--------------|-----------|--------|--------------|--------------|-----------|--------|--------------|--------------|
| GPIO0_0  | Bank 0 | GPIO0_*_DATA | 0            | GPIO0_3_2 | Bank 2 | GPIO0_*_DATA | 0            | GPIO0_6_4 | Bank 4 | GPIO0_*_DATA | 0            |
| GPIO0_1  | Bank 0 | GPIO0_*_DATA | 1            | GPIO0_3_3 | Bank 2 | GPIO0_*_DATA | 1            | GPIO0_6_5 | Bank 4 | GPIO0_*_DATA | 1            |
| GPIO0_2  | Bank 0 | GPIO0_*_DATA | 2            | GPIO0_3_4 | Bank 2 | GPIO0_*_DATA | 2            | GPIO0_6_6 | Bank 4 | GPIO0_*_DATA | 2            |
| GPIO0_3  | Bank 0 | GPIO0_*_DATA | 3            | GPIO0_3_5 | Bank 2 | GPIO0_*_DATA | 3            | GPIO0_6_7 | Bank 4 | GPIO0_*_DATA | 3            |
| GPIO0_4  | Bank 0 | GPIO0_*_DATA | 4            | GPIO0_3_6 | Bank 2 | GPIO0_*_DATA | 4            | GPIO0_6_8 | Bank 4 | GPIO0_*_DATA | 4            |
| GPIO0_5  | Bank 0 | GPIO0_*_DATA | 5            | GPIO0_3_7 | Bank 2 | GPIO0_*_DATA | 5            | GPIO0_6_9 | Bank 4 | GPIO0_*_DATA | 5            |
| GPIO0_6  | Bank 0 | GPIO0_*_DATA | 6            | GPIO0_3_8 | Bank 2 | GPIO0_*_DATA | 6            | GPIO0_7_0 | Bank 4 | GPIO0_*_DATA | 6            |
| GPIO0_7  | Bank 0 | GPIO0_*_DATA | 7            | GPIO0_3_9 | Bank 2 | GPIO0_*_DATA | 7            | GPIO0_7_1 | Bank 4 | GPIO0_*_DATA | 7            |
| GPIO0_8  | Bank 0 | GPIO0_*_DATA | 8            | GPIO0_4_0 | Bank 2 | GPIO0_*_DATA | 8            | GPIO0_7_2 | Bank 4 | GPIO0_*_DATA | 8            |
| GPIO0_9  | Bank 0 | GPIO0_*_DATA | 9            | GPIO0_4_1 | Bank 2 | GPIO0_*_DATA | 9            | GPIO0_7_3 | Bank 4 | GPIO0_*_DATA | 9            |
| GPIO0_10 | Bank 0 | GPIO0_*_DATA | 10           | GPIO0_4_2 | Bank 2 | GPIO0_*_DATA | 10           | GPIO0_7_4 | Bank 4 | GPIO0_*_DATA | 10           |
| GPIO0_11 | Bank 0 | GPIO0_*_DATA | 11           | GPIO0_4_3 | Bank 2 | GPIO0_*_DATA | 11           | GPIO0_7_5 | Bank 4 | GPIO0_*_DATA | 11           |
| GPIO0_12 | Bank 0 | GPIO0_*_DATA | 12           | GPIO0_4_4 | Bank 2 | GPIO0_*_DATA | 12           | GPIO0_7_6 | Bank 4 | GPIO0_*_DATA | 12           |
| GPIO0_13 | Bank 0 | GPIO0_*_DATA | 13           | GPIO0_4_5 | Bank 2 | GPIO0_*_DATA | 13           | GPIO0_7_7 | Bank 4 | GPIO0_*_DATA | 13           |
| GPIO0_14 | Bank 0 | GPIO0_*_DATA | 14           | GPIO0_4_6 | Bank 2 | GPIO0_*_DATA | 14           | GPIO0_7_8 | Bank 4 | GPIO0_*_DATA | 14           |
| GPIO0_15 | Bank 0 | GPIO0_*_DATA | 15           | GPIO0_4_7 | Bank 2 | GPIO0_*_DATA | 15           | GPIO0_7_9 | Bank 4 | GPIO0_*_DATA | 15           |
| GPIO0_16 | Bank 1 | GPIO0_*_DATA | 16           | GPIO0_4_8 | Bank 3 | GPIO0_*_DATA | 16           | GPIO0_8_0 | Bank 5 | GPIO0_*_DATA | 16           |
| GPIO0_17 | Bank 1 | GPIO0_*_DATA | 17           | GPIO0_4_9 | Bank 3 | GPIO0_*_DATA | 17           | GPIO0_8_1 | Bank 5 | GPIO0_*_DATA | 17           |
| GPIO0_18 | Bank 1 | GPIO0_*_DATA | 18           | GPIO0_5_0 | Bank 3 | GPIO0_*_DATA | 18           | GPIO0_8_2 | Bank 5 | GPIO0_*_DATA | 18           |
| GPIO0_19 | Bank 1 | GPIO0_*_DATA | 19           | GPIO0_5_1 | Bank 3 | GPIO0_*_DATA | 19           | GPIO0_8_3 | Bank 5 | GPIO0_*_DATA | 19           |
| GPIO0_20 | Bank 1 | GPIO0_*_DATA | 20           | GPIO0_5_2 | Bank 3 | GPIO0_*_DATA | 20           | GPIO0_8_4 | Bank 5 | GPIO0_*_DATA | 20           |

| Signal    | Bank   | GPIO0_*_DATA | Register Bit | Signal    | Bank   | GPIO0_*_DATA | Register Bit | Signal    | Bank   | GPIO0_*_DATA | Register Bit |
|-----------|--------|--------------|--------------|-----------|--------|--------------|--------------|-----------|--------|--------------|--------------|
| GPIO0_2_1 | Bank 1 | GPIO0_*_DATA | 21           | GPIO0_5_3 | Bank 3 | GPIO0_*_DATA | 21           | GPIO0_8_5 | Bank 5 | GPIO0_*_DATA | 21           |
| GPIO0_2_2 | Bank 1 | GPIO0_*_DATA | 22           | GPIO0_5_4 | Bank 3 | GPIO0_*_DATA | 22           | GPIO0_8_6 | Bank 5 | GPIO0_*_DATA | 22           |
| GPIO0_2_3 | Bank 1 | GPIO0_*_DATA | 23           | GPIO0_5_5 | Bank 3 | GPIO0_*_DATA | 23           | GPIO0_8_7 | Bank 5 | GPIO0_*_DATA | 23           |
| GPIO0_2_4 | Bank 1 | GPIO0_*_DATA | 24           | GPIO0_5_6 | Bank 3 | GPIO0_*_DATA | 24           | GPIO0_8_8 | Bank 5 | GPIO0_*_DATA | 24           |
| GPIO0_2_5 | Bank 1 | GPIO0_*_DATA | 25           | GPIO0_5_7 | Bank 3 | GPIO0_*_DATA | 25           | GPIO0_8_9 | Bank 5 | GPIO0_*_DATA | 25           |
| GPIO0_2_6 | Bank 1 | GPIO0_*_DATA | 26           | GPIO0_5_8 | Bank 3 | GPIO0_*_DATA | 26           | GPIO0_9_0 | Bank 5 | GPIO0_*_DATA | 26           |
| GPIO0_2_7 | Bank 1 | GPIO0_*_DATA | 27           | GPIO0_5_9 | Bank 3 | GPIO0_*_DATA | 27           | GPIO0_9_1 | Bank 5 | GPIO0_*_DATA | 27           |
| GPIO0_2_8 | Bank 1 | GPIO0_*_DATA | 28           | GPIO0_6_0 | Bank 3 | GPIO0_*_DATA | 28           |           |        |              |              |
| GPIO0_2_9 | Bank 1 | GPIO0_*_DATA | 29           | GPIO0_6_1 | Bank 3 | GPIO0_*_DATA | 29           |           |        |              |              |
| GPIO0_3_0 | Bank 1 | GPIO0_*_DATA | 30           | GPIO0_6_2 | Bank 3 | GPIO0_*_DATA | 30           |           |        |              |              |
| GPIO0_3_1 | Bank 1 | GPIO0_*_DATA | 31           | GPIO0_6_3 | Bank 3 | GPIO0_*_DATA | 31           |           |        |              |              |

#### 4.7.1.5 GPIO1 Register/Pin Mapping

| Signal  | Bank   | GPIO1_*_DATA | Register Bit | Signal    | Bank   | GPIO1_*_DATA | Register Bit | Signal    | Bank   | GPIO1_*_DATA | Register Bit |
|---------|--------|--------------|--------------|-----------|--------|--------------|--------------|-----------|--------|--------------|--------------|
| GPIO1_0 | Bank 0 | GPIO1_*_DATA | 0            | GPIO1_1_6 | Bank 1 | GPIO1_*_DATA | 16           | GPIO1_4_8 | Bank 3 | GPIO1_*_DATA | 16           |
| GPIO1_1 | Bank 0 | GPIO1_*_DATA | 1            | GPIO1_1_7 | Bank 1 | GPIO1_*_DATA | 17           | GPIO1_4_9 | Bank 3 | GPIO1_*_DATA | 17           |
| GPIO1_2 | Bank 0 | GPIO1_*_DATA | 2            | GPIO1_1_8 | Bank 1 | GPIO1_*_DATA | 18           | GPIO1_5_0 | Bank 3 | GPIO1_*_DATA | 18           |
| GPIO1_3 | Bank 0 | GPIO1_*_DATA | 3            | GPIO1_1_9 | Bank 1 | GPIO1_*_DATA | 19           | GPIO1_5_1 | Bank 3 | GPIO1_*_DATA | 19           |
| GPIO1_4 | Bank 0 | GPIO1_*_DATA | 4            | GPIO1_2_0 | Bank 1 | GPIO1_*_DATA | 20           |           |        |              |              |
| GPIO1_5 | Bank 0 | GPIO1_*_DATA | 5            | GPIO1_2_1 | Bank 1 | GPIO1_*_DATA | 21           |           |        |              |              |
| GPIO1_6 | Bank 0 | GPIO1_*_DATA | 6            | GPIO1_2_2 | Bank 1 | GPIO1_*_DATA | 22           |           |        |              |              |
| GPIO1_7 | Bank 0 | GPIO1_*_DATA | 7            | GPIO1_2_3 | Bank 1 | GPIO1_*_DATA | 23           |           |        |              |              |

| Signal   | Bank   | GPIO1_*_DATA | Register Bit | Signal   | Bank   | GPIO1_*_DATA | Register Bit | Signal | Bank | GPIO1_*_DATA | Register Bit |
|----------|--------|--------------|--------------|----------|--------|--------------|--------------|--------|------|--------------|--------------|
| GPIO1_8  | Bank 0 | GPIO1_*_DATA | 8            | GPIO1_24 | Bank 1 | GPIO1_*_DATA | 24           |        |      |              |              |
| GPIO1_9  | Bank 0 | GPIO1_*_DATA | 9            | GPIO1_25 | Bank 1 | GPIO1_*_DATA | 25           |        |      |              |              |
| GPIO1_10 | Bank 0 | GPIO1_*_DATA | 10           | GPIO1_26 | Bank 1 | GPIO1_*_DATA | 26           |        |      |              |              |
| GPIO1_11 | Bank 0 | GPIO1_*_DATA | 11           | GPIO1_27 | Bank 1 | GPIO1_*_DATA | 27           |        |      |              |              |
| GPIO1_12 | Bank 0 | GPIO1_*_DATA | 12           | GPIO1_28 | Bank 1 | GPIO1_*_DATA | 28           |        |      |              |              |
| GPIO1_13 | Bank 0 | GPIO1_*_DATA | 13           | GPIO1_29 | Bank 1 | GPIO1_*_DATA | 29           |        |      |              |              |
| GPIO1_14 | Bank 0 | GPIO1_*_DATA | 14           | GPIO1_30 | Bank 1 | GPIO1_*_DATA | 30           |        |      |              |              |
| GPIO1_15 | Bank 0 | GPIO1_*_DATA | 15           | GPIO1_31 | Bank 1 | GPIO1_*_DATA | 31           |        |      |              |              |

#### 4.7.1.6 MCU\_GPIO0 Register/Pin Mapping

| Signal       | Bank   | MCU_GPIO0_*_DATA | Register Bit | Signal       | Bank   | GPIO0_*_DATA     | Register Bit |
|--------------|--------|------------------|--------------|--------------|--------|------------------|--------------|
| MCU_GPIO0_0  | Bank 0 | MCU_GPIO0_*_DATA | 0            | MCU_GPIO0_16 | Bank 1 | MCU_GPIO0_*_DATA | 16           |
| MCU_GPIO0_1  | Bank 0 | MCU_GPIO0_*_DATA | 1            | MCU_GPIO0_17 | Bank 1 | MCU_GPIO0_*_DATA | 17           |
| MCU_GPIO0_2  | Bank 0 | MCU_GPIO0_*_DATA | 2            | MCU_GPIO0_18 | Bank 1 | MCU_GPIO0_*_DATA | 18           |
| MCU_GPIO0_3  | Bank 0 | MCU_GPIO0_*_DATA | 3            | MCU_GPIO0_19 | Bank 1 | MCU_GPIO0_*_DATA | 19           |
| MCU_GPIO0_4  | Bank 0 | MCU_GPIO0_*_DATA | 4            | MCU_GPIO0_20 | Bank 1 | MCU_GPIO0_*_DATA | 20           |
| MCU_GPIO0_5  | Bank 0 | MCU_GPIO0_*_DATA | 5            | MCU_GPIO0_21 | Bank 1 | MCU_GPIO0_*_DATA | 21           |
| MCU_GPIO0_6  | Bank 0 | MCU_GPIO0_*_DATA | 6            | MCU_GPIO0_22 | Bank 1 | MCU_GPIO0_*_DATA | 22           |
| MCU_GPIO0_7  | Bank 0 | MCU_GPIO0_*_DATA | 7            | MCU_GPIO0_23 | Bank 1 | MCU_GPIO0_*_DATA | 23           |
| MCU_GPIO0_8  | Bank 0 | MCU_GPIO0_*_DATA | 8            |              |        |                  |              |
| MCU_GPIO0_9  | Bank 0 | MCU_GPIO0_*_DATA | 9            |              |        |                  |              |
| MCU_GPIO0_10 | Bank 0 | MCU_GPIO0_*_DATA | 10           |              |        |                  |              |

| Signal        | Bank   | MCU_GPIO0_*_DATA | Register Bit | Signal | Bank | GPIO0_*_DATA | Register Bit |
|---------------|--------|------------------|--------------|--------|------|--------------|--------------|
| MCU_GPIO0_1_1 | Bank 0 | MCU_GPIO0_*_DATA | 11           |        |      |              |              |
| MCU_GPIO0_1_2 | Bank 0 | MCU_GPIO0_*_DATA | 12           |        |      |              |              |
| MCU_GPIO0_1_3 | Bank 0 | MCU_GPIO0_*_DATA | 13           |        |      |              |              |
| MCU_GPIO0_1_4 | Bank 0 | MCU_GPIO0_*_DATA | 14           |        |      |              |              |
| MCU_GPIO0_1_5 | Bank 0 | MCU_GPIO0_*_DATA | 15           |        |      |              |              |

#### 4.7.2 Inter-Integrated Circuit (I2C)

This section contains the integration details for the I2C module on this device. For further information, see the Inter-Integrated Circuit (I2C) section of the Peripherals chapter

##### 4.7.2.1 I2C Unsupported Features

The following features are not supported on this family of devices:

- Serial Camera Control Bus (SCCB) Protocol
- DMA Mode
- Full I<sup>2</sup>C electrical compliance for I2C modules using device pins with LVCMOS voltage buffers (Refer to chapter 4 of the device-specific Datasheet for details related to device *Terminal Configuration and Functions*)
- High-speed (3.4-Mbps) operation for I2C modules using device pins with LVCMOS voltage buffers (Refer to chapter 4 of the device-specific Datasheet for details related to device *Terminal Configuration and Functions*)
- Debug suspend mode
- Asynchronous wakeup (via IO Daisy Chain) not supported by Main domain instances.

##### 4.7.2.2 Module Allocations

**Table 4-52. I2C Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| I2C0      |        |     | ✓    |
| I2C1      |        |     | ✓    |
| I2C2      |        |     | ✓    |
| I2C3      |        |     | ✓    |
| MCU_I2C0  |        | ✓   |      |
| WKUP_I2C0 | ✓      |     |      |

##### 4.7.2.3 Resets, Interrupts, and Clocks

**Table 4-53. I2C Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain      | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|--------------------|-------|---------|--------------|------------------------|
| I2C0            | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| I2C1            | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| I2C2            | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| I2C3            | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| MCU_I2C0        | WKUP_PSC0              | PD_M4F       | LPSC MCU COMMON    | 9     | ON      | YES          | LPSC_DM2SAF_E_ISO      |
| WKUP_I2C0       | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE                   |

**Table 4-54. I2C Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| I2C0            | PSC0_PSC_0 | I2C0 reset  |

**Table 4-54. I2C Resets (continued)**

| Module Instance | Source     | Description     |
|-----------------|------------|-----------------|
| I2C1            | PSC0_PSC_0 | I2C1 reset      |
| I2C2            | PSC0_PSC_0 | I2C2 reset      |
| I2C3            | PSC0_PSC_0 | I2C3 reset      |
| MCU_I2C0        | WKUP_PSC0  | MCU_I2C0 reset  |
| WKUP_I2C0       | PSC0_PSC_0 | WKUP_I2C0 reset |

**Table 4-55. I2C Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input        | Destination       | Description            | Type  |
|-----------------|-------------------------|------------------------------------|-------------------|------------------------|-------|
| I2C0            | I2C0_pointrpend_0       | GICSS0_COMMON_0_spi_IN_193         | GICSS0_COMMON_0   | I2C0 interrupt request | level |
| I2C0            | I2C0_pointrpend_0       | R5FSS0_CORE0_intr_IN_193           | R5FSS0_CORE0      | I2C0 interrupt request | level |
| I2C0            | I2C0_pointrpend_0       | MCU_R5FSS0_COR_E0_cpu0_intr_IN_193 | MCU_R5FSS0_COR_E0 | I2C0 interrupt request | level |
| I2C0            | I2C0_pointrpend_0       | C7X256V0_CLEC_gi_c_spi_IN_161      | C7X256V0_CLEC     | I2C0 interrupt request | level |
| I2C0            | I2C0_pointrpend_0       | TIFS0_nvic_IN_97                   | TIFS0             | I2C0 interrupt request | level |
| I2C0            | I2C0_pointrpend_0       | HSM0_nvic_IN_97                    | HSM0              | I2C0 interrupt request | level |
| I2C1            | I2C1_pointrpend_0       | GICSS0_COMMON_0_spi_IN_194         | GICSS0_COMMON_0   | I2C1 interrupt request | level |
| I2C1            | I2C1_pointrpend_0       | R5FSS0_CORE0_intr_IN_194           | R5FSS0_CORE0      | I2C1 interrupt request | level |
| I2C1            | I2C1_pointrpend_0       | MCU_R5FSS0_COR_E0_cpu0_intr_IN_194 | MCU_R5FSS0_COR_E0 | I2C1 interrupt request | level |
| I2C1            | I2C1_pointrpend_0       | C7X256V0_CLEC_gi_c_spi_IN_162      | C7X256V0_CLEC     | I2C1 interrupt request | level |
| I2C1            | I2C1_pointrpend_0       | TIFS0_nvic_IN_98                   | TIFS0             | I2C1 interrupt request | level |
| I2C1            | I2C1_pointrpend_0       | HSM0_nvic_IN_98                    | HSM0              | I2C1 interrupt request | level |
| I2C2            | I2C2_pointrpend_0       | GICSS0_COMMON_0_spi_IN_195         | GICSS0_COMMON_0   | I2C2 interrupt request | level |
| I2C2            | I2C2_pointrpend_0       | R5FSS0_CORE0_intr_IN_195           | R5FSS0_CORE0      | I2C2 interrupt request | level |
| I2C2            | I2C2_pointrpend_0       | MCU_R5FSS0_COR_E0_cpu0_intr_IN_195 | MCU_R5FSS0_COR_E0 | I2C2 interrupt request | level |
| I2C2            | I2C2_pointrpend_0       | C7X256V0_CLEC_gi_c_spi_IN_163      | C7X256V0_CLEC     | I2C2 interrupt request | level |
| I2C2            | I2C2_pointrpend_0       | TIFS0_nvic_IN_99                   | TIFS0             | I2C2 interrupt request | level |
| I2C2            | I2C2_pointrpend_0       | HSM0_nvic_IN_99                    | HSM0              | I2C2 interrupt request | level |
| I2C3            | I2C3_pointrpend_0       | GICSS0_COMMON_0_spi_IN_196         | GICSS0_COMMON_0   | I2C3 interrupt request | level |

Table 4-55. I2C Hardware Requests (continued)

| Module Instance | Module Interrupt Signal    | Destination Interrupt Input                                     | Destination             | Description                 | Type  |
|-----------------|----------------------------|-----------------------------------------------------------------|-------------------------|-----------------------------|-------|
| I2C3            | I2C3_pointrpend_0          | R5FSS0_CORE0_intr_IN_196                                        | R5FSS0_CORE0            | I2C3 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | MCU_R5FSS0_COR_E0_cpu0_intr_IN_196                              | MCU_R5FSS0_COR_E0       | I2C3 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | C7X256V0_CLEC_gi_c_spi_IN_164                                   | C7X256V0_CLEC           | I2C3 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | TIFS0_nvic_IN_100                                               | TIFS0                   | I2C3 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | HSM0_nvic_IN_100                                                | HSM0                    | I2C3 interrupt request      | level |
| MCU_I2C0        | MCU_I2C0_pointrpen_d_0     | GICSS0_COMMON_0_spi_IN_139                                      | GICSS0_COMMON_0         | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpen_d_0     | R5FSS0_CORE0_intr_IN_197                                        | R5FSS0_CORE0            | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpen_d_0     | MCU_R5FSS0_COR_E0_cpu0_intr_IN_197                              | MCU_R5FSS0_COR_E0       | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpen_d_0     | C7X256V0_CLEC_gi_c_spi_IN_107                                   | C7X256V0_CLEC           | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpen_d_0     | TIFS0_nvic_IN_101                                               | TIFS0                   | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpen_d_0     | HSM0_nvic_IN_101                                                | HSM0                    | MCU_I2C0 interrupt request  | level |
| WKUP_I2C0       | WKUP_I2C0_clkstop_wakeup_0 | R5FSS0_CORE0_intr_IN_143                                        | R5FSS0_CORE0            | WKUP_I2C0 interrupt request | level |
| WKUP_I2C0       | WKUP_I2C0_clkstop_wakeup_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_0 | WKUP_DEEPSLEEP_SOURCES0 | WKUP_I2C0 interrupt request | level |
| WKUP_I2C0       | WKUP_I2C0_pointrpend_0     | GICSS0_COMMON_0_spi_IN_197                                      | GICSS0_COMMON_0         | WKUP_I2C0 interrupt request | level |
| WKUP_I2C0       | WKUP_I2C0_pointrpend_0     | R5FSS0_CORE0_intr_IN_190                                        | R5FSS0_CORE0            | WKUP_I2C0 interrupt request | level |
| I2C0            | I2C0_pointrpend_0          | GICSS0_spi_IN_193                                               | GICSS0                  | I2C0 interrupt request      | level |
| I2C0            | I2C0_pointrpend_0          | ICSSM0_COMMON_0_pr1_slv_intr_IN_9                               | ICSSM0_COMMON_0         | I2C0 interrupt request      | level |
| I2C0            | I2C0_pointrpend_0          | R5FSS0_CORE0_intr_IN_193                                        | R5FSS0_CORE0            | I2C0 interrupt request      | level |
| I2C0            | I2C0_pointrpend_0          | TIFS0_nvic_IN_97                                                | TIFS0                   | I2C0 interrupt request      | level |
| I2C0            | I2C0_pointrpend_0          | HSM0_nvic_IN_97                                                 | HSM0                    | I2C0 interrupt request      | level |
| I2C1            | I2C1_pointrpend_0          | GICSS0_spi_IN_194                                               | GICSS0                  | I2C1 interrupt request      | level |
| I2C1            | I2C1_pointrpend_0          | R5FSS0_CORE0_intr_IN_194                                        | R5FSS0_CORE0            | I2C1 interrupt request      | level |
| I2C1            | I2C1_pointrpend_0          | TIFS0_nvic_IN_98                                                | TIFS0                   | I2C1 interrupt request      | level |

**Table 4-55. I2C Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal    | Destination Interrupt Input                                     | Destination             | Description                 | Type  |
|-----------------|----------------------------|-----------------------------------------------------------------|-------------------------|-----------------------------|-------|
| I2C1            | I2C1_pointrpend_0          | HSM0_nvic_IN_98                                                 | HSM0                    | I2C1 interrupt request      | level |
| I2C2            | I2C2_pointrpend_0          | GICSS0_spi_IN_195                                               | GICSS0                  | I2C2 interrupt request      | level |
| I2C2            | I2C2_pointrpend_0          | R5FSS0_CORE0_intr_IN_195                                        | R5FSS0_CORE0            | I2C2 interrupt request      | level |
| I2C2            | I2C2_pointrpend_0          | TIFS0_nvic_IN_99                                                | TIFS0                   | I2C2 interrupt request      | level |
| I2C2            | I2C2_pointrpend_0          | HSM0_nvic_IN_99                                                 | HSM0                    | I2C2 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | GICSS0_spi_IN_196                                               | GICSS0                  | I2C3 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | R5FSS0_CORE0_intr_IN_196                                        | R5FSS0_CORE0            | I2C3 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | TIFS0_nvic_IN_100                                               | TIFS0                   | I2C3 interrupt request      | level |
| I2C3            | I2C3_pointrpend_0          | HSM0_nvic_IN_100                                                | HSM0                    | I2C3 interrupt request      | level |
| MCU_I2C0        | MCU_I2C0_pointrpnd_0       | MCU_M4FSS0_CORE0_nvic_IN_17                                     | MCU_M4FSS0_CORE0        | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpnd_0       | GICSS0_spi_IN_139                                               | GICSS0                  | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpnd_0       | R5FSS0_CORE0_intr_IN_197                                        | R5FSS0_CORE0            | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpnd_0       | TIFS0_nvic_IN_101                                               | TIFS0                   | MCU_I2C0 interrupt request  | level |
| MCU_I2C0        | MCU_I2C0_pointrpnd_0       | HSM0_nvic_IN_101                                                | HSM0                    | MCU_I2C0 interrupt request  | level |
| WKUP_I2C0       | WKUP_I2C0_clkstop_wakeup_0 | R5FSS0_CORE0_intr_IN_143                                        | R5FSS0_CORE0            | WKUP_I2C0 interrupt request | level |
| WKUP_I2C0       | WKUP_I2C0_clkstop_wakeup_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_0 | WKUP_DEEPSLEEP_SOURCES0 | WKUP_I2C0 interrupt request | level |
| WKUP_I2C0       | WKUP_I2C0_pointrpnd_0      | GICSS0_spi_IN_197                                               | GICSS0                  | WKUP_I2C0 interrupt request | level |
| WKUP_I2C0       | WKUP_I2C0_pointrpnd_0      | R5FSS0_CORE0_intr_IN_190                                        | R5FSS0_CORE0            | WKUP_I2C0 interrupt request | level |

**Table 4-56. I2C Clocks**

| Module Instance | Module Clock Input | Source Clock              | Source Control Register | Description           |
|-----------------|--------------------|---------------------------|-------------------------|-----------------------|
| I2C0            | OC_P_CLK           | MAIN_SYSCLK0/4            |                         | I2C0 Interface Clock  |
|                 | SYS_CLK            | MAIN_PLL1_HSDIV0_CLKOUT/2 |                         | I2C0 Functional Clock |
| I2C1            | OC_P_CLK           | MAIN_SYSCLK0/4            |                         | I2C1 Interface Clock  |
|                 | SYS_CLK            | MAIN_PLL1_HSDIV0_CLKOUT/2 |                         | I2C1 Functional Clock |

**Table 4-56. I2C Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                  | Source Control Register | Description                   |
|-----------------|--------------------|-------------------------------|-------------------------|-------------------------------|
| I2C2            | OCP_CLK            | MAIN_SYSCLK0/4                |                         | I2C2 Interface Clock          |
|                 | SYS_CLK            | MAIN_PLL1_HSDIV0_CL<br>KOUT/2 |                         | I2C2 Functional Clock         |
| I2C3            | OCP_CLK            | MAIN_SYSCLK0/4                |                         | I2C3 Interface Clock          |
|                 | SYS_CLK            | MAIN_PLL1_HSDIV0_CL<br>KOUT/2 |                         | I2C3 Functional Clock         |
| MCU_I2C0        | OCP_CLK            | MCU_SYSCLK0/4                 |                         | MCU_I2C0 Interface Clock      |
|                 | SYS_CLK            | MCU_PLL0_HSDIV1_CLK<br>OUT    |                         | MCU_I2C0 Functional<br>Clock  |
| WKUP_I2C0       | OCP_CLK            | DM_CLK/4                      | WKUP_CLKSEL[0:0]        | WKUP_I2C0 Interface<br>Clock  |
|                 | SYS_CLK            | MCU_PLL0_HSDIV1_CLK<br>OUT    |                         | WKUP_I2C0 Functional<br>Clock |

#### 4.7.3 Multichannel Serial Peripheral Interface (MCSPI)

This section contains the integration details for the MCSPI module on this device. For further information, see the Multichannel Serial Peripheral Interface (MCSPI) section of the Peripherals chapter

##### 4.7.3.1 SPI Unsupported Features

The following features are not supported on this family of devices:

- Peripheral mode wakeup.
- Retention During Power Down

##### 4.7.3.2 Module Allocations

**Table 4-57. MCSPI Modules Allocation within Device Domains**

| Instance   | Domain |     |      |
|------------|--------|-----|------|
|            | WKUP   | MCU | Main |
| MCSPI0     |        |     | ✓    |
| MCSPI1     |        |     | ✓    |
| MCSPI2     |        |     | ✓    |
| MCU_MCSPI0 |        | ✓   |      |
| MCU_MCSPI1 |        | ✓   |      |

##### 4.7.3.3 Resets, Interrupts, and Clocks

**Table 4-58. MCSPI Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain   | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|-----------------|-------|---------|--------------|------------------------|
| MCSPI0          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP    | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| MCSPI1          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP    | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| MCSPI2          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP    | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| MCU_MCSPI0      | WKUP_PSC0              | PD_M4F       | LPSC MCU COMMON | 9     | ON      | YES          | LPSC_DM2SAFE_ISO       |
| MCU_MCSPI1      | WKUP_PSC0              | PD_M4F       | LPSC MCU COMMON | 9     | ON      | YES          | LPSC_DM2SAFE_ISO       |

**Table 4-59. MCSPI Resets**

| Module Instance | Source     | Description      |
|-----------------|------------|------------------|
| MCSPI0          | PSC0_PSC_0 | MCSPI0 reset     |
| MCSPI1          | PSC0_PSC_0 | MCSPI1 reset     |
| MCSPI2          | PSC0_PSC_0 | MCSPI2 reset     |
| MCU_MCSPI0      | WKUP_PSC0  | MCU_MCSPI0 reset |
| MCU_MCSPI1      | WKUP_PSC0  | MCU_MCSPI1 reset |

**Table 4-60. MCSPI Hardware Requests**

| Module Instance | Module Interrupt Signal      | Destination Interrupt Input  | Destination      | Description                  | Type  |
|-----------------|------------------------------|------------------------------|------------------|------------------------------|-------|
| MCSPI0          | MCSPI0_dma_read_event_[3:0]  | PDMA0_spi_main_0_rx_IN_[3:0] | PDMA0            | MCSPI0 interrupt request     | pulse |
| MCSPI0          | MCSPI0_dma_write_event_[3:0] | PDMA0_spi_main_0_tx_IN_[3:0] | PDMA0            | MCSPI0 interrupt request     | pulse |
| MCSPI0          | MCSPI0_intr_spi_0            | GICSS0_spi_IN_204            | GICSS0           | MCSPI0 interrupt request     | level |
| MCSPI0          | MCSPI0_intr_spi_0            | ICSSM0_pr1_slv_intr_IN_12    | ICSSM0           | MCSPI0 interrupt request     | level |
| MCSPI0          | MCSPI0_intr_spi_0            | R5FSS0_CORE0_intr_IN_204     | R5FSS0_CORE0     | MCSPI0 interrupt request     | level |
| MCSPI0          | MCSPI0_intr_spi_0            | TIFS0_nvic_IN_84             | TIFS0            | MCSPI0 interrupt request     | level |
| MCSPI0          | MCSPI0_intr_spi_0            | HSM0_nvic_IN_84              | HSM0             | MCSPI0 interrupt request     | level |
| MCSPI1          | MCSPI1_dma_read_event_[3:0]  | PDMA0_spi_main_1_rx_IN_[3:0] | PDMA0            | MCSPI1 interrupt request     | pulse |
| MCSPI1          | MCSPI1_dma_write_event_[3:0] | PDMA0_spi_main_1_tx_IN_[3:0] | PDMA0            | MCSPI1 interrupt request     | pulse |
| MCSPI1          | MCSPI1_intr_spi_0            | GICSS0_spi_IN_205            | GICSS0           | MCSPI1 interrupt request     | level |
| MCSPI1          | MCSPI1_intr_spi_0            | ICSSM0_pr1_slv_intr_IN_15    | ICSSM0           | MCSPI1 interrupt request     | level |
| MCSPI1          | MCSPI1_intr_spi_0            | R5FSS0_CORE0_intr_IN_205     | R5FSS0_CORE0     | MCSPI1 interrupt request     | level |
| MCSPI1          | MCSPI1_intr_spi_0            | TIFS0_nvic_IN_87             | TIFS0            | MCSPI1 interrupt request     | level |
| MCSPI1          | MCSPI1_intr_spi_0            | HSM0_nvic_IN_87              | HSM0             | MCSPI1 interrupt request     | level |
| MCSPI2          | MCSPI2_dma_read_event_[3:0]  | PDMA0_spi_main_2_rx_IN_[3:0] | PDMA0            | MCSPI2 interrupt request     | pulse |
| MCSPI2          | MCSPI2_dma_write_event_[3:0] | PDMA0_spi_main_2_tx_IN_[3:0] | PDMA0            | MCSPI2 interrupt request     | pulse |
| MCSPI2          | MCSPI2_intr_spi_0            | GICSS0_spi_IN_206            | GICSS0           | MCSPI2 interrupt request     | level |
| MCSPI2          | MCSPI2_intr_spi_0            | R5FSS0_CORE0_intr_IN_206     | R5FSS0_CORE0     | MCSPI2 interrupt request     | level |
| MCSPI2          | MCSPI2_intr_spi_0            | TIFS0_nvic_IN_88             | TIFS0            | MCSPI2 interrupt request     | level |
| MCSPI2          | MCSPI2_intr_spi_0            | HSM0_nvic_IN_88              | HSM0             | MCSPI2 interrupt request     | level |
| MCU_MCSPI0      | MCU_MCSPI0_intr_spi_0        | MCU_M4FSS0_CORE0_nvic_IN_22  | MCU_M4FSS0_CORE0 | MCU_MCSPI0 interrupt request | level |

**Table 4-60. MCSPI Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination      | Description                  | Type  |
|-----------------|-------------------------|-----------------------------|------------------|------------------------------|-------|
| MCU_MCSPI0      | MCU_MCSPI0_intr_s_pi_0  | GICSS0_spi_IN_208           | GICSS0           | MCU_MCSPI0 interrupt request | level |
| MCU_MCSPI0      | MCU_MCSPI0_intr_s_pi_0  | R5FSS0_CORE0_intr_IN_207    | R5FSS0_CORE0     | MCU_MCSPI0 interrupt request | level |
| MCU_MCSPI0      | MCU_MCSPI0_intr_s_pi_0  | TIFS0_nvic_IN_85            | TIFS0            | MCU_MCSPI0 interrupt request | level |
| MCU_MCSPI0      | MCU_MCSPI0_intr_s_pi_0  | HSM0_nvic_IN_85             | HSM0             | MCU_MCSPI0 interrupt request | level |
| MCU_MCSPI1      | MCU_MCSPI1_intr_s_pi_0  | MCU_M4FSS0_CORE0_nvic_IN_23 | MCU_M4FSS0_CORE0 | MCU_MCSPI1 interrupt request | level |
| MCU_MCSPI1      | MCU_MCSPI1_intr_s_pi_0  | GICSS0_spi_IN_209           | GICSS0           | MCU_MCSPI1 interrupt request | level |
| MCU_MCSPI1      | MCU_MCSPI1_intr_s_pi_0  | R5FSS0_CORE0_intr_IN_208    | R5FSS0_CORE0     | MCU_MCSPI1 interrupt request | level |
| MCU_MCSPI1      | MCU_MCSPI1_intr_s_pi_0  | TIFS0_nvic_IN_86            | TIFS0            | MCU_MCSPI1 interrupt request | level |
| MCU_MCSPI1      | MCU_MCSPI1_intr_s_pi_0  | HSM0_nvic_IN_86             | HSM0             | MCU_MCSPI1 interrupt request | level |

**Table 4-61. MCSPI Clocks**

| Module Instance | Module Clock Input | Source Clock    | Source Control Register | Description                 |
|-----------------|--------------------|-----------------|-------------------------|-----------------------------|
| MCSPI0          | FCLK               | MAIN_SYSCLK0/10 |                         | MCSPI0 Functional Clock     |
|                 | ICLK               | MAIN_SYSCLK0/4  |                         | MCSPI0 Interface Clock      |
| MCSPI1          | FCLK               | MAIN_SYSCLK0/10 |                         | MCSPI1 Functional Clock     |
|                 | ICLK               | MAIN_SYSCLK0/4  |                         | MCSPI1 Interface Clock      |
| MCSPI2          | FCLK               | MAIN_SYSCLK0/10 |                         | MCSPI2 Functional Clock     |
|                 | ICLK               | MAIN_SYSCLK0/4  |                         | MCSPI2 Interface Clock      |
| MCU_MCSPI0      | FCLK               | MCU_SYSCLK0/8   |                         | MCU_MCSPI0 Functional Clock |
|                 | ICLK               | MCU_SYSCLK0/2   |                         | MCU_MCSPI0 Interface Clock  |
| MCU_MCSPI1      | FCLK               | MCU_SYSCLK0/8   |                         | MCU_MCSPI1 Functional Clock |
|                 | ICLK               | MCU_SYSCLK0/2   |                         | MCU_MCSPI1 Interface Clock  |

#### 4.7.4 Universal Asynchronous Receiver/Transmitter (UART)

This section contains the integration details for the UART module on this device. For further information, see the Universal Asynchronous Receiver/Transmitter (UART) section of the Processors and Accelerators chapter

##### 4.7.4.1 UART Unsupported Features

The following features are not supported on this family of devices:

- 12Mbps not supported for MCU and WKUP domains.
- Full modem handshaking is not available on all instances. See device datasheet for instances supporting full modem handshaking.
- Synchronous mode - SCLK not pinned out
- ISO7816 Mode
- SCR DMA Mode 2
- Multi-drop Transmission
- 9-bit Mode

##### 4.7.4.2 Module Allocations

**Table 4-62. UART Modules Allocation within Device Domains**

| Instance   | Domain |     |      |
|------------|--------|-----|------|
|            | WKUP   | MCU | Main |
| UART0      |        |     | ✓    |
| UART1      |        |     | ✓    |
| UART2      |        |     | ✓    |
| UART3      |        |     | ✓    |
| UART4      |        |     | ✓    |
| UART5      |        |     | ✓    |
| UART6      |        |     | ✓    |
| MCU_UART0  |        | ✓   |      |
| WKUP_UART0 | ✓      |     |      |

##### 4.7.4.3 Resets, Interrupts, and Clocks

**Table 4-63. UART Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain       | Index | Default | Controllable | dependences                |
|-----------------|------------------------|--------------|---------------------|-------|---------|--------------|----------------------------|
| MCU_UART0       | WKUP_PSC0              | PD_M4F       | LPSC MCU_C<br>OMMON | 9     | ON      | YES          | LPSC_DM2SAF<br>E_ISO       |
| UART0           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP        | 34    | ON      | YES          | LPSC_DM2MAI<br>N_INFRA_ISO |
| UART1           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP        | 34    | ON      | YES          | LPSC_DM2MAI<br>N_INFRA_ISO |
| UART2           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP        | 34    | ON      | YES          | LPSC_DM2MAI<br>N_INFRA_ISO |
| UART3           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP        | 34    | ON      | YES          | LPSC_DM2MAI<br>N_INFRA_ISO |
| UART4           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP        | 34    | ON      | YES          | LPSC_DM2MAI<br>N_INFRA_ISO |

**Table 4-63. UART Integration Attributes (continued)**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain      | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|--------------------|-------|---------|--------------|------------------------|
| UART5           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| UART6           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| WKUP_UART0      | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE                   |

**Table 4-64. UART Clocks**

| Module Instance | Module Clock Input                                  | Source Clock            | Source Control Register | Description                |
|-----------------|-----------------------------------------------------|-------------------------|-------------------------|----------------------------|
| MCU_UART0       | FCLK                                                | MCU_PLL0_HSDIV2_CLKOUT  |                         | MCU_UART0 Functional Clock |
|                 | CLK                                                 | MCU_SYSCLK0/2           |                         | MCU_UART0 Interface Clock  |
| UART0           | FCLK                                                | MAIN_PLL1_HSDIV0_CLKOUT | USART0_CLKSEL[0:0]      | UART0 Functional Clock     |
|                 |                                                     | MAIN_PLL1_HSDIV1_CLKOUT | USART0_CLKSEL[0:0]      |                            |
|                 | CLK                                                 | MAIN_SYSCLK0/4          |                         | UART0 Interface Clock      |
| UART1           | FCLK                                                | MAIN_PLL1_HSDIV0_CLKOUT | USART1_CLKSEL[0:0]      | UART1 Functional Clock     |
|                 |                                                     | MAIN_PLL1_HSDIV1_CLKOUT | USART1_CLKSEL[0:0]      |                            |
|                 | PDMA0_COMMON_0_spi_main_2_tx_IN_[3:0]+A28015:F28136 | MAIN_SYSCLK0/4          |                         | UART1 Interface Clock      |
| UART2           | FCLK                                                | MAIN_PLL1_HSDIV0_CLKOUT | USART2_CLKSEL[0:0]      | UART2 Functional Clock     |
|                 |                                                     | MAIN_PLL1_HSDIV1_CLKOUT | USART2_CLKSEL[0:0]      |                            |
|                 | CLK                                                 | MAIN_SYSCLK0/4          |                         | UART2 Interface Clock      |
| UART3           | FCLK                                                | MAIN_PLL1_HSDIV0_CLKOUT | USART3_CLKSEL[0:0]      | UART3 Functional Clock     |
|                 |                                                     | MAIN_PLL1_HSDIV1_CLKOUT | USART3_CLKSEL[0:0]      |                            |
|                 | CLK                                                 | MAIN_SYSCLK0/4          |                         | UART3 Interface Clock      |
| UART4           | FCLK                                                | MAIN_PLL1_HSDIV0_CLKOUT | USART4_CLKSEL[0:0]      | UART4 Functional Clock     |
|                 |                                                     | MAIN_PLL1_HSDIV1_CLKOUT | USART4_CLKSEL[0:0]      |                            |
|                 | CLK                                                 | MAIN_SYSCLK0/4          |                         | UART4 Interface Clock      |

Table 4-64. UART Clocks (continued)

| Module Instance | Module Clock Input | Source Clock            | Source Control Register | Description                 |
|-----------------|--------------------|-------------------------|-------------------------|-----------------------------|
| UART5           | FCLK               | MAIN_PLL1_HSDIV0_CLKOUT | USART5_CLKSEL[0:0]      | UART5 Functional Clock      |
|                 |                    | MAIN_PLL1_HSDIV1_CLKOUT | USART5_CLKSEL[0:0]      |                             |
|                 | CLK                | MAIN_SYSCLK0/4          |                         | UART5 Interface Clock       |
| UART6           | FCLK               | MAIN_PLL1_HSDIV0_CLKOUT | USART6_CLKSEL[0:0]      | UART6 Functional Clock      |
|                 |                    | MAIN_PLL1_HSDIV1_CLKOUT | USART6_CLKSEL[0:0]      |                             |
|                 | CLK                | MAIN_SYSCLK0/4          |                         | UART6 Interface Clock       |
| WKUP_UART0      | FCLK               | MCU_PLL0_HSDIV2_CLKOUT  |                         | WKUP_UART0 Functional Clock |
|                 | CLK                | DM_CLK/4                | WKUP_CLKSEL[0:0]        | WKUP_UART0 Interface Clock  |

Table 4-65. UART Resets

| Module Instance | Source     | Description      |
|-----------------|------------|------------------|
| MCU_UART0       | WKUP_PSC0  | MCU_UART0 reset  |
| UART0           | PSC0_PSC_0 | UART0 reset      |
| UART1           | PSC0_PSC_0 | UART1 reset      |
| UART2           | PSC0_PSC_0 | UART2 reset      |
| UART3           | PSC0_PSC_0 | UART3 reset      |
| UART4           | PSC0_PSC_0 | UART4 reset      |
| UART5           | PSC0_PSC_0 | UART5 reset      |
| UART6           | PSC0_PSC_0 | UART6 reset      |
| WKUP_UART0      | PSC0_PSC_0 | WKUP_UART0 reset |

Table 4-66. UART Hardware Requests

| Module Instance | Module Interrupt Signal | Destination Interrupt Input  | Destination       | Description                 | Type  |
|-----------------|-------------------------|------------------------------|-------------------|-----------------------------|-------|
| MCU_UART0       | MCU_UART0_usart_i_rq_0  | MCU_M4FSS0_COR_E0_nvic_IN_24 | MCU_M4FSS0_COR_E0 | MCU_UART0 interrupt request | level |
| MCU_UART0       | MCU_UART0_usart_i_rq_0  | GICSS0_spi_IN_217            | GICSS0            | MCU_UART0 interrupt request | level |
| MCU_UART0       | MCU_UART0_usart_i_rq_0  | R5FSS0_CORE0_intr_IN_217     | R5FSS0_CORE0      | MCU_UART0 interrupt request | level |
| MCU_UART0       | MCU_UART0_usart_i_rq_0  | TIFS0_nvic_IN_96             | TIFS0             | MCU_UART0 interrupt request | level |
| MCU_UART0       | MCU_UART0_usart_i_rq_0  | HSM0_nvic_IN_96              | HSM0              | MCU_UART0 interrupt request | level |
| UART0           | UART0_usart_dma_0       | PDMA1_usart_main_0_rx_IN_0   | PDMA1             | UART0 interrupt request     | level |

**Table 4-66. UART Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description             | Type  |
|-----------------|-------------------------|-----------------------------|--------------|-------------------------|-------|
| UART0           | UART0_usart_dma_0       | PDMA1_usart_main_0_tx_IN_0  | PDMA1        | UART0 interrupt request | level |
| UART0           | UART0_usart_dma_1       | PDMA1_usart_main_0_rx_IN_0  | PDMA1        | UART0 interrupt request | level |
| UART0           | UART0_usart_dma_1       | PDMA1_usart_main_0_tx_IN_0  | PDMA1        | UART0 interrupt request | level |
| UART0           | UART0_usart_irq_0       | GICSS0_spi_IN_210           | GICSS0       | UART0 interrupt request | level |
| UART0           | UART0_usart_irq_0       | ICSSM0_pr1_slv_intr_IN_19   | ICSSM0       | UART0 interrupt request | level |
| UART0           | UART0_usart_irq_0       | R5FSS0_CORE0_intr_IN_210    | R5FSS0_CORE0 | UART0 interrupt request | level |
| UART0           | UART0_usart_irq_0       | TIFS0_nvic_IN_89            | TIFS0        | UART0 interrupt request | level |
| UART0           | UART0_usart_irq_0       | HSM0_nvic_IN_89             | HSM0         | UART0 interrupt request | level |
| UART1           | UART1_usart_dma_0       | PDMA1_usart_main_1_rx_IN_0  | PDMA1        | UART1 interrupt request | level |
| UART1           | UART1_usart_dma_0       | PDMA1_usart_main_1_tx_IN_0  | PDMA1        | UART1 interrupt request | level |
| UART1           | UART1_usart_dma_1       | PDMA1_usart_main_1_rx_IN_0  | PDMA1        | UART1 interrupt request | level |
| UART1           | UART1_usart_dma_1       | PDMA1_usart_main_1_tx_IN_0  | PDMA1        | UART1 interrupt request | level |
| UART1           | UART1_usart_irq_0       | GICSS0_spi_IN_211           | GICSS0       | UART1 interrupt request | level |
| UART1           | UART1_usart_irq_0       | ICSSM0_pr1_slv_intr_IN_0    | ICSSM0       | UART1 interrupt request | level |
| UART1           | UART1_usart_irq_0       | R5FSS0_CORE0_intr_IN_211    | R5FSS0_CORE0 | UART1 interrupt request | level |
| UART1           | UART1_usart_irq_0       | TIFS0_nvic_IN_90            | TIFS0        | UART1 interrupt request | level |
| UART1           | UART1_usart_irq_0       | HSM0_nvic_IN_90             | HSM0         | UART1 interrupt request | level |
| UART2           | UART2_usart_dma_0       | PDMA1_usart_main_2_rx_IN_0  | PDMA1        | UART2 interrupt request | level |
| UART2           | UART2_usart_dma_0       | PDMA1_usart_main_2_tx_IN_0  | PDMA1        | UART2 interrupt request | level |
| UART2           | UART2_usart_dma_1       | PDMA1_usart_main_2_rx_IN_0  | PDMA1        | UART2 interrupt request | level |
| UART2           | UART2_usart_dma_1       | PDMA1_usart_main_2_tx_IN_0  | PDMA1        | UART2 interrupt request | level |

**Table 4-66. UART Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description             | Type  |
|-----------------|-------------------------|-----------------------------|--------------|-------------------------|-------|
| UART2           | UART2_usart_irq_0       | GICSS0_spi_IN_212           | GICSS0       | UART2 interrupt request | level |
| UART2           | UART2_usart_irq_0       | ICSSM0_pr1_slv_intr_IN_20   | ICSSM0       | UART2 interrupt request | level |
| UART2           | UART2_usart_irq_0       | R5FSS0_CORE0_intr_IN_212    | R5FSS0_CORE0 | UART2 interrupt request | level |
| UART2           | UART2_usart_irq_0       | TIFS0_nvic_IN_91            | TIFS0        | UART2 interrupt request | level |
| UART2           | UART2_usart_irq_0       | HSM0_nvic_IN_91             | HSM0         | UART2 interrupt request | level |
| UART3           | UART3_usart_dma_0       | PDMA1_usart_main_3_rx_IN_0  | PDMA1        | UART3 interrupt request | level |
| UART3           | UART3_usart_dma_0       | PDMA1_usart_main_3_tx_IN_0  | PDMA1        | UART3 interrupt request | level |
| UART3           | UART3_usart_dma_1       | PDMA1_usart_main_3_rx_IN_0  | PDMA1        | UART3 interrupt request | level |
| UART3           | UART3_usart_dma_1       | PDMA1_usart_main_3_tx_IN_0  | PDMA1        | UART3 interrupt request | level |
| UART3           | UART3_usart_irq_0       | GICSS0_spi_IN_213           | GICSS0       | UART3 interrupt request | level |
| UART3           | UART3_usart_irq_0       | R5FSS0_CORE0_intr_IN_213    | R5FSS0_CORE0 | UART3 interrupt request | level |
| UART3           | UART3_usart_irq_0       | TIFS0_nvic_IN_92            | TIFS0        | UART3 interrupt request | level |
| UART3           | UART3_usart_irq_0       | HSM0_nvic_IN_92             | HSM0         | UART3 interrupt request | level |
| UART4           | UART4_usart_dma_0       | PDMA1_usart_main_4_rx_IN_0  | PDMA1        | UART4 interrupt request | level |
| UART4           | UART4_usart_dma_0       | PDMA1_usart_main_4_tx_IN_0  | PDMA1        | UART4 interrupt request | level |
| UART4           | UART4_usart_dma_1       | PDMA1_usart_main_4_rx_IN_0  | PDMA1        | UART4 interrupt request | level |
| UART4           | UART4_usart_dma_1       | PDMA1_usart_main_4_tx_IN_0  | PDMA1        | UART4 interrupt request | level |
| UART4           | UART4_usart_irq_0       | GICSS0_spi_IN_214           | GICSS0       | UART4 interrupt request | level |
| UART4           | UART4_usart_irq_0       | R5FSS0_CORE0_intr_IN_214    | R5FSS0_CORE0 | UART4 interrupt request | level |
| UART4           | UART4_usart_irq_0       | TIFS0_nvic_IN_93            | TIFS0        | UART4 interrupt request | level |
| UART4           | UART4_usart_irq_0       | HSM0_nvic_IN_93             | HSM0         | UART4 interrupt request | level |

**Table 4-66. UART Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal     | Destination Interrupt Input                                     | Destination             | Description                  | Type  |
|-----------------|-----------------------------|-----------------------------------------------------------------|-------------------------|------------------------------|-------|
| UART5           | UART5_usart_dma_0           | PDMA1_usart_main_5_rx_IN_0                                      | PDMA1                   | UART5 interrupt request      | level |
| UART5           | UART5_usart_dma_0           | PDMA1_usart_main_5_tx_IN_0                                      | PDMA1                   | UART5 interrupt request      | level |
| UART5           | UART5_usart_dma_1           | PDMA1_usart_main_5_rx_IN_0                                      | PDMA1                   | UART5 interrupt request      | level |
| UART5           | UART5_usart_dma_1           | PDMA1_usart_main_5_tx_IN_0                                      | PDMA1                   | UART5 interrupt request      | level |
| UART5           | UART5_usart_irq_0           | GICSS0_spi_IN_215                                               | GICSS0                  | UART5 interrupt request      | level |
| UART5           | UART5_usart_irq_0           | R5FSS0_CORE0_intr_IN_215                                        | R5FSS0_CORE0            | UART5 interrupt request      | level |
| UART5           | UART5_usart_irq_0           | TIFS0_nvic_IN_94                                                | TIFS0                   | UART5 interrupt request      | level |
| UART5           | UART5_usart_irq_0           | HSM0_nvic_IN_94                                                 | HSM0                    | UART5 interrupt request      | level |
| UART6           | UART6_usart_dma_0           | PDMA1_usart_main_6_rx_IN_0                                      | PDMA1                   | UART6 interrupt request      | level |
| UART6           | UART6_usart_dma_0           | PDMA1_usart_main_6_tx_IN_0                                      | PDMA1                   | UART6 interrupt request      | level |
| UART6           | UART6_usart_dma_1           | PDMA1_usart_main_6_rx_IN_0                                      | PDMA1                   | UART6 interrupt request      | level |
| UART6           | UART6_usart_dma_1           | PDMA1_usart_main_6_tx_IN_0                                      | PDMA1                   | UART6 interrupt request      | level |
| UART6           | UART6_usart_irq_0           | GICSS0_spi_IN_216                                               | GICSS0                  | UART6 interrupt request      | level |
| UART6           | UART6_usart_irq_0           | R5FSS0_CORE0_intr_IN_216                                        | R5FSS0_CORE0            | UART6 interrupt request      | level |
| UART6           | UART6_usart_irq_0           | TIFS0_nvic_IN_95                                                | TIFS0                   | UART6 interrupt request      | level |
| UART6           | UART6_usart_irq_0           | HSM0_nvic_IN_95                                                 | HSM0                    | UART6 interrupt request      | level |
| WKUP_UART0      | WKUP_UART0_clkstop_wakeup_0 | R5FSS0_CORE0_intr_IN_144                                        | R5FSS0_CORE0            | WKUP_UART0 interrupt request | level |
| WKUP_UART0      | WKUP_UART0_clkstop_wakeup_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_1 | WKUP_DEEPSLEEP_SOURCES0 | WKUP_UART0 interrupt request | level |
| WKUP_UART0      | WKUP_UART0_usart_irq_0      | GICSS0_spi_IN_218                                               | GICSS0                  | WKUP_UART0 interrupt request | level |
| WKUP_UART0      | WKUP_UART0_usart_irq_0      | R5FSS0_CORE0_intr_IN_219                                        | R5FSS0_CORE0            | WKUP_UART0 interrupt request | level |

## 4.8 High-speed Serial Interfaces

### 4.8.1 Gigabit Ethernet Switch (CPSW)

This section contains the integration details for the CPSW module on this device. For further information, see the Gigabit Ethernet Switch (CPSW) section of the Peripherals chapter

#### 4.8.1.1 CPSW Unsupported Features

The following features are not supported by the CPSW switch:

- Maximum frame size of 9600 bytes
- GMII Mode
- SGMII Mode
- MACSEC
- Synchronous Ethernet

#### 4.8.1.2 Module Allocations

**Table 4-67. CPSW Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| CPSW0    |        |     | ✓    |

#### 4.8.1.3 Resets, Interrupts, and Clocks

**Table 4-68. CPSW Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------|
| CPSW0           | PSC0_PSC_0             | PD_CPSW      | LPSC_CPSW3_G  | 41    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-69. CPSW Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| CPSW0           | PSC0_PSC_0 | CPSW0 reset |

**Table 4-70. CPSW Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input                                        | Destination                           | Description             | Type  |
|-----------------|-------------------------|--------------------------------------------------------------------|---------------------------------------|-------------------------|-------|
| CPSW0           | CPSW0_cpts_comp_0       | PINFUNCTION_CP_GEMAC_CPTS0_TS_COMPout_CP_GEMAC_CPTS0_TS_COM_P_IN_0 | PINFUNCTION_CP_GEMAC_CPTS0_TS_COMPout | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_cpts_comp_0       | CMP_EVENT_INTRO_UTER0_in_IN_24                                     | CMP_EVENT_INTRO_UTER0                 | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_cpts_genf0_0      | TIMESYNC_EVENT_ROUTER0_in_IN_16                                    | TIMESYNC_EVENT_ROUTER0                | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_cpts_genf1_0      | TIMESYNC_EVENT_ROUTER0_in_IN_17                                    | TIMESYNC_EVENT_ROUTER0                | CPSW0 interrupt request | level |

**Table 4-70. CPSW Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input                                      | Destination                          | Description             | Type  |
|-----------------|-------------------------|------------------------------------------------------------------|--------------------------------------|-------------------------|-------|
| CPSW0           | CPSW0_cpts_sync_0       | PINFUNCTOR_CP_GEMAC_CPTSO_TS_SYNCout_CP_GEMAC_CPTSO_TS_SYNC_IN_0 | PINFUNCTOR_CP_GEMAC_CPTSO_TS_SYNCout | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_cpts_sync_0       | TIMESYNC_EVENT_ROUTER0_in_IN_18                                  | TIMESYNC_EVENT_ROUTER0               | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_ecc_ded_pend_0    | ESM0_esm_lvl_event_IN_67                                         | ESM0                                 | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_ecc_sec_pend_0    | ESM0_esm_lvl_event_IN_3                                          | ESM0                                 | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_evnt_pend_0       | GICSS0_spi_IN_134                                                | GICSS0                               | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_evnt_pend_0       | R5FSS0_CORE0_intr_IN_134                                         | R5FSS0_CORE0                         | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_mdio_pend_0       | GICSS0_spi_IN_135                                                | GICSS0                               | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_mdio_pend_0       | R5FSS0_CORE0_intr_IN_135                                         | R5FSS0_CORE0                         | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_stat_pend_0       | GICSS0_spi_IN_136                                                | GICSS0                               | CPSW0 interrupt request | level |
| CPSW0           | CPSW0_stat_pend_0       | R5FSS0_CORE0_intr_IN_136                                         | R5FSS0_CORE0                         | CPSW0 interrupt request | level |

Table 4-71. CPSW Clocks

| Module Instance | Module Clock Input | Source Clock                   | Source Control Register | Description                                 |
|-----------------|--------------------|--------------------------------|-------------------------|---------------------------------------------|
| CPSW0           | CPPI_CLK           | MAIN_SYSCLK0/2                 |                         | CPSW0 CPPI packet streaming interface clock |
|                 | CPTS_RFT_CLK       | MAIN_PLL2_HSDIV5_CL<br>KOUT    | CPSW_CLKSEL[2:0]        |                                             |
|                 |                    | MAIN_PLL0_HSDIV6_CL<br>KOUT    | CPSW_CLKSEL[2:0]        |                                             |
|                 |                    | CP_GEMAC_CPTS_REF<br>_CLK      | CPSW_CLKSEL[2:0]        |                                             |
|                 |                    | MCU_EXT_REFCLK0                | CPSW_CLKSEL[2:0]        |                                             |
|                 |                    | EXT_REFCLK1                    | CPSW_CLKSEL[2:0]        |                                             |
|                 |                    | MCU_SYSCLK0                    | CPSW_CLKSEL[2:0]        |                                             |
|                 | MAIN_SYSCLK0       | CPSW_CLKSEL[2:0]               |                         |                                             |
|                 | GMII1_MR_CLK       | MAIN_PLL2_HSDIV1_CL<br>KOUT/10 |                         |                                             |
|                 | GMII1_MT_CLK       | MAIN_PLL2_HSDIV1_CL<br>KOUT/10 |                         |                                             |
|                 | GMII2_MR_CLK       | MAIN_PLL2_HSDIV1_CL<br>KOUT/10 |                         |                                             |
|                 | GMII2_MT_CLK       | MAIN_PLL2_HSDIV1_CL<br>KOUT/10 |                         |                                             |
|                 | GMII_RFT_CLK       | MAIN_PLL2_HSDIV1_CL<br>KOUT/2  |                         | CPSW0 125MHz Gigabit Mode Clock             |
|                 | RGMII_MHZ_250_CLK  | MAIN_PLL2_HSDIV1_CL<br>KOUT    |                         | CPSW0 250-MHz Reference clock               |
|                 | RGMII_MHZ_50_CLK   | MAIN_PLL2_HSDIV1_CL<br>KOUT/5  |                         | CPSW0 50-MHz Reference Clock                |
|                 | RGMII_MHZ_5_CLK    | MAIN_PLL2_HSDIV1_CL<br>KOUT/50 |                         | CPSW0 5-MHz Reference Clock                 |

#### 4.8.2 Universal Serial Bus Subsystem (USB)

This section contains the integration details for the USB module on this device. For further information, see the Universal Serial Bus Subsystem (USB) section of the Peripherals chapter

##### 4.8.2.1 USB2SS Unsupported Features

The following features are not supported on this family of devices:

- Battery Charger Support
- Accessory Charger Adaptor Support
- On-The-Go (OTG)
- No Virtualization Support
- SuperSpeed (5Gb/s) operation
- USB 2.0 ECN: Link Power Management (LPM)
- Low Speed operation in device mode
- Charger Detection

##### 4.8.2.2 Module Allocations

**Table 4-72. USB Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| USB0     |        |     | ✓    |
| USB1     |        |     | ✓    |

##### 4.8.2.3 Resets, Interrupts, and Clocks

**Table 4-73. USB Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------|
| USB0            | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_USB_0    | 23    | OFF     | YES          | LPSC_MAIN_IP |
| USB1            | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_USB_1    | 24    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-74. USB Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| USB0            | PSC0_PSC_0 | USB0 reset  |
| USB1            | PSC0_PSC_0 | USB1 reset  |

**Table 4-75. USB Hardware Requests**

| Module Instance | Module Interrupt Signal  | Destination Interrupt Input    | Destination  | Description            | Type  |
|-----------------|--------------------------|--------------------------------|--------------|------------------------|-------|
| USB0            | USB0_host_system_error_0 | ESM0_esm_lvl_event_IN_32       | ESM0         | USB0 interrupt request | level |
| USB0            | USB0_irq_[7:0]           | GICSS0_spi_IN_[227:220]        | GICSS0       | USB0 interrupt request | level |
| USB0            | USB0_irq_[7:0]           | R5FSS0_CORE0_intr_IN_[227:220] | R5FSS0_CORE0 | USB0 interrupt request | level |
| USB0            | USB0_misc_level_0        | GICSS0_spi_IN_228              | GICSS0       | USB0 interrupt request | pulse |

Table 4-75. USB Hardware Requests (continued)

| Module Instance | Module Interrupt Signal           | Destination Interrupt Input                                      | Destination             | Description            | Type  |
|-----------------|-----------------------------------|------------------------------------------------------------------|-------------------------|------------------------|-------|
| USB0            | USB0_misc_level_0                 | R5FSS0_CORE0_intr_IN_228                                         | R5FSS0_CORE0            | USB0 interrupt request | pulse |
| USB0            | USB0_usb_wakeup_c_lkstop_wakeup_0 | R5FSS0_CORE0_intr_IN_61                                          | R5FSS0_CORE0            | USB0 interrupt request | level |
| USB0            | USB0_usb_wakeup_c_lkstop_wakeup_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_9  | WKUP_DEEPSLEEP_SOURCES0 | USB0 interrupt request | level |
| USB1            | USB1_host_system_error_0          | ESM0_esm_lvt_event_IN_33                                         | ESM0                    | USB1 interrupt request | level |
| USB1            | USB1_irq_[7:0]                    | GICSS0_spi_IN_[265:258]                                          | GICSS0                  | USB1 interrupt request | level |
| USB1            | USB1_irq_[7:0]                    | R5FSS0_CORE0_intr_IN_[237:230]                                   | R5FSS0_CORE0            | USB1 interrupt request | level |
| USB1            | USB1_misc_level_0                 | GICSS0_spi_IN_266                                                | GICSS0                  | USB1 interrupt request | pulse |
| USB1            | USB1_misc_level_0                 | R5FSS0_CORE0_intr_IN_238                                         | R5FSS0_CORE0            | USB1 interrupt request | pulse |
| USB1            | USB1_usb_wakeup_c_lkstop_wakeup_0 | R5FSS0_CORE0_intr_IN_62                                          | R5FSS0_CORE0            | USB1 interrupt request | level |
| USB1            | USB1_usb_wakeup_c_lkstop_wakeup_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_10 | WKUP_DEEPSLEEP_SOURCES0 | USB1 interrupt request | level |

Table 4-76. USB Clocks

| Module Instance | Module Clock Input | Source Clock            | Source Control Register | Description |
|-----------------|--------------------|-------------------------|-------------------------|-------------|
| USB0            | BUS_CLK            | MAIN_SYSCLK0/2          |                         |             |
|                 | CFG_CLK            | MAIN_SYSCLK0/4          |                         |             |
|                 | USB2_APB_PCLK_CLK  | MAIN_SYSCLK0/4          |                         |             |
|                 | USB2_REFCLK_CLK    | HFOSC0_CLKOUT           | USB0_CLKSEL[0:0]        |             |
|                 |                    | MAIN_PLL0_HSDIV8_CLKOUT | USB0_CLKSEL[0:0]        |             |
| USB1            | BUS_CLK            | MAIN_SYSCLK0/2          |                         |             |
|                 | CFG_CLK            | MAIN_SYSCLK0/4          |                         |             |
|                 | USB2_APB_PCLK_CLK  | MAIN_SYSCLK0/4          |                         |             |
|                 | USB2_REFCLK_CLK    | HFOSC0_CLKOUT           | USB1_CLKSEL[0:0]        |             |
|                 |                    | MAIN_PLL0_HSDIV8_CLKOUT | USB1_CLKSEL[0:0]        |             |

## 4.9 Memory Interfaces

### 4.9.1 Flash Subsystem (FSS)

This section contains the integration details for the Flash Subsystem on this device. For further information, see the Flash Subsystem (FSS) section of the Peripherals chapter

#### 4.9.1.1 FSS Unsupported Features

For more information, see [Section 4.9.2.1, OSPI Not Supported Features](#).

#### 4.9.1.2 Module Allocations

**Table 4-77. FSS Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| FSS0     |        |     | ✓    |

#### 4.9.1.3 Resets, Interrupts, and Clocks

**Table 4-78. FSS Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|-------------|
| FSS0            |                        |              |               |       |         |              |             |

**Table 4-79. FSS Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| FSS0            | PSC0_PSC_0 | FSS0 reset  |

**Table 4-80. FSS Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description | Type |
|-----------------|-------------------------|-----------------------------|-------------|-------------|------|
|                 |                         |                             |             |             |      |

**Table 4-81. FSS Clocks**

| Module Instance | Module Clock Input | Source Clock | Source Control Register | Description |
|-----------------|--------------------|--------------|-------------------------|-------------|
|                 |                    |              |                         |             |

#### 4.9.2 Octal Serial Peripheral Interface (OSPI)

This section contains the integration details for the OSPI module on this device. For Further information, see the Octal Serial Peripheral Interface (OSPI) section of the Peripherals chapter

##### 4.9.2.1 OSPI Unsupported Features

The following features are not supported on this family of devices:

- OSPI PDMA. Use CPU-triggered block DMA
- OSPI Clock Phase/Polarity Modes 1,2,3
- Reset Pins OSPI0\_RESET\_OUT2, OSPI0\_RESET\_OUT3

##### 4.9.2.2 Module Allocations

**Table 4-82. OSPI Modules Allocation within Device Domains**

| Instance    | Domain |     |      |
|-------------|--------|-----|------|
|             | WKUP   | MCU | Main |
| FSS0_OSPI_0 |        |     | ✓    |

##### 4.9.2.3 Resets, Interrupts, and Clocks

**Table 4-83. OSPI Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|-------------|
|                 |                        |              |               |       |         |              |             |

**Table 4-84. OSPI Resets**

| Module Instance | Source | Description |
|-----------------|--------|-------------|
|                 |        |             |

**Table 4-85. OSPI Hardware Requests**

| Module Instance | Module Interrupt Signal                | Destination Interrupt Input | Destination  | Description                   | Type  |
|-----------------|----------------------------------------|-----------------------------|--------------|-------------------------------|-------|
| FSS0_OSPI_0     | FSS0_OSPI_0_ospi_ecc_corr_lvl_intr_0   | ESM0_esm_lvl_event_IN_11    | ESM0         | FSS0_OSPI_0 interrupt request | level |
| FSS0_OSPI_0     | FSS0_OSPI_0_ospi_ecc_uncorr_lvl_intr_0 | ESM0_esm_lvl_event_IN_74    | ESM0         | FSS0_OSPI_0 interrupt request | level |
| FSS0_OSPI_0     | FSS0_OSPI_0_ospi_lvl_intr_0            | GICSS0_spi_IN_171           | GICSS0       | FSS0_OSPI_0 interrupt request | level |
| FSS0_OSPI_0     | FSS0_OSPI_0_ospi_lvl_intr_0            | ICSSM0_pr1_slv_intr_IN_26   | ICSSM0       | FSS0_OSPI_0 interrupt request | level |
| FSS0_OSPI_0     | FSS0_OSPI_0_ospi_lvl_intr_0            | R5FSS0_CORE0_intr_IN_171    | R5FSS0_CORE0 | FSS0_OSPI_0 interrupt request | level |
| FSS0_OSPI_0     | FSS0_OSPI_0_ospi_lvl_intr_0            | TIFS0_nvic_IN_224           | TIFS0        | FSS0_OSPI_0 interrupt request | level |
| FSS0_OSPI_0     | FSS0_OSPI_0_ospi_lvl_intr_0            | HSM0_nvic_IN_224            | HSM0         | FSS0_OSPI_0 interrupt request | level |

**Table 4-86. OSPI Clocks**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description                     |
|-----------------|--------------------|-----------------------------|-------------------------|---------------------------------|
| FSS0_OSPI_0     | HCLK               | MAIN_SYSCLK0                |                         | FSS0_OSPI_0 Data Transfer Clock |
|                 | PCLK               | MAIN_SYSCLK0                |                         | FSS0_OSPI_0 Configuration clock |
|                 | RCLK               | MAIN_PLL0_HSDIV1_CL<br>KOUT | OSPI0_CLKSEL[0:0]       | FSS0_OSPI_0 Reference Clock     |
|                 |                    | MAIN_PLL1_HSDIV5_CL<br>KOUT | OSPI0_CLKSEL[0:0]       |                                 |

#### 4.9.3 General-Purpose Memory Controller (GPMC)

This section contains the integration details for the GPMC module on this device. For further information, see the General-Purpose Memory Controller (GPMC) section of the Peripherals chapter.

##### 4.9.3.1 GPMC Unsupported Features

The following features are not supported on this family of devices:

- Pins GPMC\_CS[7:4]n are not pinned out
- Pins GPMC\_A[27:23] are not pinned out
- Pins GPMC\_AD[31:16] are not pinned out
- Pins GPMC\_WAIT[3:2] are not pinned out
- Pins GPMC\_BE[3:2]n are not pinned out

##### 4.9.3.2 Module Allocations

**Table 4-87. GPMC Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| GPMC0    |        |     | ✓    |

##### 4.9.3.3 Resets, Interrupts, and Clocks

**Table 4-88. GPMC Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------|
| GPMC0           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_GPMC     | 15    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-89. GPMC Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| GPMC0           | PSC0_PSC_0 | GPMC0 reset |

**Table 4-90. GPMC Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input              | Destination      | Description             | Type  |
|-----------------|-------------------------|------------------------------------------|------------------|-------------------------|-------|
| GPMC0           | GPMC0_gpmc_sdma_req_0   | DMASS0_INTAGGR_0_intaggr_levi_pend_IN_26 | DMASS0_INTAGGR_0 | GPMC0 interrupt request | level |
| GPMC0           | GPMC0_gpmc_sinterrupt_0 | GICSS0_spi_IN_138                        | GICSS0           | GPMC0 interrupt request | level |
| GPMC0           | GPMC0_gpmc_sinterrupt_0 | R5FSS0_CORE0_intr_IN_103                 | R5FSS0_CORE0     | GPMC0 interrupt request | level |

**Table 4-91. GPMC Clocks**

| Module Instance | Module Clock Input | Source Clock            | Source Control Register | Description            |
|-----------------|--------------------|-------------------------|-------------------------|------------------------|
| GPMC0           | FCLK               | MAIN_PLL0_HSDIV3_CLKOUT | GPCMC_CLKSEL[0:0]       | GPMC0 Functional Clock |
|                 |                    | MAIN_PLL2_HSDIV7_CLKOUT | GPCMC_CLKSEL[0:0]       |                        |
|                 | ICLK               | MAIN_SYSCLK0/2          |                         | GPMC0 Interface clock  |

#### 4.9.4 Error Location Module (ELM)

This section contains the integration details for the ELM module on this device. For further information, see the Error Location Module (ELM) section of the Peripherals chapter

##### 4.9.4.1 ELM Unsupported Features

The following features are not supported on this family of devices:

- There are no unsupported features

##### 4.9.4.2 Module Allocations

**Table 4-92. ELM Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| ELM0     |        |     | ✓    |

##### 4.9.4.3 Resets, Interrupts, and Clocks

**Table 4-93. ELM Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------|
| ELM0            | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_GPMC     | 15    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-94. ELM Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| ELM0            | PSC0_PSC_0 | ELM0 reset  |

**Table 4-95. ELM Hardware Requests**

| Module Instance | Module Interrupt Signal           | Destination Interrupt Input | Destination  | Description            | Type  |
|-----------------|-----------------------------------|-----------------------------|--------------|------------------------|-------|
| ELM0            | ELM0_elm_porocpsin_terrrupt_lvl_0 | GICSS0_spi_IN_164           | GICSS0       | ELM0 interrupt request | level |
| ELM0            | ELM0_elm_porocpsin_terrrupt_lvl_0 | R5FSS0_CORE0_intr_IN_164    | R5FSS0_CORE0 | ELM0 interrupt request | level |

**Table 4-96. ELM Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                         |
|-----------------|--------------------|----------------|-------------------------|-------------------------------------|
| ELM0            | FICLK              | MAIN_SYSCLK0/4 |                         | ELM0 Functional and Interface Clock |

#### 4.9.5 Multimedia Card Secure Digital (MMCSD)

This section contains the integration details for the MMCSD module on this device. For further information, see the Multimedia Card Secure Digital (MMCSD) section of the Peripherals chapter

##### 4.9.5.1 MMCSD Unsupported Features

The following features are not supported on this family of devices:

- The following apply to 4-bit MMCSD instances:
  - SD Card busy LED - Not pinned out
  - High Speed DDR
- The following apply to 8-bit MMCSD instances:
  - SD Card busy LED - Not pinned out
  - SD/SDIO/MMC Cards (Removable) - no support for 4-pin/8-pin muxing
  - SD Card Detect Pin - Not pinned out
  - SD Card Write Protect Pin - Not pinned out
  - High Speed DDR

##### 4.9.5.2 Module Allocations

Table 4-97. MMCSD Modules Allocation within Device Domains

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| MMCSD1   |        |     | ✓    |
| MMCSD2   |        |     | ✓    |
| MMCSD0   |        |     | ✓    |

##### 4.9.5.3 Resets, Interrupts, and Clocks

Table 4-98. MMCSD Integration Attributes

| Module Instance | Power Sleep Controller | Power Domain | Module Domain  | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|----------------|-------|---------|--------------|--------------|
| MMCSD0          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_EMMC_8B   | 20    | OFF     | YES          | LPSC_MAIN_IP |
| MMCSD1          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_EMMC_4B_0 | 21    | OFF     | YES          | LPSC_MAIN_IP |
| MMCSD2          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_EMMC_4B_1 | 22    | OFF     | YES          | LPSC_MAIN_IP |

Table 4-99. MMCSD Resets

| Module Instance | Source     | Description  |
|-----------------|------------|--------------|
| MMCSD1          | PSC0_PSC_0 | MMCSD1 reset |
| MMCSD2          | PSC0_PSC_0 | MMCSD2 reset |
| MMCSD0          | PSC0_PSC_0 | MMCSD0 reset |

Table 4-100. MMCSD Hardware Requests

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description              | Type  |
|-----------------|-------------------------|-----------------------------|-------------|--------------------------|-------|
| MMCSD1          | MMCSD1_emmcssdss_intr_0 | GICSS0_spi_IN_115           | GICSS0      | MMCSD1 interrupt request | level |

**Table 4-100. MMCSD Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description              | Type  |
|-----------------|-------------------------|-----------------------------|--------------|--------------------------|-------|
| MMCSD1          | MMCSD1_emmcssdss_intr_0 | R5FSS0_CORE0_intr_IN_162    | R5FSS0_CORE0 | MMCSD1 interrupt request | level |
| MMCSD2          | MMCSD2_emmcssdss_intr_0 | GICSS0_spi_IN_114           | GICSS0       | MMCSD2 interrupt request | level |
| MMCSD2          | MMCSD2_emmcssdss_intr_0 | R5FSS0_CORE0_intr_IN_163    | R5FSS0_CORE0 | MMCSD2 interrupt request | level |
| MMCSD0          | MMCSD0_emmcssdss_intr_0 | GICSS0_spi_IN_165           | GICSS0       | MMCSD0 interrupt request | level |
| MMCSD0          | MMCSD0_emmcssdss_intr_0 | R5FSS0_CORE0_intr_IN_161    | R5FSS0_CORE0 | MMCSD0 interrupt request | level |

**Table 4-101. MMCSD Clocks**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description |
|-----------------|--------------------|-----------------------------|-------------------------|-------------|
| MMCSD1          | EMMCSDDSS_VBUS_CLK | MAIN_SYSCLK0/2              |                         |             |
|                 | EMMCSDDSS_XIN_CLK  | MAIN_PLL0_HSDIV5_CL<br>KOUT | EMMC1_CLKSEL[0:0]       |             |
|                 |                    | MAIN_PLL2_HSDIV2_CL<br>KOUT | EMMC1_CLKSEL[0:0]       |             |
| MMCSD2          | EMMCSDDSS_VBUS_CLK | MAIN_SYSCLK0/2              |                         |             |
|                 | EMMCSDDSS_XIN_CLK  | MAIN_PLL0_HSDIV5_CL<br>KOUT | EMMC2_CLKSEL[0:0]       |             |
|                 |                    | MAIN_PLL2_HSDIV2_CL<br>KOUT | EMMC2_CLKSEL[0:0]       |             |
| MMCSD0          | EMMCSDDSS_VBUS_CLK | MAIN_SYSCLK0/2              |                         |             |
|                 | EMMCSDDSS_XIN_CLK  | MAIN_PLL0_HSDIV5_CL<br>KOUT | EMMC0_CLKSEL[0:0]       |             |
|                 |                    | MAIN_PLL2_HSDIV2_CL<br>KOUT | EMMC0_CLKSEL[0:0]       |             |

## 4.10 Industrial and Control Interfaces

### 4.10.1 Modular Controller Area Network (MCAN)

This section contains the integration details for the MCAN module on this device. For Further information, see the Modular Controller Area Network (MCAN) section of the Peripherals chapter

#### 4.10.1.1 MCAN Unsupported Features

- Debug DMAs - DMA Ack not supported by PDMA architecture. Debug messages can be traced through the RX FIFO.
- TX DMA channels 3-31 are not supported by the Main domain instance (MCAN0)- Only TX\_DMA[2:0] have associated PDMA channels
- DMA is not supported on the MCU domain instances, MCU\_MCAN0 and MCU\_MCAN1

#### 4.10.1.2 Module Allocations

**Table 4-102. MCAN Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| MCAN0     |        |     | ✓    |
| MCU_MCAN0 |        | ✓   |      |
| MCU_MCAN1 |        | ✓   |      |

#### 4.10.1.3 Resets, Interrupts, and Clocks

**Table 4-103. Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain      | Index | Default | Controllable | dependences     |
|-----------------|------------------------|--------------|--------------------|-------|---------|--------------|-----------------|
| MCAN0           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_MCANSS_0 | 35    | OFF     | YES          | LPSC_MAIN_IP    |
| MCU_MCAN0       | WKUP_PSC0              | PD_M4F       | LPSC MCU_MCANSS_0  | 7     | OFF     | YES          | LPSC MCU_COMMON |
| MCU_MCAN1       | WKUP_PSC0              | PD_M4F       | LPSC MCU_MCANSS_1  | 8     | OFF     | YES          | LPSC MCU_COMMON |

**Table 4-104. MCAN Resets**

| Module Instance | Source     | Description     |
|-----------------|------------|-----------------|
| MCAN0           | PSC0_PSC_0 | MCAN0 reset     |
| MCU_MCAN0       | WKUP_PSC0  | MCU_MCAN0 reset |
| MCU_MCAN1       | WKUP_PSC0  | MCU_MCAN1 reset |

**Table 4-105. MCAN Hardware Requests**

| Module Instance | Module Interrupt Signal                | Destination Interrupt Input | Destination  | Description             | Type  |
|-----------------|----------------------------------------|-----------------------------|--------------|-------------------------|-------|
| MCAN0           | MCAN0_mcanss_ext_ts_rollover_lvl_int_0 | GICSS0_spi_IN_186           | GICSS0       | MCAN0 interrupt request | level |
| MCAN0           | MCAN0_mcanss_ext_ts_rollover_lvl_int_0 | R5FSS0_CORE0_intr_IN_186    | R5FSS0_CORE0 | MCAN0 interrupt request | level |
| MCAN0           | MCAN0_mcanss_ext_ts_rollover_lvl_int_0 | TIFS0_nvic_IN_102           | TIFS0        | MCAN0 interrupt request | level |

**Table 4-105. MCAN Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal                    | Destination Interrupt Input     | Destination      | Description                 | Type  |
|-----------------|--------------------------------------------|---------------------------------|------------------|-----------------------------|-------|
| MCAN0           | MCANO_mcanss_ext_ts_rollover_lvl_int_0     | HSM0_nvic_IN_102                | HSM0             | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_fe_[2:0]                      | PDMA0_mcanss_main_0_fe_IN_[2:0] | PDMA0            | MCANO interrupt request     | pulse |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | GICSS0_spi_IN_187               | GICSS0           | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | GICSS0_spi_IN_188               | GICSS0           | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | R5FSS0_CORE0_intr_IN_187        | R5FSS0_CORE0     | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | R5FSS0_CORE0_intr_IN_188        | R5FSS0_CORE0     | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | TIFS0_nvic_IN_103               | TIFS0            | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | TIFS0_nvic_IN_104               | TIFS0            | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | HSM0_nvic_IN_103                | HSM0             | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_mcan_lvl_int_[1:0]            | HSM0_nvic_IN_104                | HSM0             | MCANO interrupt request     | level |
| MCAN0           | MCANO_mcanss_tx_dma_[31:0]                 | PDMA0_mcanss_main_0_tx_IN_[2:0] | PDMA0            | MCANO interrupt request     | pulse |
| MCU_MCAN0       | MCU_MCAN0_mcanss_ext_ts_rollover_lvl_int_0 | MCU_M4FSS0_CORE0_nvic_IN_42     | MCU_M4FSS0_CORE0 | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_ext_ts_rollover_lvl_int_0 | TIFS0_nvic_IN_108               | TIFS0            | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_ext_ts_rollover_lvl_int_0 | HSM0_nvic_IN_108                | HSM0             | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_mcan_lvl_int_0            | MCU_M4FSS0_CORE0_nvic_IN_43     | MCU_M4FSS0_CORE0 | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_mcan_lvl_int_0            | MCU_M4FSS0_CORE0_nvic_IN_44     | MCU_M4FSS0_CORE0 | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_mcan_lvl_int_0            | TIFS0_nvic_IN_109               | TIFS0            | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_mcan_lvl_int_0            | TIFS0_nvic_IN_110               | TIFS0            | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_mcan_lvl_int_0            | HSM0_nvic_IN_109                | HSM0             | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcanss_mcan_lvl_int_0            | HSM0_nvic_IN_110                | HSM0             | MCU_MCAN0 interrupt request | level |

Table 4-105. MCAN Hardware Requests (continued)

| Module Instance | Module Interrupt Signal                     | Destination Interrupt Input  | Destination       | Description                 | Type  |
|-----------------|---------------------------------------------|------------------------------|-------------------|-----------------------------|-------|
| MCU_MCAN0       | MCU_MCAN0_mcans.s_mcan_lvl_int_1            | MCU_M4FSS0_COR_E0_nvic_IN_43 | MCU_M4FSS0_COR_E0 | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcans.s_mcan_lvl_int_1            | MCU_M4FSS0_COR_E0_nvic_IN_44 | MCU_M4FSS0_COR_E0 | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcans.s_mcan_lvl_int_1            | TIFS0_nvic_IN_109            | TIFS0             | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcans.s_mcan_lvl_int_1            | TIFS0_nvic_IN_110            | TIFS0             | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcans.s_mcan_lvl_int_1            | HSM0_nvic_IN_109             | HSM0              | MCU_MCAN0 interrupt request | level |
| MCU_MCAN0       | MCU_MCAN0_mcans.s_mcan_lvl_int_1            | HSM0_nvic_IN_110             | HSM0              | MCU_MCAN0 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_ext_ts_rollover_lvl_int_0 | MCU_M4FSS0_COR_E0_nvic_IN_45 | MCU_M4FSS0_COR_E0 | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_ext_ts_rollover_lvl_int_0 | TIFS0_nvic_IN_105            | TIFS0             | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_ext_ts_rollover_lvl_int_0 | HSM0_nvic_IN_105             | HSM0              | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_0            | MCU_M4FSS0_COR_E0_nvic_IN_46 | MCU_M4FSS0_COR_E0 | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_0            | MCU_M4FSS0_COR_E0_nvic_IN_47 | MCU_M4FSS0_COR_E0 | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_0            | TIFS0_nvic_IN_106            | TIFS0             | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_0            | TIFS0_nvic_IN_107            | TIFS0             | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_0            | HSM0_nvic_IN_106             | HSM0              | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_0            | HSM0_nvic_IN_107             | HSM0              | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_1            | MCU_M4FSS0_COR_E0_nvic_IN_46 | MCU_M4FSS0_COR_E0 | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_1            | MCU_M4FSS0_COR_E0_nvic_IN_47 | MCU_M4FSS0_COR_E0 | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_1            | TIFS0_nvic_IN_106            | TIFS0             | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_1            | TIFS0_nvic_IN_107            | TIFS0             | MCU_MCAN1 interrupt request | level |
| MCU_MCAN1       | MCU_MCAN1_mcans.s_mcan_lvl_int_1            | HSM0_nvic_IN_106             | HSM0              | MCU_MCAN1 interrupt request | level |

**Table 4-105. MCAN Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal          | Destination Interrupt Input | Destination | Description                 | Type  |
|-----------------|----------------------------------|-----------------------------|-------------|-----------------------------|-------|
| MCU_MCAN1       | MCU_MCAN1_mcans_s_mcan_lvl_int_1 | HSM0_nvic_IN_107            | HSM0        | MCU_MCAN1 interrupt request | level |

**Table 4-106. MCAN Clocks**

| Module Instance | Module Clock Input | Source Clock            | Source Control Register | Description |
|-----------------|--------------------|-------------------------|-------------------------|-------------|
| MCAN0           | MCANSS_CCLK_CLK    | MAIN_PBIST_CLK          |                         |             |
|                 |                    | MAIN_PLL0_HSDIV4_CLKOUT | MCAN0_CLKSEL[1:0]       |             |
|                 |                    | MCU_EXT_REFCLK0         | MCAN0_CLKSEL[1:0]       |             |
|                 |                    | EXT_REFCLK1             | MCAN0_CLKSEL[1:0]       |             |
|                 |                    | HFOSC0_CLKOUT           | MCAN0_CLKSEL[1:0]       |             |
|                 | MCANSS_HCLK_CLK    | MAIN_SYSCLK0/4          |                         |             |
| MCU_MCAN0       | MCANSS_CCLK_CLK    | MCU_DFT_SCAN_CLK        |                         |             |
|                 |                    | MCU_PLL0_HSDIV4_CLKOUT  | MCU_MCAN0_CLKSEL[1:0]   |             |
|                 |                    | MCU_EXT_REFCLK0         | MCU_MCAN0_CLKSEL[1:0]   |             |
|                 |                    | HFOSC0_CLKOUT           | MCU_MCAN0_CLKSEL[1:0]   |             |
|                 |                    | HFOSC0_CLKOUT           | MCU_MCAN0_CLKSEL[1:0]   |             |
|                 | MCANSS_HCLK_CLK    | MCU_SYSCLK0/2           |                         |             |
| MCU_MCAN1       | MCANSS_CCLK_CLK    | MCU_DFT_SCAN_CLK        |                         |             |
|                 |                    | MCU_PLL0_HSDIV4_CLKOUT  | MCU_MCAN1_CLKSEL[1:0]   |             |
|                 |                    | MCU_EXT_REFCLK0         | MCU_MCAN1_CLKSEL[1:0]   |             |
|                 |                    | HFOSC0_CLKOUT           | MCU_MCAN1_CLKSEL[1:0]   |             |
|                 |                    | HFOSC0_CLKOUT           | MCU_MCAN1_CLKSEL[1:0]   |             |
|                 | MCANSS_HCLK_CLK    | MCU_SYSCLK0/2           |                         |             |

#### 4.10.2 Enhanced Capture (ECAP)

This section contains the integration details for the ECAP module on this device. For further information, see the Enhanced Capture (ECAP) section of the Peripherals chapter

##### 4.10.2.1 ECAP Unsupported Features

The following features are not supported on this family of devices:

- There are no unsupported features

##### 4.10.2.2 Module Allocations

**Table 4-107. ECAP Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| ECAP0    |        |     | ✓    |
| ECAP1    |        |     | ✓    |
| ECAP2    |        |     | ✓    |

##### 4.10.2.3 Resets, Interrupts, and Clocks

**Table 4-108. ECAP Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|------------------------|
| ECAP0           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| ECAP1           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| ECAP2           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |

**Table 4-109. ECAP Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| ECAP0           | PSC0_PSC_0 | ECAP0 reset |
| ECAP1           | PSC0_PSC_0 | ECAP1 reset |
| ECAP2           | PSC0_PSC_0 | ECAP2 reset |

**Table 4-110. ECAP Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description             | Type  |
|-----------------|-------------------------|-----------------------------|-------------|-------------------------|-------|
| ECAP0           | ECAP0_ecap_int_0        | GICSS0_spi_IN_145           | GICSS0      | ECAP0 interrupt request | pulse |
| ECAP0           | ECAP0_ecap_int_0        | ICSSM0_pr1_slv_intr_IN_10   | ICSSM0      | ECAP0 interrupt request | pulse |
| ECAP0           | ECAP0_ecap_int_0        | TIFS0_nvic_IN_74            | TIFS0       | ECAP0 interrupt request | pulse |
| ECAP0           | ECAP0_ecap_int_0        | HSM0_nvic_IN_74             | HSM0        | ECAP0 interrupt request | pulse |
| ECAP1           | ECAP1_ecap_int_0        | GICSS0_spi_IN_146           | GICSS0      | ECAP1 interrupt request | pulse |

**Table 4-110. ECAP Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description             | Type  |
|-----------------|-------------------------|-----------------------------|-------------|-------------------------|-------|
| ECAP1           | ECAP1_ecap_int_0        | ICSSM0_pr1_slv_intr_IN_3    | ICSSM0      | ECAP1 interrupt request | pulse |
| ECAP1           | ECAP1_ecap_int_0        | TIFS0_nvic_IN_75            | TIFS0       | ECAP1 interrupt request | pulse |
| ECAP1           | ECAP1_ecap_int_0        | HSM0_nvic_IN_75             | HSM0        | ECAP1 interrupt request | pulse |
| ECAP2           | ECAP2_ecap_int_0        | GICSS0_spi_IN_147           | GICSS0      | ECAP2 interrupt request | pulse |
| ECAP2           | ECAP2_ecap_int_0        | ICSSM0_pr1_slv_intr_IN_4    | ICSSM0      | ECAP2 interrupt request | pulse |
| ECAP2           | ECAP2_ecap_int_0        | TIFS0_nvic_IN_76            | TIFS0       | ECAP2 interrupt request | pulse |
| ECAP2           | ECAP2_ecap_int_0        | HSM0_nvic_IN_76             | HSM0        | ECAP2 interrupt request | pulse |

**Table 4-111. ECAP Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                          |
|-----------------|--------------------|----------------|-------------------------|--------------------------------------|
| ECAP0           | FICLK              | MAIN_SYSCLK0/4 |                         | ECAP0 Functional and Interface Clock |
| ECAP1           | FICLK              | MAIN_SYSCLK0/4 |                         | ECAP1 Functional and Interface Clock |
| ECAP2           | FICLK              | MAIN_SYSCLK0/4 |                         | ECAP2 Functional and Interface Clock |

#### 4.10.3 Enhanced Pulse Width Modulation (EPWM)

This section contains the integration details for the EPWM module on this device. For Further information, see the Enhanced Pulse Width Modulation (EPWM) section of the Peripherals chapter

##### 4.10.3.1 EPWM Unsupported Features

The following features are not supported on this family of devices:

- EPWM digital comparators
- Hi Res Extension (Delay Line Based)

##### 4.10.3.2 Module Allocations

**Table 4-112. EPWM Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| EPWM0    |        |     | ✓    |
| EPWM1    |        |     | ✓    |
| EPWM2    |        |     | ✓    |

##### 4.10.3.3 Resets, Interrupts, and Clocks

**Table 4-113. EPWM Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|------------------------|
| EPWM0           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| EPWM1           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| EPWM2           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |

**Table 4-114. EPWM Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| EPWM0           | PSC0_PSC_0 | EPWM0 reset |
| EPWM1           | PSC0_PSC_0 | EPWM1 reset |
| EPWM2           | PSC0_PSC_0 | EPWM2 reset |

**Table 4-115. EPWM Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input  | Destination       | Description             | Type  |
|-----------------|-------------------------|------------------------------|-------------------|-------------------------|-------|
| EPWM0           | EPWM0_epwm_etint_0      | MCU_M4FSS0_COR_E0_nvic_IN_36 | MCU_M4FSS0_COR_E0 | EPWM0 interrupt request | pulse |
| EPWM0           | EPWM0_epwm_etint_0      | GICSS0_spi_IN_229            | GICSS0            | EPWM0 interrupt request | pulse |
| EPWM0           | EPWM0_epwm_etint_0      | ICSSM0_pr1_slv_intr_IN_11    | ICSSM0            | EPWM0 interrupt request | pulse |
| EPWM0           | EPWM0_epwm_etint_0      | TIFS0_nvic_IN_68             | TIFS0             | EPWM0 interrupt request | pulse |

**Table 4-115. EPWM Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input    | Destination            | Description             | Type  |
|-----------------|-------------------------|--------------------------------|------------------------|-------------------------|-------|
| EPWM0           | EPWM0_epwm_etint_0      | HSM0_nvic_IN_68                | HSM0                   | EPWM0 interrupt request | pulse |
| EPWM0           | EPWM0_epwm_sync_o_o_0   | TIMESYNC_EVENT_ROUTER0_in_IN_8 | TIMESYNC_EVENT_ROUTER0 | EPWM0 interrupt request | level |
| EPWM0           | EPWM0_epwm_sync_out_0   | EPWM1_epwm_syncin_IN_0         | EPWM1                  | EPWM0 interrupt request | level |
| EPWM0           | EPWM0_epwm_tripzint_0   | ICSSM0_pr1_slv_intr_IN_24      | ICSSM0                 | EPWM0 interrupt request | pulse |
| EPWM0           | EPWM0_epwm_tripzint_0   | GICSS0_spi_IN_230              | GICSS0                 | EPWM0 interrupt request | pulse |
| EPWM1           | EPWM1_epwm_etint_0      | MCU_M4FSS0_COR_E0_nvic_IN_37   | MCU_M4FSS0_COR_E0      | EPWM1 interrupt request | pulse |
| EPWM1           | EPWM1_epwm_etint_0      | GICSS0_spi_IN_231              | GICSS0                 | EPWM1 interrupt request | pulse |
| EPWM1           | EPWM1_epwm_etint_0      | ICSSM0_pr1_slv_intr_IN_14      | ICSSM0                 | EPWM1 interrupt request | pulse |
| EPWM1           | EPWM1_epwm_etint_0      | TIFS0_nvic_IN_69               | TIFS0                  | EPWM1 interrupt request | pulse |
| EPWM1           | EPWM1_epwm_etint_0      | HSM0_nvic_IN_69                | HSM0                   | EPWM1 interrupt request | pulse |
| EPWM1           | EPWM1_epwm_sync_out_0   | EPWM2_epwm_syncin_IN_0         | EPWM2                  | EPWM1 interrupt request | level |
| EPWM1           | EPWM1_epwm_tripzint_0   | ICSSM0_pr1_slv_intr_IN_24      | ICSSM0                 | EPWM1 interrupt request | pulse |
| EPWM1           | EPWM1_epwm_tripzint_0   | GICSS0_spi_IN_233              | GICSS0                 | EPWM1 interrupt request | pulse |
| EPWM2           | EPWM2_epwm_etint_0      | MCU_M4FSS0_COR_E0_nvic_IN_38   | MCU_M4FSS0_COR_E0      | EPWM2 interrupt request | pulse |
| EPWM2           | EPWM2_epwm_etint_0      | GICSS0_spi_IN_234              | GICSS0                 | EPWM2 interrupt request | pulse |
| EPWM2           | EPWM2_epwm_etint_0      | ICSSM0_pr1_slv_intr_IN_5       | ICSSM0                 | EPWM2 interrupt request | pulse |
| EPWM2           | EPWM2_epwm_etint_0      | TIFS0_nvic_IN_70               | TIFS0                  | EPWM2 interrupt request | pulse |
| EPWM2           | EPWM2_epwm_etint_0      | HSM0_nvic_IN_70                | HSM0                   | EPWM2 interrupt request | pulse |
| EPWM2           | EPWM2_epwm_tripzint_0   | ICSSM0_pr1_slv_intr_IN_24      | ICSSM0                 | EPWM2 interrupt request | pulse |
| EPWM2           | EPWM2_epwm_tripzint_0   | GICSS0_spi_IN_235              | GICSS0                 | EPWM2 interrupt request | pulse |

Table 4-116. EPWM Clocks

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                          |
|-----------------|--------------------|----------------|-------------------------|--------------------------------------|
| EPWM0           | FICLK              | MAIN_SYSCLK0/2 |                         | EPWM0 Functional and Interface Clock |
| EPWM1           | FICLK              | MAIN_SYSCLK0/2 |                         | EPWM1 Functional and Interface Clock |
| EPWM2           | FICLK              | MAIN_SYSCLK0/2 |                         | EPWM2 Functional and Interface Clock |

#### 4.10.4 Enhanced Quadrature Encoder Pulse (EQEP)

This section contains the integration details for the EQEP module on this device. For further information, see the Enhanced Quadrature Encoder Pulse (EQEP) section of the Peripherals chapter

##### 4.10.4.1 EQEP Unsupported Features

The following features are not supported on this family of devices:

- EQEPA\_i[15:1], EQEPB\_i[15:1] are not pinned out.

##### 4.10.4.2 Module Allocations

**Table 4-117. EQEP Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| EQEP0    |        |     | ✓    |
| EQEP1    |        |     | ✓    |
| EQEP2    |        |     | ✓    |

##### 4.10.4.3 Resets, Interrupts, and Clocks

**Table 4-118. EQEP Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|------------------------|
| EQEP0           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| EQEP1           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| EQEP2           | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP  | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |

**Table 4-119. EQEP Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| EQEP0           | PSC0_PSC_0 | EQEP0 reset |
| EQEP1           | PSC0_PSC_0 | EQEP1 reset |
| EQEP2           | PSC0_PSC_0 | EQEP2 reset |

**Table 4-120. EQEP Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description             | Type  |
|-----------------|-------------------------|-----------------------------|-------------|-------------------------|-------|
| EQEP0           | EQEP0_eqep_int_0        | GICSS0_spi_IN_148           | GICSS0      | EQEP0 interrupt request | pulse |
| EQEP0           | EQEP0_eqep_int_0        | ICSSM0_pr1_slv_intr_IN_13   | ICSSM0      | EQEP0 interrupt request | pulse |
| EQEP0           | EQEP0_eqep_int_0        | TIFS0_nvic_IN_71            | TIFS0       | EQEP0 interrupt request | pulse |
| EQEP0           | EQEP0_eqep_int_0        | HSM0_nvic_IN_71             | HSM0        | EQEP0 interrupt request | pulse |
| EQEP1           | EQEP1_eqep_int_0        | GICSS0_spi_IN_149           | GICSS0      | EQEP1 interrupt request | pulse |

**Table 4-120. EQEP Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description             | Type  |
|-----------------|-------------------------|-----------------------------|-------------|-------------------------|-------|
| EQEP1           | EQEP1_eqep_int_0        | ICSSM0_pr1_slv_intr_IN_16   | ICSSM0      | EQEP1 interrupt request | pulse |
| EQEP1           | EQEP1_eqep_int_0        | TIFS0_nvic_IN_72            | TIFS0       | EQEP1 interrupt request | pulse |
| EQEP1           | EQEP1_eqep_int_0        | HSM0_nvic_IN_72             | HSM0        | EQEP1 interrupt request | pulse |
| EQEP2           | EQEP2_eqep_int_0        | GICSS0_spi_IN_150           | GICSS0      | EQEP2 interrupt request | pulse |
| EQEP2           | EQEP2_eqep_int_0        | ICSSM0_pr1_slv_intr_IN_17   | ICSSM0      | EQEP2 interrupt request | pulse |
| EQEP2           | EQEP2_eqep_int_0        | TIFS0_nvic_IN_73            | TIFS0       | EQEP2 interrupt request | pulse |
| EQEP2           | EQEP2_eqep_int_0        | HSM0_nvic_IN_73             | HSM0        | EQEP2 interrupt request | pulse |

**Table 4-121. EQEP Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                          |
|-----------------|--------------------|----------------|-------------------------|--------------------------------------|
| EQEP0           | FICLK              | MAIN_SYSCLK0/4 |                         | EQEP0 Functional and Interface Clock |
| EQEP1           | FICLK              | MAIN_SYSCLK0/4 |                         | EQEP1 Functional and Interface Clock |
| EQEP2           | FICLK              | MAIN_SYSCLK0/4 |                         | EQEP2 Functional and Interface Clock |

## 4.11 Camera Subsystem

### 4.11.1 Camera Serial Interface Receiver (CSI\_RX\_IF)

This section contains the integration details for the CSI\_RX\_IF module on this device. For further information, see the Camera Serial Interface Receiver (CSI\_RX\_IF) section of the Peripherals chapter.

#### 4.11.1.1 CSI\_RX\_IF Unsupported Features

The following features are not supported on this family of devices:

- Line Count Error Interrupt (Streams 1-3)
- Frame Mismatch Error Interrupt (Streams 1-3)
- Frame Count Error Interrupt (Streams 1-3)
- FCC Stop Interrupt (Streams 1-3)
- FCC Start Interrupt (Streams 1-3)
- Line/Byte Interrupt (Streams 1-3)
- Timer / Timer Interrupt (Streams 1-3)
- VID32 Streams to VPAC, no VPAC available
- PPI Retransmission, No Transmit interface available

#### 4.11.1.2 Module Allocations

**Table 4-122. CSI\_RX\_IF Modules Allocation within Device Domains**

| Instance   | Domain |     |      |
|------------|--------|-----|------|
|            | WKUP   | MCU | Main |
| csi_rx_if0 |        |     | ✓    |

#### 4.11.1.3 Resets, Interrupts, and Clocks

**Table 4-123. CSI\_RX\_IF Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|-------------|
| CSI_RX_IF0      | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_CSI_RX_0 | 25    | OFF     | YES          | LPSC_DPHY_0 |

**Table 4-124. CSI\_RX\_IF Resets**

| Module Instance | Source     | Description      |
|-----------------|------------|------------------|
| CSI_RX_IF0      | PSC0_PSC_0 | CSI_RX_IF0 reset |

**Table 4-125. CSI\_RX\_IF Hardware Requests**

| Module Instance | Module Interrupt Signal  | Destination Interrupt Input | Destination | Description                  | Type  |
|-----------------|--------------------------|-----------------------------|-------------|------------------------------|-------|
| CSI_RX_IF0      | CSI_RX_IF0_csi_err_irq_0 | ESM0_esm_lvl_event_IN_0     | ESM0        | CSI_RX_IF0 interrupt request | level |
| CSI_RX_IF0      | CSI_RX_IF0_csi_err_irq_0 | GICSS0_spi_IN_175           | GICSS0      | CSI_RX_IF0 interrupt request | level |
| CSI_RX_IF0      | CSI_RX_IF0_csi_fatal_0   | ESM0_esm_lvl_event_IN_70    | ESM0        | CSI_RX_IF0 interrupt request | level |
| CSI_RX_IF0      | CSI_RX_IF0_csi_irq_0     | GICSS0_spi_IN_173           | GICSS0      | CSI_RX_IF0 interrupt request | level |
| CSI_RX_IF0      | CSI_RX_IF0_csi_level_0   | ESM0_esm_lvl_event_IN_72    | ESM0        | CSI_RX_IF0 interrupt request | level |

**Table 4-125. CSI\_RX\_IF Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal    | Destination Interrupt Input | Destination | Description                  | Type  |
|-----------------|----------------------------|-----------------------------|-------------|------------------------------|-------|
| CSI_RX_IF0      | CSI_RX_IF0_csi_level_0     | GICSS0_spi_IN_174           | GICSS0      | CSI_RX_IF0 interrupt request | level |
| CSI_RX_IF0      | CSI_RX_IF0_csi_non_fatal_0 | ESM0_esm_lv_event_IN_71     | ESM0        | CSI_RX_IF0 interrupt request | level |

**Table 4-126. CSI\_RX\_IF Clocks**

| Module Instance | Module Clock Input | Source Clock Signal | Description |  |
|-----------------|--------------------|---------------------|-------------|--|
| CSI_RX_IF0      | MAIN_CLK_CLK       | MAIN_SYSCLK0        |             |  |
|                 | VBUS_CLK_CLK       | MAIN_SYSCLK0/2      |             |  |
|                 | VP_CLK_CLK         | MAIN_SYSCLK0        |             |  |

#### 4.11.2 MIPI D-PHY Receiver (DPHY\_RX)

This section contains the integration details for the DPHY\_RX module on this device. For further information, see the MIPI D-PHY Receiver (DPHY\_RX) section of the Peripherals chapter

##### 4.11.2.1 DPHY4RX Unsupported Features

The following features are not supported on this family of devices:

- Swapping of Clock & Data Lanes

##### 4.11.2.2 Module Allocations

**Table 4-127. DPHY\_RX Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| DPHY_RX0 |        |     | ✓    |

##### 4.11.2.3 Resets, Interrupts, and Clocks

**Table 4-128. DPHY\_RX Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------|
| DPHY_RX0        | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_DPHY_0   | 26    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-129. DPHY\_RX Resets**

| Module Instance | Source     | Description    |
|-----------------|------------|----------------|
| DPHY_RX0        | PSC0_PSC_0 | DPHY_RX0 reset |

**Table 4-130. DPHY\_RX Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description | Type |
|-----------------|-------------------------|-----------------------------|-------------|-------------|------|
| DPHY_RX0        |                         |                             |             |             |      |

**Table 4-131. DPHY\_RX Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description |
|-----------------|--------------------|----------------|-------------------------|-------------|
| DPHY_RX0        | MAIN_CLK_CLK       | MAIN_SYSCLK0/4 |                         |             |

## 4.12 Timer Modules

### 4.12.1 Global Timebase Counter (GTC)

This section contains the integration details for the GTC module on this device. For further information, see the Global Timebase Counter (GTC) section of the Peripherals chapter

#### 4.12.1.1 GTC Unsupported Features

The following features are not supported on this family of devices:

- There are no unsupported features

#### 4.12.1.2 Module Allocations

**Table 4-132. GTC Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| WKUP_GTC0 | ✓      |     |      |

#### 4.12.1.3 Resets, Interrupts, and Clocks

**Table 4-133. GTC Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain      | Index | Default | Controllable | dependences |
|-----------------|------------------------|--------------|--------------------|-------|---------|--------------|-------------|
| WKUP_GTC0       | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |

**Table 4-134. GTC Resets**

| Module Instance | Source     | Description     |
|-----------------|------------|-----------------|
| WKUP_GTC0       | PSC0_PSC_0 | WKUP_GTC0 reset |
| WKUP_GTC0       | PLLCTRL0   | WKUP_GTC0 reset |

**Table 4-135. GTC Hardware Requests**

| Module Instance | Module Interrupt Signal     | Destination Interrupt Input     | Destination            | Description                 | Type  |
|-----------------|-----------------------------|---------------------------------|------------------------|-----------------------------|-------|
| WKUP_GTC0       | WKUP_GTC0_gtc_pu_sh_event_0 | TIMESYNC_EVENT_ROUTER0_in_IN_11 | TIMESYNC_EVENT_ROUTER0 | WKUP_GTC0 interrupt request | pulse |

**Table 4-136. GTC Clocks**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register        | Description                   |
|-----------------|--------------------|-----------------------------|--------------------------------|-------------------------------|
| WKUP_GTC0       | CLK                | MAIN_PLL2_HSDIV5_CL<br>KOUT | WKUP_GTC_CLKSEL[2:0]<br>]<br>] | WKUP_GTC0 Functional<br>Clock |
|                 |                    | MAIN_PLL0_HSDIV6_CL<br>KOUT | WKUP_GTC_CLKSEL[2:0]<br>]<br>] |                               |
|                 |                    | CP_GEMAC_CPTS_REF<br>_CLK   | WKUP_GTC_CLKSEL[2:0]<br>]<br>] |                               |
|                 |                    | MCU_EXT_REFCLK0             | WKUP_GTC_CLKSEL[2:0]<br>]<br>] |                               |
|                 |                    | EXT_REFCLK1                 | WKUP_GTC_CLKSEL[2:0]<br>]<br>] |                               |
|                 |                    | MCU_SYSCLK0                 | WKUP_GTC_CLKSEL[2:0]<br>]<br>] |                               |
|                 |                    | MAIN_SYSCLK0                | WKUP_GTC_CLKSEL[2:0]<br>]<br>] |                               |
|                 | ICLK               | DM_CLK/4                    | WKUP_CLKSEL[0:0]               | WKUP_GTC0 Interface<br>Clock  |

#### 4.12.2 Real Time Interrupt (RTI)

This section contains the integration details for the RTI module on this device. For Further information, see the Real Time Interrupt (RTI) section of the Peripherals chapter

##### 4.12.2.1 RTI Unsupported Features

The following features are not supported on this family of devices:

- Analog watchdog timer
- External clock supervision
- Periodic Interrupt
- Timestamp (Capture Registers)

##### 4.12.2.2 Module Allocations

**Table 4-137. RTI Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| RTI4      |        |     | ✓    |
| RTI0      |        |     | ✓    |
| RTI1      |        |     | ✓    |
| RTI2      |        |     | ✓    |
| RTI3      |        |     | ✓    |
| MCU_RTI0  |        | ✓   |      |
| WKUP_RTI0 | ✓      |     |      |

##### 4.12.2.3 Resets, Interrupts, and Clocks

**Table 4-138. RTI Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences        |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------------|
| MCU_RTI0        | WKUP_PSC0              | PD_M4F       | LPSC MCU_M 4F | 6     | OFF     | YES          | LPSC MCU COMMON    |
| RTI0            | PSC0_PSC_0             | PD_A53_0     | LPSC_A53_0    | 45    | OFF     | YES          | LPSC_A53_CLOCKER_0 |
| RTI1            | PSC0_PSC_0             | PD_A53_1     | LPSC_A53_1    | 46    | OFF     | YES          | LPSC_A53_CLOCKER_0 |
| RTI15           | PSC0_PSC_0             | PD_GPU       | LPSC_GPU      | 49    | OFF     | YES          | LPSC_MAIN_IP       |
| RTI2            | PSC0_PSC_0             | PD_A53_2     | LPSC_A53_2    | 47    | OFF     | YES          | LPSC_A53_CLOCKER_0 |
| RTI3            | PSC0_PSC_0             | PD_A53_3     | LPSC_A53_3    | 48    | OFF     | YES          | LPSC_A53_CLOCKER_0 |
| WKUP_RTI0       | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_DM  | 1     | OFF     | YES          | LPSC_MAIN_ALWAYSON |

**Table 4-139. RTI Resets**

| Module Instance | Source     | Description    |
|-----------------|------------|----------------|
| MCU_RTI0        | WKUP_PSC0  | MCU_RTI0 reset |
| RTI0            | PSC0_PSC_0 | RTI0 reset     |

**Table 4-139. RTI Resets (continued)**

| Module Instance | Source     | Description     |
|-----------------|------------|-----------------|
| RTI1            | PSC0_PSC_0 | RTI1 reset      |
| RTI15           | PSC0_PSC_0 | RTI15 reset     |
| RTI2            | PSC0_PSC_0 | RTI2 reset      |
| RTI3            | PSC0_PSC_0 | RTI3 reset      |
| WKUP_RTI0       | PSC0_PSC_0 | WKUP_RTI0 reset |

**Table 4-140. RTI Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input     | Destination       | Description                | Type  |
|-----------------|-------------------------|---------------------------------|-------------------|----------------------------|-------|
| MCU_RTI0        | MCU_RTI0_intr_wwd_0     | MCU_M4FSS0_COR_E0_nvic_IN_19    | MCU_M4FSS0_COR_E0 | MCU_RTI0 interrupt request | pulse |
| MCU_RTI0        | MCU_RTI0_intr_wwd_0     | WKUP_ESM0_esm_p_ls_event0_IN_85 | WKUP_ESM0         | MCU_RTI0 interrupt request | pulse |
| MCU_RTI0        | MCU_RTI0_intr_wwd_0     | WKUP_ESM0_esm_p_ls_event1_IN_85 | WKUP_ESM0         | MCU_RTI0 interrupt request | pulse |
| MCU_RTI0        | MCU_RTI0_intr_wwd_0     | WKUP_ESM0_esm_p_ls_event2_IN_85 | WKUP_ESM0         | MCU_RTI0 interrupt request | pulse |
| RTI0            | RTI0_intr_wwd_0         | ESM0_esm_pls_even_t0_IN_160     | ESM0              | RTI0 interrupt request     | pulse |
| RTI0            | RTI0_intr_wwd_0         | ESM0_esm_pls_even_t1_IN_160     | ESM0              | RTI0 interrupt request     | pulse |
| RTI0            | RTI0_intr_wwd_0         | ESM0_esm_pls_even_t2_IN_160     | ESM0              | RTI0 interrupt request     | pulse |
| RTI0            | RTI0_intr_wwd_0         | GICSS0_spi_IN_252               | GICSS0            | RTI0 interrupt request     | pulse |
| RTI1            | RTI1_intr_wwd_0         | ESM0_esm_pls_even_t0_IN_161     | ESM0              | RTI1 interrupt request     | pulse |
| RTI1            | RTI1_intr_wwd_0         | ESM0_esm_pls_even_t1_IN_161     | ESM0              | RTI1 interrupt request     | pulse |
| RTI1            | RTI1_intr_wwd_0         | ESM0_esm_pls_even_t2_IN_161     | ESM0              | RTI1 interrupt request     | pulse |
| RTI1            | RTI1_intr_wwd_0         | GICSS0_spi_IN_253               | GICSS0            | RTI1 interrupt request     | pulse |
| RTI15           | RTI15_intr_wwd_0        | ESM0_esm_pls_even_t0_IN_162     | ESM0              | RTI15 interrupt request    | pulse |
| RTI15           | RTI15_intr_wwd_0        | ESM0_esm_pls_even_t1_IN_162     | ESM0              | RTI15 interrupt request    | pulse |
| RTI15           | RTI15_intr_wwd_0        | ESM0_esm_pls_even_t2_IN_162     | ESM0              | RTI15 interrupt request    | pulse |
| RTI15           | RTI15_intr_wwd_0        | GICSS0_spi_IN_178               | GICSS0            | RTI15 interrupt request    | pulse |
| RTI2            | RTI2_intr_wwd_0         | ESM0_esm_pls_even_t0_IN_177     | ESM0              | RTI2 interrupt request     | pulse |
| RTI2            | RTI2_intr_wwd_0         | ESM0_esm_pls_even_t1_IN_177     | ESM0              | RTI2 interrupt request     | pulse |

Table 4-140. RTI Hardware Requests (continued)

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description                 | Type  |
|-----------------|-------------------------|-----------------------------|--------------|-----------------------------|-------|
| RTI2            | RTI2_intr_wwd_0         | ESM0_esm_pls_even t2_IN_177 | ESM0         | RTI2 interrupt request      | pulse |
| RTI2            | RTI2_intr_wwd_0         | GICSS0_spi_IN_254           | GICSS0       | RTI2 interrupt request      | pulse |
| RTI3            | RTI3_intr_wwd_0         | ESM0_esm_pls_even t0_IN_178 | ESM0         | RTI3 interrupt request      | pulse |
| RTI3            | RTI3_intr_wwd_0         | ESM0_esm_pls_even t1_IN_178 | ESM0         | RTI3 interrupt request      | pulse |
| RTI3            | RTI3_intr_wwd_0         | ESM0_esm_pls_even t2_IN_178 | ESM0         | RTI3 interrupt request      | pulse |
| RTI3            | RTI3_intr_wwd_0         | GICSS0_spi_IN_255           | GICSS0       | RTI3 interrupt request      | pulse |
| WKUP_RTI0       | WKUP_RTI0_intr_wwd_0    | ESM0_esm_pls_even t0_IN_163 | ESM0         | WKUP_RTI0 interrupt request | pulse |
| WKUP_RTI0       | WKUP_RTI0_intr_wwd_0    | ESM0_esm_pls_even t1_IN_163 | ESM0         | WKUP_RTI0 interrupt request | pulse |
| WKUP_RTI0       | WKUP_RTI0_intr_wwd_0    | ESM0_esm_pls_even t2_IN_163 | ESM0         | WKUP_RTI0 interrupt request | pulse |
| WKUP_RTI0       | WKUP_RTI0_intr_wwd_0    | R5FSS0_CORE0_intr_IN_30     | R5FSS0_CORE0 | WKUP_RTI0 interrupt request | pulse |

Table 4-141. RTI Clocks

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description               |
|-----------------|--------------------|-----------------------------|-------------------------|---------------------------|
| MCU_RTI0        | FCLK               | HFOSC0_CLKOUT               | MCU_WWD0_CLKSEL[1:0]    | MCU_RTI0 Functional Clock |
|                 |                    | DEVICE_CLKOUT_32K           | MCU_WWD0_CLKSEL[1:0]    |                           |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] |                         |                           |
|                 |                    | CLK_12M_RC                  | MCU_WWD0_CLKSEL[1:0]    |                           |
|                 |                    | CLK_32K_RC                  | MCU_WWD0_CLKSEL[1:0]    |                           |
| RTI0            | FCLK               | ICLK                        | MCU_SYSCLK0/4           | MCU_RTI0 Interface Clock  |
|                 |                    | HFOSC0_CLKOUT               | WWDO_CLKSEL[1:0]        | RTI0 Functional Clock     |
|                 |                    | DEVICE_CLKOUT_32K           | WWDO_CLKSEL[1:0]        |                           |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] |                         |                           |
|                 |                    | CLK_12M_RC                  | WWDO_CLKSEL[1:0]        |                           |
|                 |                    | CLK_32K_RC                  | WWDO_CLKSEL[1:0]        | RTI0 Interface Clock      |
|                 |                    | ICLK                        | MAIN_SYSCLK0/4          |                           |

**Table 4-141. RTI Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description                |
|-----------------|--------------------|-----------------------------|-------------------------|----------------------------|
| RTI1            | FCLK               | HFOSC0_CLKOUT               | WWD1_CLKSEL[1:0]        | RTI1 Functional Clock      |
|                 |                    | DEVICE_CLKOUT_32K           | WWD1_CLKSEL[1:0]        |                            |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | WWD1_CLKSEL[1:0]        |                            |
|                 |                    | CLK_12M_RC                  | WWD1_CLKSEL[1:0]        | RTI1 Interface Clock       |
|                 |                    | CLK_32K_RC                  | WWD1_CLKSEL[1:0]        |                            |
|                 | ICLK               | MAIN_SYSCLK0/4              |                         | RTI1 Interface Clock       |
| RTI15           | FCLK               | HFOSC0_CLKOUT               | WWD15_CLKSEL[1:0]       | RTI15 Functional Clock     |
|                 |                    | DEVICE_CLKOUT_32K           | WWD15_CLKSEL[1:0]       |                            |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | WWD15_CLKSEL[1:0]       |                            |
|                 |                    | CLK_12M_RC                  | WWD15_CLKSEL[1:0]       | RTI15 Interface Clock      |
|                 |                    | CLK_32K_RC                  | WWD15_CLKSEL[1:0]       |                            |
|                 | ICLK               | MAIN_SYSCLK0/4              |                         | RTI15 Interface Clock      |
| RTI2            | FCLK               | HFOSC0_CLKOUT               | WWD2_CLKSEL[1:0]        | RTI2 Functional Clock      |
|                 |                    | DEVICE_CLKOUT_32K           | WWD2_CLKSEL[1:0]        |                            |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | WWD2_CLKSEL[1:0]        |                            |
|                 |                    | CLK_12M_RC                  | WWD2_CLKSEL[1:0]        | RTI2 Interface Clock       |
|                 |                    | CLK_32K_RC                  | WWD2_CLKSEL[1:0]        |                            |
|                 | ICLK               | MAIN_SYSCLK0/4              |                         | RTI2 Interface Clock       |
| RTI3            | FCLK               | HFOSC0_CLKOUT               | WWD3_CLKSEL[1:0]        | RTI3 Functional Clock      |
|                 |                    | DEVICE_CLKOUT_32K           | WWD3_CLKSEL[1:0]        |                            |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | WWD3_CLKSEL[1:0]        |                            |
|                 |                    | CLK_12M_RC                  | WWD3_CLKSEL[1:0]        | RTI3 Interface Clock       |
|                 |                    | CLK_32K_RC                  | WWD3_CLKSEL[1:0]        |                            |
|                 | ICLK               | MAIN_SYSCLK0/4              |                         | RTI3 Interface Clock       |
| WKUP_RTI0       | FCLK               | HFOSC0_CLKOUT               | WKUP_WWD0_CLKSEL[1:0]   | WKUP_RTI0 Functional Clock |
|                 |                    | DEVICE_CLKOUT_32K           | WKUP_WWD0_CLKSEL[1:0]   |                            |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | WKUP_WWD0_CLKSEL[1:0]   |                            |
|                 |                    | CLK_12M_RC                  | WKUP_WWD0_CLKSEL[1:0]   | WKUP_RTI0 Interface Clock  |
|                 |                    | CLK_32K_RC                  | WKUP_WWD0_CLKSEL[1:0]   |                            |
|                 | ICLK               | DM_CLK/4                    | WKUP_CLKSEL[0:0]        | WKUP_RTI0 Interface Clock  |

#### 4.12.3 Real-Time Clock (RTC)

This section contains the integration details for the RTC module on this device. For Further information, see the Real-Time Clock (RTC) section of the Peripherals chapter

##### 4.12.3.1 RTC Unsupported Features

The following features are not supported on this family of devices:

- PMIC enable support

##### 4.12.3.2 Module Allocations

**Table 4-142. RTC Modules Allocation within Device Domains**

| Instance    | Domain |     |      |
|-------------|--------|-----|------|
|             | WKUP   | MCU | Main |
| WKUP_rtcss0 | ✓      |     |      |

##### 4.12.3.3 Resets, Interrupts, and Clocks

**Table 4-143. RTC Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain      | Index | Default | Controllable | dependences |
|-----------------|------------------------|--------------|--------------------|-------|---------|--------------|-------------|
| WKUP_RTCSS0     | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |

**Table 4-144. RTC Resets**

| Module Instance | Source     | Description       |
|-----------------|------------|-------------------|
| WKUP_rtcss0     | PSC0_PSC_0 | WKUP_rtcss0 reset |

**Table 4-145. RTC Hardware Requests**

| Module Instance | Module Interrupt Signal      | Destination Interrupt Input                                     | Destination             | Description                   | Type  |
|-----------------|------------------------------|-----------------------------------------------------------------|-------------------------|-------------------------------|-------|
| WKUP_rtcss0     | WKUP_rtcss0_rtc_event_pend_0 | GICSS0_spi_IN_132                                               | GICSS0                  | WKUP_rtcss0 interrupt request | level |
| WKUP_rtcss0     | WKUP_rtcss0_rtc_event_pend_0 | R5FSS0_CORE0_intr_IN_97                                         | R5FSS0_CORE0            | WKUP_rtcss0 interrupt request | level |
| WKUP_rtcss0     | WKUP_rtcss0_rtc_event_pend_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_7 | WKUP_DEEPSLEEP_SOURCES0 | WKUP_rtcss0 interrupt request | level |

**Table 4-146. RTC Clocks**

| Module Instance | Module Clock Input | Source Clock      | Source Control Register     | Description |
|-----------------|--------------------|-------------------|-----------------------------|-------------|
| WKUP_rtcss0     | ANA_OSC32K_CLK     | DEVICE_CLKOUT_32K | WKUP_RTC_CLKSEL[0:1]        |             |
|                 |                    |                   | DEVICE_CLKOUT_32K_CTRL[1:0] |             |
|                 | VCLK_CLK           | CLK_32K_RC        | WKUP_RTC_CLKSEL[0:0]        |             |
|                 |                    | DM_CLK/8          | WKUP_CLKSEL[0:0]            |             |

#### 4.12.4 Timer

This section contains the integration details for the Timer module on this device. For Further information, see the Timer section of the Peripherals chapter

##### 4.12.4.1 Timer Unsupported Features

The following features are not supported on this family of devices:

- Cascading of timer instances is not supported.

##### 4.12.4.2 Module Allocations

**Table 4-147. Timer Modules Allocation within Device Domains**

| Instance    | Domain |     |      |
|-------------|--------|-----|------|
|             | WKUP   | MCU | Main |
| TIMER0      |        |     | ✓    |
| TIMER1      |        |     | ✓    |
| TIMER2      |        |     | ✓    |
| TIMER3      |        |     | ✓    |
| TIMER4      |        |     | ✓    |
| TIMER5      |        |     | ✓    |
| TIMER6      |        |     | ✓    |
| TIMER7      |        |     | ✓    |
| MCU_TIMER0  |        | ✓   |      |
| MCU_TIMER1  |        | ✓   |      |
| MCU_TIMER2  |        | ✓   |      |
| MCU_TIMER3  |        | ✓   |      |
| WKUP_TIMER0 | ✓      |     |      |
| WKUP_TIMER1 | ✓      |     |      |

##### 4.12.4.3 Resets, Interrupts, and Clocks

**Table 4-148. Timer Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain    | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|------------------|-------|---------|--------------|------------------------|
| MCU_TIMER0      | WKUP_PSC0              | PD_M4F       | LPSC MCU_C_OMMON | 9     | ON      | YES          | LPSC_DM2SAF_E_ISO      |
| MCU_TIMER1      | WKUP_PSC0              | PD_M4F       | LPSC MCU_C_OMMON | 9     | ON      | YES          | LPSC_DM2SAF_E_ISO      |
| MCU_TIMER2      | WKUP_PSC0              | PD_M4F       | LPSC MCU_C_OMMON | 9     | ON      | YES          | LPSC_DM2SAF_E_ISO      |
| MCU_TIMER3      | WKUP_PSC0              | PD_M4F       | LPSC MCU_C_OMMON | 9     | ON      | YES          | LPSC_DM2SAF_E_ISO      |
| TIMER0          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP     | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| TIMER1          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP     | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |

**Table 4-148. Timer Integration Attributes (continued)**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain      | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|--------------------|-------|---------|--------------|------------------------|
| TIMER2          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| TIMER3          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| TIMER4          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| TIMER5          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| TIMER6          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| TIMER7          | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP       | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| WKUP_TIMER0     | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE                   |
| WKUP_TIMER1     | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE                   |

**Table 4-149. Timer Resets**

| Module Instance | Source     | Description       |
|-----------------|------------|-------------------|
| TIMER0          | PSC0_PSC_0 | TIMER0 reset      |
| TIMER1          | PSC0_PSC_0 | TIMER1 reset      |
| TIMER2          | PSC0_PSC_0 | TIMER2 reset      |
| TIMER3          | PSC0_PSC_0 | TIMER3 reset      |
| TIMER4          | PSC0_PSC_0 | TIMER4 reset      |
| TIMER5          | PSC0_PSC_0 | TIMER5 reset      |
| TIMER6          | PSC0_PSC_0 | TIMER6 reset      |
| TIMER7          | PSC0_PSC_0 | TIMER7 reset      |
| MCU_TIMER0      | WKUP_PSC0  | MCU_TIMER0 reset  |
| MCU_TIMER1      | WKUP_PSC0  | MCU_TIMER1 reset  |
| MCU_TIMER2      | WKUP_PSC0  | MCU_TIMER2 reset  |
| MCU_TIMER3      | WKUP_PSC0  | MCU_TIMER3 reset  |
| WKUP_TIMER0     | PSC0_PSC_0 | WKUP_TIMER0 reset |
| WKUP_TIMER1     | PSC0_PSC_0 | WKUP_TIMER1 reset |

**Table 4-150. Timer Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination       | Description                  | Type  |
|-----------------|-------------------------|-----------------------------|-------------------|------------------------------|-------|
| MCU_TIMER0      | MCU_TIMER0_intr_pend_0  | MCU_M4FSS0_COR_E0_nvic_IN_4 | MCU_M4FSS0_COR_E0 | MCU_TIMER0 interrupt request | level |
| MCU_TIMER1      | MCU_TIMER1_intr_pend_0  | MCU_M4FSS0_COR_E0_nvic_IN_5 | MCU_M4FSS0_COR_E0 | MCU_TIMER1 interrupt request | level |

**Table 4-150. Timer Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal             | Destination Interrupt Input                                     | Destination             | Description                   | Type  |
|-----------------|-------------------------------------|-----------------------------------------------------------------|-------------------------|-------------------------------|-------|
| MCU_TIMER2      | MCU_TIMER2_intr_pend_0              | MCU_M4FSS0_COR_E0_nvic_IN_6                                     | MCU_M4FSS0_COR_E0       | MCU_TIMER2 interrupt request  | level |
| MCU_TIMER3      | MCU_TIMER3_intr_pend_0              | MCU_M4FSS0_COR_E0_nvic_IN_7                                     | MCU_M4FSS0_COR_E0       | MCU_TIMER3 interrupt request  | level |
| TIMER0          | TIMER0_intr_pend_0                  | GICSS0_spi_IN_152                                               | GICSS0                  | TIMER0 interrupt request      | level |
| TIMER0          | TIMER0_timer_pwm_0                  | TIMESYNC_EVENT_ROUTER0_in_IN_0                                  | TIMESYNC_EVENT_ROUTER0  | TIMER0 interrupt request      | pulse |
| TIMER1          | TIMER1_intr_pend_0                  | GICSS0_spi_IN_153                                               | GICSS0                  | TIMER1 interrupt request      | level |
| TIMER1          | TIMER1_timer_pwm_0                  | TIMESYNC_EVENT_ROUTER0_in_IN_1                                  | TIMESYNC_EVENT_ROUTER0  | TIMER1 interrupt request      | pulse |
| TIMER2          | TIMER2_intr_pend_0                  | GICSS0_spi_IN_154                                               | GICSS0                  | TIMER2 interrupt request      | level |
| TIMER2          | TIMER2_timer_pwm_0                  | TIMESYNC_EVENT_ROUTER0_in_IN_2                                  | TIMESYNC_EVENT_ROUTER0  | TIMER2 interrupt request      | pulse |
| TIMER3          | TIMER3_intr_pend_0                  | GICSS0_spi_IN_155                                               | GICSS0                  | TIMER3 interrupt request      | level |
| TIMER3          | TIMER3_timer_pwm_0                  | TIMESYNC_EVENT_ROUTER0_in_IN_3                                  | TIMESYNC_EVENT_ROUTER0  | TIMER3 interrupt request      | pulse |
| TIMER4          | TIMER4_intr_pend_0                  | GICSS0_spi_IN_156                                               | GICSS0                  | TIMER4 interrupt request      | level |
| TIMER5          | TIMER5_intr_pend_0                  | GICSS0_spi_IN_157                                               | GICSS0                  | TIMER5 interrupt request      | level |
| TIMER6          | TIMER6_intr_pend_0                  | GICSS0_spi_IN_158                                               | GICSS0                  | TIMER6 interrupt request      | level |
| TIMER7          | TIMER7_intr_pend_0                  | GICSS0_spi_IN_159                                               | GICSS0                  | TIMER7 interrupt request      | level |
| WKUP_TIMER0     | WKUP_TIMER0_intr_pend_0             | R5FSS0_CORE0_intr_IN_138                                        | R5FSS0_CORE0            | WKUP_TIMER0 interrupt request | level |
| WKUP_TIMER0     | WKUP_TIMER0_time_r_clkstop_wakeup_0 | R5FSS0_CORE0_intr_IN_28                                         | R5FSS0_CORE0            | WKUP_TIMER0 interrupt request | level |
| WKUP_TIMER0     | WKUP_TIMER0_time_r_clkstop_wakeup_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_5 | WKUP_DEEPSLEEP_SOURCES0 | WKUP_TIMER0 interrupt request | level |
| WKUP_TIMER1     | WKUP_TIMER1_intr_pend_0             | R5FSS0_CORE0_intr_IN_139                                        | R5FSS0_CORE0            | WKUP_TIMER1 interrupt request | level |
| WKUP_TIMER1     | WKUP_TIMER1_time_r_clkstop_wakeup_0 | R5FSS0_CORE0_intr_IN_29                                         | R5FSS0_CORE0            | WKUP_TIMER1 interrupt request | level |

**Table 4-150. Timer Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal             | Destination Interrupt Input                                     | Destination             | Description                   | Type  |
|-----------------|-------------------------------------|-----------------------------------------------------------------|-------------------------|-------------------------------|-------|
| WKUP_TIMER1     | WKUP_TIMER1_time_r_clkstop_wakeup_0 | WKUP_DEEPSLEEP_SOURCES0_lsam62_dm_wakeup_deepsleep_sources_IN_6 | WKUP_DEEPSLEEP_SOURCES0 | WKUP_TIMER1 interrupt request | level |

**Table 4-151. Timer Clocks**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description                 |
|-----------------|--------------------|-----------------------------|-------------------------|-----------------------------|
| MCU_TIMER0      | TIMER_FCLK         | TIMER_ICLK                  | MCU_SYSCLK0/4           | MCU_TIMER0 Interface Clock  |
|                 |                    | HFOSC0_CLKOUT               | MCU_TIMER0_CLKSEL[2:0]  | MCU_TIMER0 Functional Clock |
|                 |                    | MCU_SYSCLK0/2               | MCU_TIMER0_CLKSEL[2:0]  |                             |
|                 |                    | CLK_12M_RC                  | MCU_TIMER0_CLKSEL[2:0]  |                             |
|                 |                    | MCU_PLL0_HSDIV3_CLKOUT      | MCU_TIMER0_CLKSEL[2:0]  |                             |
|                 |                    | MCU_EXT_REFCLK0             | MCU_TIMER0_CLKSEL[2:0]  |                             |
|                 |                    | DEVICE_CLKOUT_32K           | MCU_TIMER0_CLKSEL[2:0]  |                             |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] |                         |                             |
|                 |                    | CPSW0.CPTS_GENF0            | MCU_TIMER0_CLKSEL[2:0]  |                             |
|                 |                    | CLK_32K_RC                  | MCU_TIMER0_CLKSEL[2:0]  |                             |

**Table 4-151. Timer Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description                 |
|-----------------|--------------------|-----------------------------|-------------------------|-----------------------------|
| MCU_TIMER1      | TIMER_FCLK         | TIMER_ICLK                  | MCU_SYSCLK0/4           | MCU_TIMER1 Interface Clock  |
|                 |                    | HFOSC0_CLKOUT               | MCU_TIMER1_CLKSEL[2:0]  | MCU_TIMER1 Functional Clock |
|                 |                    | MCU_SYSCLK0/2               | MCU_TIMER1_CLKSEL[2:0]  |                             |
|                 |                    | CLK_12M_RC                  | MCU_TIMER1_CLKSEL[2:0]  |                             |
|                 |                    | MCU_PLL0_HSDIV3_CLKOUT      | MCU_TIMER1_CLKSEL[2:0]  |                             |
|                 |                    | MCU_EXT_REFCLK0             | MCU_TIMER1_CLKSEL[2:0]  |                             |
|                 |                    | DEVICE_CLKOUT_32K           | MCU_TIMER1_CLKSEL[2:0]  |                             |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] |                         |                             |
|                 |                    | CPSW0.CPTS_GENF0            | MCU_TIMER1_CLKSEL[2:0]  |                             |
|                 |                    | CLK_32K_RC                  | MCU_TIMER1_CLKSEL[2:0]  |                             |
| MCU_TIMER2      | TIMER_FCLK         | TIMER_ICLK                  | MCU_SYSCLK0/4           | MCU_TIMER2 Interface Clock  |
|                 |                    | HFOSC0_CLKOUT               | MCU_TIMER2_CLKSEL[2:0]  | MCU_TIMER2 Functional Clock |
|                 |                    | MCU_SYSCLK0/2               | MCU_TIMER2_CLKSEL[2:0]  |                             |
|                 |                    | CLK_12M_RC                  | MCU_TIMER2_CLKSEL[2:0]  |                             |
|                 |                    | MCU_PLL0_HSDIV3_CLKOUT      | MCU_TIMER2_CLKSEL[2:0]  |                             |
|                 |                    | MCU_EXT_REFCLK0             | MCU_TIMER2_CLKSEL[2:0]  |                             |
|                 |                    | DEVICE_CLKOUT_32K           | MCU_TIMER2_CLKSEL[2:0]  |                             |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] |                         |                             |
|                 |                    | CPSW0.CPTS_GENF0            | MCU_TIMER2_CLKSEL[2:0]  |                             |
|                 |                    | CLK_32K_RC                  | MCU_TIMER2_CLKSEL[2:0]  |                             |

**Table 4-151. Timer Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register     | Description                 |
|-----------------|--------------------|-----------------------------|-----------------------------|-----------------------------|
| MCU_TIMER3      | TIMER_FCLK         | TIMER_ICLK                  | MCU_SYSCLK0/4               | MCU_TIMER3 Interface Clock  |
|                 |                    | HFOSC0_CLKOUT               | MCU_TIMER3_CLKSEL[2:0]      | MCU_TIMER3 Functional Clock |
|                 |                    | MCU_SYSCLK0/2               | MCU_TIMER3_CLKSEL[2:0]      |                             |
|                 |                    | CLK_12M_RC                  | MCU_TIMER3_CLKSEL[2:0]      |                             |
|                 |                    | MCU_PLL0_HSDIV3_CLKOUT      | MCU_TIMER3_CLKSEL[2:0]      |                             |
|                 |                    | MCU_EXT_REFCLK0             | MCU_TIMER3_CLKSEL[2:0]      |                             |
|                 |                    | DEVICE_CLKOUT_32K           | MCU_TIMER3_CLKSEL[2:0]      |                             |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                             |
|                 |                    | CPSW0.CPTS_GENF0            | MCU_TIMER3_CLKSEL[2:0]      |                             |
|                 |                    | CLK_32K_RC                  | MCU_TIMER3_CLKSEL[2:0]      |                             |
| TIMER0          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER0 Interface Clock      |
|                 |                    | HFOSC0_CLKOUT               | TIMER0_CLKSEL[3:0]          | TIMER0 Functional Clock     |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                             |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | CLK_12M_RC                  | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | MCU_EXT_REFCLK0             | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | EXT_REFCLK1                 | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER0_CLKSEL[3:0]          |                             |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER0_CLKSEL[3:0]          |                             |

**Table 4-151. Timer Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register     | Description            |
|-----------------|--------------------|-----------------------------|-----------------------------|------------------------|
| TIMER1          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER1 Interface Clock |
|                 |                    | HFOSC0_CLKOUT               | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                        |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | CLK_12M_RC                  | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | MCU_EXT_REFCLK0             | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | EXT_REFCLK1                 | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER1_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER1_CLKSEL[3:0]          |                        |
| TIMER2          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER2 Interface Clock |
|                 |                    | HFOSC0_CLKOUT               | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                        |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | CLK_12M_RC                  | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | MCU_EXT_REFCLK0             | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | EXT_REFCLK1                 | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER2_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER2_CLKSEL[3:0]          |                        |

Table 4-151. Timer Clocks (continued)

| Module Instance | Module Clock Input | Source Clock                | Source Control Register     | Description            |
|-----------------|--------------------|-----------------------------|-----------------------------|------------------------|
| TIMER3          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER3 Interface Clock |
|                 |                    | HFOSC0_CLKOUT               | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                        |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | CLK_12M_RC                  | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | MCU_EXT_REFCLK0             | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | EXT_REFCLK1                 | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER3_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER3_CLKSEL[3:0]          |                        |
| TIMER4          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER4 Interface Clock |
|                 |                    | HFOSC0_CLKOUT               | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                        |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | CLK_12M_RC                  | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | MCU_EXT_REFCLK0             | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | EXT_REFCLK1                 | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER4_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER4_CLKSEL[3:0]          |                        |

**Table 4-151. Timer Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register     | Description            |
|-----------------|--------------------|-----------------------------|-----------------------------|------------------------|
| TIMER5          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER5 Interface Clock |
|                 |                    | HFOSC0_CLKOUT               | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                        |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | CLK_12M_RC                  | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | MCU_EXT_REFCLK0             | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | EXT_REFCLK1                 | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER5_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER5_CLKSEL[3:0]          |                        |
| TIMER6          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER6 Interface Clock |
|                 |                    | HFOSC0_CLKOUT               | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                        |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | CLK_12M_RC                  | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | MCU_EXT_REFCLK0             | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | EXT_REFCLK1                 | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER6_CLKSEL[3:0]          |                        |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER6_CLKSEL[3:0]          |                        |

**Table 4-151. Timer Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register     | Description                  |
|-----------------|--------------------|-----------------------------|-----------------------------|------------------------------|
| TIMER7          | TIMER_FCLK         | TIMER_ICLK                  | MAIN_SYSCLK0/4              | TIMER7 Interface Clock       |
|                 |                    | HFOSC0_CLKOUT               | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | DEVICE_CLKOUT_32K           | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                              |
|                 |                    | CPSW0.CPTS_GENF0            | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | CPSW0.CPTS_GENF1            | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | MAIN_PLL0_HSDIV7_CLKOUT     | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | CLK_12M_RC                  | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | MCU_EXT_REFCLK0             | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | EXT_REFCLK1                 | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | CP_GEMAC_CPTS_REF_CLK       | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | MAIN_PLL1_HSDIV3_CLKOUT     | TIMER7_CLKSEL[3:0]          |                              |
|                 |                    | MAIN_PLL2_HSDIV6_CLKOUT     | TIMER7_CLKSEL[3:0]          |                              |
| WKUP_TIMER0     | TIMER_FCLK         | TIMER_ICLK                  | DM_CLK/2                    | WKUP_TIMER0 Interface Clock  |
|                 |                    | HFOSC0_CLKOUT               | WKUP_TIMER0_CLKSEL[2:0]     | WKUP_TIMER0 Functional Clock |
|                 |                    | DM_CLK/2                    | WKUP_TIMER0_CLKSEL[2:0]     |                              |
|                 |                    | CLK_12M_RC                  | WKUP_TIMER0_CLKSEL[2:0]     |                              |
|                 |                    | MCU_PLL0_HSDIV3_CLKOUT      | WKUP_TIMER0_CLKSEL[2:0]     |                              |
|                 |                    | MCU_EXT_REFCLK0             | WKUP_TIMER0_CLKSEL[2:0]     |                              |
|                 |                    | DEVICE_CLKOUT_32K           | WKUP_TIMER0_CLKSEL[2:0]     |                              |
|                 |                    | DEVICE_CLKOUT_32K_CTRL[1:0] | DEVICE_CLKOUT_32K_CTRL[1:0] |                              |
|                 |                    | CPSW0.CPTS_GENF0            | WKUP_TIMER0_CLKSEL[2:0]     |                              |
|                 |                    | CLK_32K_RC                  | WKUP_TIMER0_CLKSEL[2:0]     |                              |

**Table 4-151. Timer Clocks (continued)**

| Module Instance | Module Clock Input | Source Clock           | Source Control Register     | Description                                     |
|-----------------|--------------------|------------------------|-----------------------------|-------------------------------------------------|
| WKUP_TIMER1     | TIMER_FCLK         | TIMER_ICLK             | DM_CLK/2                    | WKUP_CLKSEL[0:0]<br>WKUP_TIMER1_Interface Clock |
|                 |                    | HFOSC0_CLKOUT          | WKUP_TIMER1_CLKSEL[2:0]     | WKUP_TIMER1 Functional Clock                    |
|                 |                    | DM_CLK/2               | WKUP_TIMER1_CLKSEL[2:0]     |                                                 |
|                 |                    |                        | WKUP_CLKSEL[0:0]            |                                                 |
|                 |                    | CLK_12M_RC             | WKUP_TIMER1_CLKSEL[2:0]     |                                                 |
|                 |                    | MCU_PLL0_HSDIV3_CLKOUT | WKUP_TIMER1_CLKSEL[2:0]     |                                                 |
|                 |                    | MCU_EXT_REFCLK0        | WKUP_TIMER1_CLKSEL[2:0]     |                                                 |
|                 |                    | DEVICE_CLKOUT_32K      | WKUP_TIMER1_CLKSEL[2:0]     |                                                 |
|                 |                    |                        | DEVICE_CLKOUT_32K_CTRL[1:0] |                                                 |
|                 |                    | CPSW0.CPTS_GENF0       | WKUP_TIMER1_CLKSEL[2:0]     |                                                 |
|                 |                    | CLK_32K_RC             | WKUP_TIMER1_CLKSEL[2:0]     |                                                 |

## 4.13 Internal Diagnostic Modules

### 4.13.1 Dual Clock Comparator (DCC)

This section contains the integration details for the DCC module on this device. For Further information, see the Dual Clock Comparator (DCC) section of the Peripherals chapter

#### 4.13.1.1 DCC Unsupported Features

The following features are not supported on this family of devices:

- There are no unsupported features

#### 4.13.1.2 Module Allocations

**Table 4-152. DCC Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| DCC0     |        |     | ✓    |
| DCC1     |        |     | ✓    |
| DCC2     |        |     | ✓    |
| DCC3     |        |     | ✓    |
| DCC4     |        |     | ✓    |
| DCC5     |        |     | ✓    |
| DCC6     |        |     | ✓    |
| MCU_DCC0 |        | ✓   |      |
| MCU_DCC1 |        | ✓   |      |

#### 4.13.1.3 Resets, Interrupts, and Clocks

**Table 4-153. DDC Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain    | Module Domain      | Index | Default | Controllable | dependences |
|-----------------|------------------------|-----------------|--------------------|-------|---------|--------------|-------------|
| DCC0            | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| DCC1            | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| DCC2            | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| DCC3            | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| DCC4            | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| DCC5            | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| DCC6            | PSC0_PSC_0             | GP_CORE_CTL     | LPSC_MAIN_ALWAYSON | 0     | ON      | NO           | NONE        |
| MCU_DCC0        | WKUP_PSC0              | GP_CORE_CTL_MCU | LPSC MCU_ALWAYSON  | 0     | ON      | NO           | NONE        |

**Table 4-154. DCC Resets**

| Module Instance | Source     | Description    |
|-----------------|------------|----------------|
| DCC0            | PSC0_PSC_0 | DCC0 reset     |
| DCC1            | PSC0_PSC_0 | DCC1 reset     |
| DCC2            | PSC0_PSC_0 | DCC2 reset     |
| DCC3            | PSC0_PSC_0 | DCC3 reset     |
| DCC4            | PSC0_PSC_0 | DCC4 reset     |
| DCC5            | PSC0_PSC_0 | DCC5 reset     |
| DCC6            | PSC0_PSC_0 | DCC6 reset     |
| MCU_DCC0        | WKUP_PSC0  | MCU_DCC0 reset |

**Table 4-155. DCC Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description            | Type  |
|-----------------|-------------------------|-----------------------------|--------------|------------------------|-------|
| DCC0            | DCC0_intr_done_level_0  | GICSS0_spi_IN_128           | GICSS0       | DCC0 interrupt request | level |
| DCC0            | DCC0_intr_done_level_0  | R5FSS0_CORE0_intr_IN_109    | R5FSS0_CORE0 | DCC0 interrupt request | level |
| DCC0            | DCC0_intr_done_level_0  | TIFS0_nvic_IN_111           | TIFS0        | DCC0 interrupt request | level |
| DCC0            | DCC0_intr_done_level_0  | HSM0_nvic_IN_111            | HSM0         | DCC0 interrupt request | level |
| DCC0            | DCC0_intr_err_level_0   | ESM0_esm_lvl_event_IN_112   | ESM0         | DCC0 interrupt request | level |
| DCC1            | DCC1_intr_done_level_0  | GICSS0_spi_IN_128           | GICSS0       | DCC1 interrupt request | level |
| DCC1            | DCC1_intr_done_level_0  | R5FSS0_CORE0_intr_IN_109    | R5FSS0_CORE0 | DCC1 interrupt request | level |
| DCC1            | DCC1_intr_done_level_0  | TIFS0_nvic_IN_111           | TIFS0        | DCC1 interrupt request | level |
| DCC1            | DCC1_intr_done_level_0  | HSM0_nvic_IN_111            | HSM0         | DCC1 interrupt request | level |
| DCC1            | DCC1_intr_err_level_0   | ESM0_esm_lvl_event_IN_113   | ESM0         | DCC1 interrupt request | level |
| DCC2            | DCC2_intr_done_level_0  | GICSS0_spi_IN_128           | GICSS0       | DCC2 interrupt request | level |
| DCC2            | DCC2_intr_done_level_0  | R5FSS0_CORE0_intr_IN_109    | R5FSS0_CORE0 | DCC2 interrupt request | level |
| DCC2            | DCC2_intr_done_level_0  | TIFS0_nvic_IN_111           | TIFS0        | DCC2 interrupt request | level |
| DCC2            | DCC2_intr_done_level_0  | HSM0_nvic_IN_111            | HSM0         | DCC2 interrupt request | level |
| DCC2            | DCC2_intr_err_level_0   | ESM0_esm_lvl_event_IN_114   | ESM0         | DCC2 interrupt request | level |

Table 4-155. DCC Hardware Requests (continued)

| Module Instance | Module Interrupt Signal     | Destination Interrupt Input | Destination      | Description                | Type  |
|-----------------|-----------------------------|-----------------------------|------------------|----------------------------|-------|
| DCC3            | DCC3_intr_done_level_0      | GICSS0_spi_IN_128           | GICSS0           | DCC3 interrupt request     | level |
| DCC3            | DCC3_intr_done_level_0      | R5FSS0_CORE0_intr_IN_109    | R5FSS0_CORE0     | DCC3 interrupt request     | level |
| DCC3            | DCC3_intr_done_level_0      | TIFS0_nvic_IN_111           | TIFS0            | DCC3 interrupt request     | level |
| DCC3            | DCC3_intr_done_level_0      | HSM0_nvic_IN_111            | HSM0             | DCC3 interrupt request     | level |
| DCC3            | DCC3_intr_err_level_0       | ESM0_esm_lvl_event_IN_115   | ESM0             | DCC3 interrupt request     | level |
| DCC4            | DCC4_intr_done_level_0      | GICSS0_spi_IN_128           | GICSS0           | DCC4 interrupt request     | level |
| DCC4            | DCC4_intr_done_level_0      | R5FSS0_CORE0_intr_IN_109    | R5FSS0_CORE0     | DCC4 interrupt request     | level |
| DCC4            | DCC4_intr_done_level_0      | TIFS0_nvic_IN_111           | TIFS0            | DCC4 interrupt request     | level |
| DCC4            | DCC4_intr_done_level_0      | HSM0_nvic_IN_111            | HSM0             | DCC4 interrupt request     | level |
| DCC4            | DCC4_intr_err_level_0       | ESM0_esm_lvl_event_IN_116   | ESM0             | DCC4 interrupt request     | level |
| DCC5            | DCC5_intr_done_level_0      | GICSS0_spi_IN_128           | GICSS0           | DCC5 interrupt request     | level |
| DCC5            | DCC5_intr_done_level_0      | R5FSS0_CORE0_intr_IN_109    | R5FSS0_CORE0     | DCC5 interrupt request     | level |
| DCC5            | DCC5_intr_done_level_0      | TIFS0_nvic_IN_111           | TIFS0            | DCC5 interrupt request     | level |
| DCC5            | DCC5_intr_done_level_0      | HSM0_nvic_IN_111            | HSM0             | DCC5 interrupt request     | level |
| DCC5            | DCC5_intr_err_level_0       | ESM0_esm_lvl_event_IN_117   | ESM0             | DCC5 interrupt request     | level |
| DCC6            | DCC6_intr_done_level_0      | GICSS0_spi_IN_128           | GICSS0           | DCC6 interrupt request     | level |
| DCC6            | DCC6_intr_done_level_0      | R5FSS0_CORE0_intr_IN_109    | R5FSS0_CORE0     | DCC6 interrupt request     | level |
| DCC6            | DCC6_intr_done_level_0      | TIFS0_nvic_IN_111           | TIFS0            | DCC6 interrupt request     | level |
| DCC6            | DCC6_intr_done_level_0      | HSM0_nvic_IN_111            | HSM0             | DCC6 interrupt request     | level |
| DCC6            | DCC6_intr_err_level_0       | ESM0_esm_lvl_event_IN_79    | ESM0             | DCC6 interrupt request     | level |
| MCU_DCC0        | MCU_DCC0_intr_donne_level_0 | MCU_M4FSS0_CORE0_nvic_IN_21 | MCU_M4FSS0_CORE0 | MCU_DCC0 interrupt request | level |

**Table 4-155. DCC Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal     | Destination Interrupt Input   | Destination  | Description                | Type  |
|-----------------|-----------------------------|-------------------------------|--------------|----------------------------|-------|
| MCU_DCC0        | MCU_DCC0_intr_donne_level_0 | R5FSS0_CORE0_intr_IN_108      | R5FSS0_CORE0 | MCU_DCC0 interrupt request | level |
| MCU_DCC0        | MCU_DCC0_intr_donne_level_0 | TIFS0_nvic_IN_112             | TIFS0        | MCU_DCC0 interrupt request | level |
| MCU_DCC0        | MCU_DCC0_intr_donne_level_0 | HSM0_nvic_IN_112              | HSM0         | MCU_DCC0 interrupt request | level |
| MCU_DCC0        | MCU_DCC0_intr_err_level_0   | WKUP_ESM0_esm_lvl_event_IN_37 | WKUP_ESM0    | MCU_DCC0 interrupt request | level |

**Table 4-156. DDC Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                             |
|-----------------|--------------------|----------------|-------------------------|-----------------------------------------|
| DCC0            | FICLK              | MAIN_SYSCLK0/4 |                         | DCC0 Functional and Interface Clock     |
| DCC1            | FICLK              | MAIN_SYSCLK0/4 |                         | DCC1 Functional and Interface Clock     |
| DCC2            | FICLK              | MAIN_SYSCLK0/4 |                         | DCC2 Functional and Interface Clock     |
| DCC3            | FICLK              | MAIN_SYSCLK0/4 |                         | DCC3 Functional and Interface Clock     |
| DCC4            | FICLK              | MAIN_SYSCLK0/4 |                         | DCC4 Functional and Interface Clock     |
| DCC5            | FICLK              | MAIN_SYSCLK0/4 |                         | DCC5 Functional and Interface Clock     |
| DCC6            | FICLK              | MAIN_SYSCLK0/4 |                         | DCC6 Functional and Interface Clock     |
| MCU_DCC0        | FICLK              | MCU_SYSCLK0/4  |                         | MCU_DCC0 Functional and Interface Clock |

#### 4.13.1.4 DCC Input Source Clock Mapping

**Table 4-157. DCC0 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface  | Clock Source            |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|-------------------|-------------------------|
| DCC0            | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT     | HFOSCO_CLKOUT           |
| DCC0            | dcc_input01_clk | 0          | 1                                  | PINFUNCTION_EXT_REFCLK1in            | EXT_REFCLK1       | EXT_REFCLK1             |
| DCC0            | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC                      | CLKOUT            | CLK_12M_RC              |
| DCC0            | dcc_input03_clk | 0          | 3                                  | PLLCTRL0                             | FICLK             | main_SYSCLK0/4          |
| DCC0            | dcc_input10_clk | 1          | 0                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0/2          |
| DCC0            | dcc_cksrc0_clk  | 1          | 1                                  | hsdiv4_16ff_main_0                   | hsdivt1_clk       | MAIN_PLL0_HSDIV1_CLKOUT |
| DCC0            | dcc_cksrc1_clk  | 1          | 2                                  | hsdiv4_16ff_main_0                   | hsdivt2_clk       | MAIN_PLL0_HSDIV2_CLKOUT |
| DCC0            | dcc_cksrc2_clk  | 1          | 3                                  | hsdiv4_16ff_main_0                   | hsdivt3_clk       | MAIN_PLL0_HSDIV3_CLKOUT |
| DCC0            | dcc_cksrc3_clk  | 1          | 4                                  | hsdiv4_16ff_main_0                   | hsdivt4_clk       | MAIN_PLL0_HSDIV4_CLKOUT |
| DCC0            | dcc_cksrc4_clk  | 1          | 5                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT     | HFOSCO_CLKOUT           |
| DCC0            | dcc_cksrc5_clk  | 1          | 6                                  | PINFUNCTION_EXT_REFCLK1in            | EXT_REFCLK1       | EXT_REFCLK1             |
| DCC0            | dcc_cksrc6_clk  | 1          | 7                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0            |
| DCC0            | dcc_cksrc7_clk  | 1          | 8                                  | postdiv4_16ff_main_2                 | hsdivt8_clk       | MAIN_PLL2_HSDIV8_CLKOUT |
| DCC0            | vbus_clk        | 1          | 9                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0/4          |

**Table 4-158. DCC1 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface  | Clock Source            |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|-------------------|-------------------------|
| DCC1            | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT     | HFOSCO_CLKOUT           |
| DCC1            | dcc_input01_clk | 0          | 1                                  | PINFUNCTION_EXT_REFCLK1in            | EXT_REFCLK1       | EXT_REFCLK1             |
| DCC1            | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC                      | CLKOUT            | CLK_12M_RC              |
| DCC1            | dcc_input03_clk | 0          | 3                                  | PLLCTRL0                             | FICLK             | main_SYSCLK0/4          |
| DCC1            | dcc_input10_clk | 1          | 0                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0/2          |
| DCC1            | dcc_cksrc0_clk  | 1          | 1                                  | postdiv4_16ff_main_0                 | hsdivt5_clk       | MAIN_PLL0_HSDIV5_CLKOUT |
| DCC1            | dcc_cksrc1_clk  | 1          | 2                                  | postdiv4_16ff_main_0                 | hsdivt6_clk       | MAIN_PLL0_HSDIV6_CLKOUT |
| DCC1            | dcc_cksrc2_clk  | 1          | 3                                  | postdiv4_16ff_main_0                 | hsdivt7_clk       | MAIN_PLL0_HSDIV7_CLKOUT |
| DCC1            | dcc_cksrc3_clk  | 1          | 4                                  | hsdiv4_16ff_main_1                   | hsdivt1_clk       | MAIN_PLL1_HSDIV1_CLKOUT |
| DCC1            | dcc_cksrc4_clk  | 1          | 5                                  | postdiv4_16ff_main_0                 | hsdivt9_clk       | MAIN_PLL0_HSDIV9_CLKOUT |
| DCC1            | dcc_cksrc5_clk  | 1          | 6                                  | hsdiv4_16ff_main_1                   | hsdivt0_clk       | MAIN_PLL1_HSDIV0_CLKOUT |

**Table 4-158. DCC1 Input Source Clock Mapping (continued)**

| Domain Instance | Domain Input   | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance     | Source Interface  | Clock Source            |
|-----------------|----------------|------------|------------------------------------|---------------------|-------------------|-------------------------|
| DCC1            | dcc_cksrc6_clk | 1          | 7                                  | GLUELOGIC_RCOSC     | CLKOUT            | CLK_12M_RC              |
| DCC1            | dcc_cksrc7_clk | 1          | 8                                  | hsdiv4_16fft_main_1 | hsdivout2_clk     | MAIN_PLL1_HSDIV2_CLKOUT |
| DCC1            | vbus_clk       | 1          | 9                                  | PLLCTRL0            | chip_div1_clk_clk | main_SYSCLK0/4          |

**Table 4-159. DCC2 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface  | Clock Source             |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|-------------------|--------------------------|
| DCC2            | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT     | HFOSCO_CLKOUT            |
| DCC2            | dcc_input01_clk | 0          | 1                                  | PINFUNCTION_EXT_REFCLK1in            | EXT_REFCLK1       | EXT_REFCLK1              |
| DCC2            | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC                      | CLKOUT            | CLK_12M_RC               |
| DCC2            | dcc_input03_clk | 0          | 3                                  | PLLCTRL0                             | FICLK             | main_SYSCLK0/4           |
| DCC2            | dcc_input10_clk | 1          | 0                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0/4           |
| DCC2            | dcc_cksrc0_clk  | 1          | 1                                  | hsdiv4_16fft_main_1                  | hsdivout3_clk     | MAIN_PLL1_HSDIV3_CLKOUT  |
| DCC2            | dcc_cksrc1_clk  | 1          | 2                                  | hsdiv1_16fft_main_15                 | hsdivout0_clk     | MAIN_PLL15_HSDIV0_CLKOUT |
| DCC2            | dcc_cksrc2_clk  | 1          | 3                                  | postdiv1_16fft_main_1                | hsdivout5_clk     | MAIN_PLL1_HSDIV5_CLKOUT  |
| DCC2            | dcc_cksrc3_clk  | 1          | 4                                  | postdiv1_16fft_main_1                | hsdivout6_clk     | MAIN_PLL1_HSDIV6_CLKOUT  |
| DCC2            | dcc_cksrc4_clk  | 1          | 5                                  | hsdiv4_16fft_main_2                  | hsdivout0_clk     | MAIN_PLL2_HSDIV0_CLKOUT  |
| DCC2            | dcc_cksrc5_clk  | 1          | 6                                  | hsdiv1_16fft_main_15                 | hsdivout1_clk     | MAIN_PLL15_HSDIV1_CLKOUT |
| DCC2            | dcc_cksrc6_clk  | 1          | 7                                  | hsdiv4_16fft_main_2                  | hsdivout2_clk     | MAIN_PLL2_HSDIV2_CLKOUT  |
| DCC2            | dcc_cksrc7_clk  | 1          | 8                                  | PINFUNCTION_RMII2_REF_CLKin          | RMII2_REF_CLK     | RMII2_REF_CLK            |
| DCC2            | vbus_clk        | 1          | 9                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0/4           |

**Table 4-160. DCC3 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface  | Clock Source            |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|-------------------|-------------------------|
| DCC3            | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT     | HFOSCO_CLKOUT           |
| DCC3            | dcc_input01_clk | 0          | 1                                  | PINFUNCTION_EXT_REFCLK1in            | EXT_REFCLK1       | EXT_REFCLK1             |
| DCC3            | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC                      | CLKOUT            | CLK_12M_RC              |
| DCC3            | dcc_input03_clk | 0          | 3                                  | PLLCTRL0                             | FICLK             | main_SYSCLK0/4          |
| DCC3            | dcc_input10_clk | 1          | 0                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0/4          |
| DCC3            | dcc_cksrc0_clk  | 1          | 1                                  | hsdiv4_16fft_main_1                  | hsdivout0_clk     | MAIN_PLL1_HSDIV0_CLKOUT |

**Table 4-160. DCC3 Input Source Clock Mapping (continued)**

| Domain Instance | Domain Input   | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance      | Source Interface  | Clock Source              |
|-----------------|----------------|------------|------------------------------------|----------------------|-------------------|---------------------------|
| DCC3            | dcc_cksrc1_clk | 1          | 2                                  | postdiv4_16ff_main_2 | hsdivout5_clk     | MAIN_PLL2_HSDIV5_CLKOUT   |
| DCC3            | dcc_cksrc3_clk | 1          | 4                                  | postdiv4_16ff_main_2 | hsdivout7_clk     | MAIN_PLL2_HSDIV7_CLKOUT   |
| DCC3            | dcc_cksrc4_clk | 1          | 5                                  | postdiv4_16ff_main_2 | hsdivout6_clk     | MAIN_PLL2_HSDIV6_CLKOUT   |
| DCC3            | dcc_cksrc5_clk | 1          | 6                                  | postdiv4_16ff_main_2 | hsdivout9_clk     | MAIN_PLL2_HSDIV9_CLKOUT   |
| DCC3            | dcc_cksrc6_clk | 1          | 7                                  | hsdiv0_16fft_main_8  | hsdivout0_clk     | MAIN_PLL8_HSDIV0_CLKOUT/4 |
| DCC3            | dcc_cksrc7_clk | 1          | 8                                  | hsdiv0_16fft_main_12 | hsdivout0_clk     | MAIN_PLL12_HSDIV0_CLKOUT  |
| DCC3            | vbus_clk       | 1          | 9                                  | PLLCTRL0             | chip_div1_clk_clk | main_SYSCLK0/4            |

**Table 4-161. DCC4 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface       | Clock Source           |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|------------------------|------------------------|
| DCC4            | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT          | HFOSCO_CLKOUT          |
| DCC4            | dcc_input01_clk | 0          | 1                                  | PINFUNCTION_EXT_REFCLK1in            | EXT_REFCLK1            | EXT_REFCLK1            |
| DCC4            | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC                      | CLKOUT                 | CLK_12M_RC             |
| DCC4            | dcc_input03_clk | 0          | 3                                  | PLLCTRL0                             | FICLK                  | main_SYSCLK0/4         |
| DCC4            | dcc_input10_clk | 1          | 0                                  | PLLCTRL0                             | chip_div1_clk_clk      | main_SYSCLK0/2         |
| DCC4            | dcc_cksrc0_clk  | 1          | 1                                  | PINFUNCTION_GPMCO_CLKLBin            | GPMCO_CLKLB            | GPMCO_CLKLB            |
| DCC4            | dcc_cksrc1_clk  | 1          | 2                                  | PINFUNCTION_CP_GEMAC_CPTSO_RFT_CLKin | CP_GEMAC_CPTSO_RFT_CLK | CP_GEMAC_CPTSO_RFT_CLK |
| DCC4            | dcc_cksrc2_clk  | 1          | 3                                  | PINFUNCTION_AUDIO_EXT_REFCLK1in      | AUDIO_EXT_REFCLK1      | AUDIO_EXT_REFCLK1      |
| DCC4            | dcc_cksrc3_clk  | 1          | 4                                  | DPHY_RX0                             | ppi_rx_byte_clk        | ppi_rx_byte_clk        |
| DCC4            | dcc_cksrc4_clk  | 1          | 5                                  | PINFUNCTION MCU_EXT_REFCLK0in        | MCU_EXT_REFCLK0        | MCU_EXT_REFCLK0        |
| DCC4            | dcc_cksrc5_clk  | 1          | 6                                  | PINFUNCTION_RMII1_REF_CLKin          | RMII1_REF_CLK          | RMII1_REF_CLK/4        |
| DCC4            | dcc_cksrc6_clk  | 1          | 7                                  | PINFUNCTION_RGMII1_RXCin             | RGMII1_RXC             | RGMII1_RXC             |
| DCC4            | dcc_cksrc7_clk  | 1          | 8                                  | CLK_32K_RC_SEL                       | out0                   | DEVICE_CLKOUT_32K      |
| DCC4            | vbus_clk        | 1          | 9                                  | PLLCTRL0                             | chip_div1_clk_clk      | main_SYSCLK0/4         |

**Table 4-162. DCC5 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface | Clock Source  |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|------------------|---------------|
| DCC5            | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT    | HFOSCO_CLKOUT |

**Table 4-162. DCC5 Input Source Clock Mapping (continued)**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance           | Source Interface  | Clock Source               |
|-----------------|-----------------|------------|------------------------------------|---------------------------|-------------------|----------------------------|
| DCC5            | dcc_input01_clk | 0          | 1                                  | PINFUNCTION_EXT_REFCLK1in | EXT_REFCLK1       | EXT_REFCLK1                |
| DCC5            | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC           | CLKOUT            | CLK_12M_RC                 |
| DCC5            | dcc_input03_clk | 0          | 3                                  | PLLCTRL0                  | FICLK             | main_SYSCLK0/4             |
| DCC5            | dcc_input10_clk | 1          | 0                                  | PLLCTRL0                  | chip_div1_clk_clk | main_SYSCLK0               |
| DCC5            | dcc_cksrc0_clk  | 1          | 1                                  | postdiv4_16fft_main_0     | hsdivout8_clk     | MAIN_PLL0_HSDIV8_CLKOUT    |
| DCC5            | dcc_cksrc1_clk  | 1          | 2                                  | hsdiv4_16fft_main_1       | hsdivout4_clk     | MAIN_PLL1_HSDIV4_CLKOUT    |
| DCC5            | dcc_cksrc2_clk  | 1          | 3                                  | hsdiv4_16fft_main_2       | hsdivout1_clk     | MAIN_PLL2_HSDIV1_CLKOUT    |
| DCC5            | dcc_cksrc3_clk  | 1          | 4                                  | hsdiv4_16fft_main_2       | hsdivout3_clk     | MAIN_PLL2_HSDIV3_CLKOUT    |
| DCC5            | dcc_cksrc4_clk  | 1          | 5                                  | hsdiv4_16fft_main_2       | hsdivout4_clk     | MAIN_PLL2_HSDIV4_CLKOUT    |
| DCC5            | dcc_cksrc5_clk  | 1          | 6                                  | hsdiv0_16fft_main_16      | hsdivout0_clk     | MAIN_PLL16_HSDIV0_CLKOUT/4 |
| DCC5            | dcc_cksrc6_clk  | 1          | 7                                  | hsdiv0_16fft_main_17      | hsdivout0_clk     | MAIN_PLL17_HSDIV0_CLKOUT   |
| DCC5            | dcc_cksrc7_clk  | 1          | 8                                  | PINFUNCTION_RGMII2_RXCin  | RGMII2_RXC        | RGMII2_RXC                 |
| DCC5            | vbus_clk        | 1          | 9                                  | PLLCTRL0                  | chip_div1_clk_clk | main_SYSCLK0/4             |

**Table 4-163. DCC6 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface  | Clock Source     |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|-------------------|------------------|
| DCC6            | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT     | HFOSCO_CLKOUT    |
| DCC6            | dcc_input01_clk | 0          | 1                                  | PINFUNCTION_EXT_REFCLK1in            | EXT_REFCLK1       | EXT_REFCLK1      |
| DCC6            | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC                      | CLKOUT            | CLK_12M_RC       |
| DCC6            | dcc_input03_clk | 0          | 3                                  | PLLCTRL0                             | FICLK             | main_SYSCLK0/4   |
| DCC6            | dcc_input10_clk | 1          | 0                                  | PLLCTRL0                             | chip_div1_clk_clk | main_SYSCLK0     |
| DCC6            | dcc_cksrc0_clk  | 1          | 1                                  | PINFUNCTION_VOUT0_EXTPCLKINin        | VOUT0_EXTPCLKIN   | VOUT_EXTPCLKIN   |
| DCC6            | dcc_cksrc1_clk  | 1          | 2                                  | PINFUNCTION_MCASP0_ACLKXin           | MCASP0_ACLKX      | MCASP0_ACLKX     |
| DCC6            | dcc_cksrc2_clk  | 1          | 3                                  | PINFUNCTION_MCASP0_ACLKRin           | MCASP0_ACLKR      | MCASP0_ACLKR     |
| DCC6            | dcc_cksrc3_clk  | 1          | 4                                  | PINFUNCTION_MCASP1_ACLKXin           | MCASP1_ACLKX      | MCASP1_ACLKX     |
| DCC6            | dcc_cksrc4_clk  | 1          | 5                                  | PINFUNCTION_MCASP1_ACLKRin           | MCASP1_ACLKR      | MCASP1_ACLKR     |
| DCC6            | dcc_cksrc5_clk  | 1          | 6                                  | PINFUNCTION_MCASP2_ACLKXin           | MCASP2_ACLKX      | MCASP2_ACLKX     |
| DCC6            | dcc_cksrc6_clk  | 1          | 7                                  | PINFUNCTION_MCASP2_ACLKRin           | MCASP2_ACLKR      | MCASP2_ACLKR     |
| DCC6            | dcc_cksrc7_clk  | 1          | 8                                  | PINFUNCTION_AUDIO_EXT_REFCLKin       | AUDIO_EXT_REFCLK  | AUDIO_EXT_REFCLK |
| DCC6            |                 |            | 0                                  |                                      | 0                 |                  |

**Table 4-163. DCC6 Input Source Clock Mapping (continued)**

| Domain Instance | Domain Input | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance | Source Interface  | Clock Source   |
|-----------------|--------------|------------|------------------------------------|-----------------|-------------------|----------------|
| DCC6            | vbus_clk     | 1          | 9                                  | PLLCTRL0        | chip_div1_clk_clk | main_SYSCLK0/4 |

**Table 4-164. MCU\_DCC0 Input Source Clock Mapping**

| Domain Instance | Domain Input    | Input/ MUX | DCCCLKSRC0/<br>DCCCLKSRC1<br>Value | Source Instance                      | Source Interface  | Clock Source           |
|-----------------|-----------------|------------|------------------------------------|--------------------------------------|-------------------|------------------------|
| MCU_DCC0        | dcc_input00_clk | 0          | 0                                  | GLUELOGIC_HFOSCO_CLOCKLOSS_DETECTION | HFOSCO_CLKOUT     | HFOSCO_CLKOUT          |
| MCU_DCC0        | dcc_input01_clk | 0          | 1                                  | CLK_32K_RC_DIV                       | out0              | CLK_32K_RC             |
| MCU_DCC0        | dcc_input02_clk | 0          | 2                                  | GLUELOGIC_RCOSC                      | CLKOUT            | CLK_12M_RC             |
| MCU_DCC0        | dcc_input03_clk | 0          | 3                                  | MCU_PLLCTRL0                         | FICLK             | main_SYSCLK0/4         |
| MCU_DCC0        | dcc_input10_clk | 1          | 0                                  | MCU_PLLCTRL0                         | chip_div1_clk_clk | MCU_SYSCLK0/2          |
| MCU_DCC0        | dcc_cksrc0_clk  | 1          | 1                                  | hsdiv4_16fft_mcu_0                   | hsdivout0_clk     | MCU_PLL0_HSDIV0_CLKOUT |
| MCU_DCC0        | dcc_cksrc1_clk  | 1          | 2                                  | hsdiv4_16fft_mcu_0                   | hsdivout1_clk     | MCU_PLL0_HSDIV1_CLKOUT |
| MCU_DCC0        | dcc_cksrc2_clk  | 1          | 3                                  | hsdiv4_16fft_mcu_0                   | hsdivout2_clk     | MCU_PLL0_HSDIV2_CLKOUT |
| MCU_DCC0        | dcc_cksrc3_clk  | 1          | 4                                  | hsdiv4_16fft_mcu_0                   | hsdivout3_clk     | MCU_PLL0_HSDIV3_CLKOUT |
| MCU_DCC0        | dcc_cksrc4_clk  | 1          | 5                                  | hsdiv4_16fft_mcu_0                   | hsdivout4_clk     | MCU_PLL0_HSDIV4_CLKOUT |
| MCU_DCC0        | dcc_cksrc5_clk  | 1          | 6                                  | CLK_32K_RC_DIV                       | out0              | CLK_32K_RC             |
| MCU_DCC0        | dcc_cksrc6_clk  | 1          | 7                                  | CLK_32K_RC_SEL                       | out0              | DEVICE_CLKOUT_32K      |
| MCU_DCC0        | dcc_cksrc7_clk  | 1          | 8                                  | PINFUNCTION_MCU_EXT_REFCLK0in        | MCU_EXT_REFCLK0   | MCU_EXT_REFCLK0        |
| MCU_DCC0        | vbus_clk        | 1          | 9                                  | MCU_PLLCTRL0                         | chip_div1_clk_clk | MCU_SYSCLK0/4          |

#### 4.13.2 Error Signaling Module (ESM)

This section contains the integration details for the ESM module on this device. For further information, see the Error Signaling Module (ESM) section of the Peripherals chapter

##### 4.13.2.1 ESM Unsupported Features

The following features are not supported on this family of devices:

- No Dedicated ERROR Pin for MAIN domain ESM. MAIN ESM error interrupts are routed to the MCU ESM - the MCU ESM drives the MCU\_ERROR pin and can factor in errors from MAIN ESM if programmed to do so.

##### 4.13.2.2 Module Allocations

**Table 4-165. ESM Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| ESM0      |        |     | ✓    |
| WKUP_ESM0 | ✓      |     |      |

##### 4.13.2.3 Resets, Interrupts, and Clocks

**Table 4-166. ESM Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain     | Module Domain      | Index | Default | Controllable | dependences |
|-----------------|------------------------|------------------|--------------------|-------|---------|--------------|-------------|
| WKUP_ESM0       | WKUP_PSC0              | GP_CORE_CT_L_MCU | LPSC MCU AL WAYSON | 0     | ON      | NO           | NONE        |

**Table 4-167. ESM Resets**

| Module Instance | Source    | Description     |
|-----------------|-----------|-----------------|
| WKUP_ESM0       | WKUP_PSC0 | WKUP_ESM0 reset |

**Table 4-168. ESM Hardware Requests**

| Module Instance | Module Interrupt Signal      | Destination Interrupt Input  | Destination       | Description                 | Type  |
|-----------------|------------------------------|------------------------------|-------------------|-----------------------------|-------|
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_cfg_lvl_0 | MCU_M4FSS0_COR E0_nvic_IN_11 | MCU_M4FSS0_COR E0 | WKUP_ESM0 interrupt request | level |
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_cfg_lvl_0 | ESM0_esm_lvl_event _IN_37    | ESM0              | WKUP_ESM0 interrupt request | level |
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_cfg_lvl_0 | R5FSS0_CORE0_intr _IN_140    | R5FSS0_CORE0      | WKUP_ESM0 interrupt request | level |
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_hi_lvl_0  | MCU_M4FSS0_COR E0_nvic_IN_12 | MCU_M4FSS0_COR E0 | WKUP_ESM0 interrupt request | level |
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_hi_lvl_0  | ESM0_esm_lvl_event _IN_38    | ESM0              | WKUP_ESM0 interrupt request | level |
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_hi_lvl_0  | R5FSS0_CORE0_intr _IN_141    | R5FSS0_CORE0      | WKUP_ESM0 interrupt request | level |
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_low_lvl_0 | MCU_M4FSS0_COR E0_nvic_IN_13 | MCU_M4FSS0_COR E0 | WKUP_ESM0 interrupt request | level |
| WKUP_ESM0       | WKUP_ESM0_esm_i nt_low_lvl_0 | ESM0_esm_lvl_event _IN_39    | ESM0              | WKUP_ESM0 interrupt request | level |

**Table 4-168. ESM Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal     | Destination Interrupt Input | Destination  | Description                 | Type  |
|-----------------|-----------------------------|-----------------------------|--------------|-----------------------------|-------|
| WKUP_ESM0       | WKUP_ESM0_esm_int_low_lvl_0 | R5FSS0_CORE0_intr_IN_142    | R5FSS0_CORE0 | WKUP_ESM0 interrupt request | level |

**Table 4-169. ESM Clocks**

| Module Instance | Module Clock Input | Source Clock  | Source Control Register | Description                              |
|-----------------|--------------------|---------------|-------------------------|------------------------------------------|
| WKUP_ESM0       | FICLK              | MCU_SYSCLK0/4 |                         | WKUP_ESM0 Functional and Interface Clock |

#### 4.13.3 Memory Cyclic Redundancy Check (MCRC64)

This section contains the integration details for the MCRC64 module on this device. For further information, see the Memory Cyclic Redundancy Check (MCRC64) section of the Peripherals chapter

##### 4.13.3.1 MCRC64 Unsupported Features

The following features are not supported on this family of devices:

- Data Trace Mode (Automatic PSA on CPU Instruction and Data TCM busses) - Wrapper only supports VBUSM Signature Analysis. ITCM, DTCM designed for Cortex R5F
- DMA is not supported by the MCU instances

##### 4.13.3.2 Module Allocations

**Table 4-170. MCRC64 Modules Allocation within Device Domains**

| Instance     | Domain |     |      |
|--------------|--------|-----|------|
|              | WKUP   | MCU | Main |
| MCRC64_0     |        |     | ✓    |
| MCU_MCRC64_0 |        | ✓   |      |

##### 4.13.3.3 Resets, Interrupts, and Clocks

**Table 4-171. MCRC64 Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain   | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|-----------------|-------|---------|--------------|------------------------|
| MCRC64_0        | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP    | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| MCU_MCRC64_0    | WKUP_PSC0              | PD_M4F       | LPSC MCU COMMON | 9     | ON      | YES          | LPSC_DM2SAFE_ISO       |

**Table 4-172. MCRC64 Resets**

| Module Instance | Source     | Description        |
|-----------------|------------|--------------------|
| MCRC64_0        | PSC0_PSC_0 | MCRC64_0 reset     |
| MCU_MCRC64_0    | WKUP_PSC0  | MCU_MCRC64_0 reset |

**Table 4-173. MCRC64 Hardware Requests**

| Module Instance | Module Interrupt Signal  | Destination Interrupt Input                   | Destination      | Description                    | Type  |
|-----------------|--------------------------|-----------------------------------------------|------------------|--------------------------------|-------|
| MCRC64_0        | MCRC64_0_dma_event_[3:0] | DMASS0_INTAGGR_0_intaggr_levi_pend_IN_[31:28] | DMASS0_INTAGGR_0 | MCRC64_0 interrupt request     | pulse |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | GICSS0_spi_IN_166                             | GICSS0           | MCRC64_0 interrupt request     | level |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | R5FSS0_CORE0_intr_IN_119                      | R5FSS0_CORE0     | MCRC64_0 interrupt request     | level |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | TIFS0_nvic_IN_83                              | TIFS0            | MCRC64_0 interrupt request     | level |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | HSM0_nvic_IN_83                               | HSM0             | MCRC64_0 interrupt request     | level |
| MCU_MCRC64_0    | MCU_MCRC64_0_int_mcrc_0  | MCU_M4FSS0_CORE0_nvic_IN_25                   | MCU_M4FSS0_CORE0 | MCU_MCRC64_0 interrupt request | level |

**Table 4-173. MCRC64 Hardware Requests (continued)**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination  | Description                    | Type  |
|-----------------|-------------------------|-----------------------------|--------------|--------------------------------|-------|
| MCU_MCRC64_0    | MCU_MCRC64_0_int_mcrc_0 | GICSS0_spi_IN_192           | GICSS0       | MCU_MCRC64_0 interrupt request | level |
| MCU_MCRC64_0    | MCU_MCRC64_0_int_mcrc_0 | R5FSS0_CORE0_intr_IN_192    | R5FSS0_CORE0 | MCU_MCRC64_0 interrupt request | level |

**Table 4-174. MCRC64 Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                                 |
|-----------------|--------------------|----------------|-------------------------|---------------------------------------------|
| MCRC64_0        | FICLK              | MAIN_SYSCLK0/2 |                         | MCRC64_0 Functional and Interface Clock     |
| MCU_MCRC64_0    | FICLK              | MCU_SYSCLK0/2  |                         | MCU_MCRC64_0 Functional and Interface Clock |

#### 4.13.4 ECC Aggregator (ECC\_AGGR)

This section contains the integration details for the ECC\_AGGR module on this device. For further information, see the ECC Aggregator (ECC\_AGGR) section of the Peripherals chapter.

##### 4.13.4.1 Module Allocations

**Table 4-175. ECC\_AGGR Modules Allocation within Device Domains**

| Instance       | Domain |     |      |
|----------------|--------|-----|------|
|                | WKUP   | MCU | Main |
| ECC_AGGR0      |        |     | ✓    |
| ECC_AGGR1      |        |     | ✓    |
| MCU_ECC_AGGR0  |        | ✓   |      |
| MCU_ECC_AGGR1  |        | ✓   |      |
| WKUP_ECC_AGGR0 | ✓      |     |      |
| WKUP_ECC_AGGR1 | ✓      |     |      |
| WKUP_ECC_AGGR2 | ✓      |     |      |

##### 4.13.4.2 Modules and Subsystems with ECC Aggregator

| Module Instance  | MAIN | MCU | WKUP |
|------------------|------|-----|------|
| COMPUTE_CLUSTER0 | ✓    |     |      |
| CPSW0            | ✓    |     |      |
| DMASS0           | ✓    |     |      |
| FSS0             | ✓    |     |      |
| GICSS0           | ✓    |     |      |
| ICSSM0           | ✓    |     |      |
| MCAN0            | ✓    |     |      |
| MCU_M4FSS0       |      | ✓   |      |
| MCU_MCAN0        |      | ✓   |      |
| MCU_MCAN1        |      | ✓   |      |
| MMCS0            | ✓    |     |      |
| MMCS1            | ✓    |     |      |
| MMCS2            | ✓    |     |      |
| PDMA0            | ✓    |     |      |
| PDMA1            | ✓    |     |      |
| PSRAMECC0        | ✓    |     |      |
| PSRAMECC_16K0    | ✓    |     |      |
| SA3_SS0          | ✓    |     |      |
| SMS0             | ✓    |     |      |
| USB0             | ✓    |     |      |
| USB1             | ✓    |     |      |
| WKUP_R5FSS0      |      |     | ✓    |
| WKUP_VTM0        |      |     | ✓    |

| Module Instance | MAIN | MCU | WKUP |
|-----------------|------|-----|------|
| CSI_RX_IF0      | ✓    |     |      |

#### 4.13.4.3 Resets, Interrupts, and Clocks

**Table 4-176. ECC\_AGGR Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain   | Index | Default | Controllable | dependences            |
|-----------------|------------------------|--------------|-----------------|-------|---------|--------------|------------------------|
| MCRC64_0        | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_MAIN_IP    | 34    | ON      | YES          | LPSC_DM2MAIN_INFRA_ISO |
| MCU_MCRC64_0    | WKUP_PSC0              | PD_M4F       | LPSC MCU COMMON | 9     | ON      | YES          | LPSC_DM2SAFE_ISO       |

**Table 4-177. ECC\_AGGR Resets**

| Module Instance | Source     | Description        |
|-----------------|------------|--------------------|
| MCRC64_0        | PSC0_PSC_0 | MCRC64_0 reset     |
| MCU_MCRC64_0    | WKUP_PSC0  | MCU_MCRC64_0 reset |

**Table 4-178. ECC\_AGGR Hardware Requests**

| Module Instance | Module Interrupt Signal  | Destination Interrupt Input                   | Destination         | Description                    | Type  |
|-----------------|--------------------------|-----------------------------------------------|---------------------|--------------------------------|-------|
| MCRC64_0        | MCRC64_0_dma_event_[3:0] | DMASS0_INTAGGR_0_intaggr_levi_pend_IN_[31:28] | DMASS0_INTAGGR_0    | MCRC64_0 interrupt request     | pulse |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | GICSS0_spi_IN_166                             | GICSS0              | MCRC64_0 interrupt request     | level |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | R5FSS0_CORE0_intr_IN_119                      | R5FSS0_CORE0        | MCRC64_0 interrupt request     | level |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | TIFS0_nvic_IN_83                              | TIFS0               | MCRC64_0 interrupt request     | level |
| MCRC64_0        | MCRC64_0_int_mcrc_0      | HSM0_nvic_IN_83                               | HSM0                | MCRC64_0 interrupt request     | level |
| MCU_MCRC64_0    | MCU_MCRC64_0_int_mcrc_0  | MCU_M4FSS0_CORE0_nvic_IN_25                   | MCU_M4FSS0_CORE0_E0 | MCU_MCRC64_0 interrupt request | level |
| MCU_MCRC64_0    | MCU_MCRC64_0_int_mcrc_0  | GICSS0_spi_IN_192                             | GICSS0              | MCU_MCRC64_0 interrupt request | level |
| MCU_MCRC64_0    | MCU_MCRC64_0_int_mcrc_0  | R5FSS0_CORE0_intr_IN_192                      | R5FSS0_CORE0        | MCU_MCRC64_0 interrupt request | level |

**Table 4-179. ECC\_AGGR Clocks**

| Module Instance | Module Clock Input | Source Clock   | Source Control Register | Description                                 |
|-----------------|--------------------|----------------|-------------------------|---------------------------------------------|
| MCRC64_0        | FICLK              | MAIN_SYSCLK0/2 |                         | MCRC64_0 Functional and Interface Clock     |
| MCU_MCRC64_0    | FICLK              | MCU_SYSCLK0/2  |                         | MCU_MCRC64_0 Functional and Interface Clock |

#### 4.13.4.4 Interconnect ECC Aggregators

**Table 4-180. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0**

| RAM ID Name                                      | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|--------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S_VBUS  | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_SV_BUS  | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S_VBUS  | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_SV_BUS  | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU0_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SV_BUS       | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU0_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SV_BUS       | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SV_BUS     | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SV_BUS     | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SV_BUS     | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SV_BUS     | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SV_BUS     | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SV_BUS     | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SV_BUS     | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK7_ECC_SV_BUS     | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SV_BUS      | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SV_BUS      | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SV_BUS      | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SV_BUS      | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DDIRTY_SPRAM_ECC_SV_BUS          | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SV_BUS       | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SV_BUS       | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SV_BUS       | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SV_BUS       | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC_SV_BUS | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC_SV_BUS | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC_SV_BUS | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC_SV_BUS | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S_VBUS  | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |

Table 4-180. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)

| RAM ID Name                                         | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|-----------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_SV<br>BUS  | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S<br>VBUS  | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_SV<br>BUS  | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU1_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SV<br>BUS       | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU1_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SV<br>BUS       | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SV<br>US      | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SV<br>US      | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SV<br>US      | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SV<br>US      | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SV<br>US      | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SV<br>US      | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SV<br>US      | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK7_ECC_SV<br>US      | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SV<br>S        | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SV<br>S        | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SV<br>S        | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SV<br>S        | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DDIRTY_SPRAM_ECC_SV<br>BUS          | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SV<br>BUS       | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SV<br>BUS       | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SV<br>BUS       | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SV<br>BUS       | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC<br>_SVBUS | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC<br>_SVBUS | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC<br>_SVBUS | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC<br>_SVBUS | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S<br>VBUS  | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_SV<br>BUS  | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S<br>VBUS  | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |

**Table 4-180. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)**

| RAM ID Name                                      | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|--------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_SV_BUS  | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU2_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SV_BUS       | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU2_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SV_BUS       | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SV_B_US    | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SV_B_US    | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SV_B_US    | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SV_B_US    | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SV_B_US    | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SV_B_US    | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SV_B_US    | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK7_ECC_SV_B_US    | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SV_B_US     | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SV_B_US     | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SV_B_US     | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SV_B_US     | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DDIRTY_SPRAM_ECC_SV_BUS          | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SV_BUS       | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SV_BUS       | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SV_BUS       | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SV_BUS       | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC_SV_BUS | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC_SV_BUS | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC_SV_BUS | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC_SV_BUS | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S_VBUS  | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_S_VBUS  | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S_VBUS  | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_S_VBUS  | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SV_BUS       | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU3_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SV_BUS       | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |

Table 4-180. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)

| RAM ID Name                                        | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|----------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SVB<br>US    | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SVB<br>US    | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SVB<br>US    | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SVB<br>US    | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SVB<br>US    | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SVB<br>US    | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SVB<br>US    | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK7_ECC_SVB<br>US     | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SVBU<br>S     | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SVBU<br>S     | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SVBU<br>S     | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SVBU<br>S     | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DDIRTY_SPRAM_ECC_SVBU              | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SVBU           | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SVBU           | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SVBU           | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SVBU           | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC<br>_SVBU | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC<br>_SVBU | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC<br>_SVBU | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC<br>_SVBU | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY0_ECC_SVBU           | 0      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY1_ECC_SVBU           | 1      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY2_ECC_SVBU           | 2      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY3_ECC_SVBU           | 3      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY4_ECC_SVBU           | 4      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY5_ECC_SVBU           | 5      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY6_ECC_SVBU           | 6      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY7_ECC_SVBU           | 7      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY8_ECC_SVBU           | 8      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY9_ECC_SVBU           | 9      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY10_ECC_SVBU<br>S     | 10     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |

**Table 4-180. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)**

| RAM ID Name                                 | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|---------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY11_ECC_SVBU_S | 11     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY12_ECC_SVBU_S | 12     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY13_ECC_SVBU_S | 13     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY14_ECC_SVBU_S | 14     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY15_ECC_SVBU_S | 15     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_DATARAM_SPRAM_0_ECC_SVBU_S    | 16     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_1_ECC_SVBU_S    | 17     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_2_ECC_SVBU_S    | 18     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_3_ECC_SVBU_S    | 19     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_4_ECC_SVBU_S    | 20     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_5_ECC_SVBU_S    | 21     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_6_ECC_SVBU_S    | 22     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_7_ECC_SVBU_S    | 23     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |

**Table 4-181. Properties of ECC Aggregator Instance CPSW0**

| RAM ID Name | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| ALE_RAM     | 0      | ECC Wrapper | Inject with error capture | Yes             | 568       | 4 KB     |
| P0_RX_FIFO  | 1      | ECC Wrapper | Inject with error capture | Yes             | 256       | 32 B     |
| P0_TX_FIFO  | 2      | ECC Wrapper | Inject with error capture | Yes             | 256       | 32 B     |
| P1_RX_FIFO  | 3      | ECC Wrapper | Inject with error capture | Yes             | 256       | 32 B     |
| P1_TX_FIFO  | 4      | ECC Wrapper | Inject with error capture | Yes             | 256       | 32 B     |
| P2_RX_FIFO  | 5      | ECC Wrapper | Inject with error capture | Yes             | 256       | 32 B     |
| P2_TX_FIFO  | 6      | ECC Wrapper | Inject with error capture | Yes             | 256       | 32 B     |
| EST_RAM     | 19     | ECC Wrapper | Inject with error capture | Yes             | 22        | 704 B    |

**Table 4-182. Properties of ECC Aggregator Instance CSI\_RX\_IF0**

| RAM ID Name                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_RX_IF_RX_SHIM_DMA_PSIL_FIFO | 1      | ECC Wrapper | Inject with error capture | Yes             | 143       | 36 KB    |
| CSI_RX_IF_RAM_WRAPPER0_FIFO     | 2      | ECC Wrapper | Inject only               | Yes             | 45        | 11 KB    |
| CSI_RX_IF_RAM_WRAPPER1_FIFO     | 3      | ECC Wrapper | Inject only               | Yes             | 45        | 6 KB     |
| CSI_RX_IF_RAM_WRAPPER2_FIFO     | 4      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_RAM_WRAPPER3_FIFO     | 5      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |

**Table 4-182. Properties of ECC Aggregator Instance CSI\_RX\_IF0 (continued)**

| RAM ID Name           | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-----------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_RX_IF_VP0_VP_FIFO | 6      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |
| CSI_RX_IF_VP1_VP_FIFO | 7      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |

**Table 4-183. Properties of ECC Aggregator Instance CSI\_RX\_IF0**

| RAM ID Name          | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------------|--------|------------------|---------------------------|-----------------|------------------------|
| CSI_RX_IF_EDC_CTRL_0 | 0      | EDC Interconnect | Inject with error capture | Yes             | 2                      |

**Table 4-184. EDC checkers information for ECC Aggregator Instance CSI\_RX\_IF0**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CSI_RX_IF_EDC_CTRL_0   | 0        | 32    | Parity       |
| CSI_RX_IF_EDC_CTRL_0   | 1        | 32    | Parity       |

**Table 4-185. Properties of ECC Aggregator Instance DMASS0**

| RAM ID Name                      | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|----------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| DMSS_AM62_PKTDMA_CFG_CONFIG      | 0      | ECC Wrapper | Inject with error capture | Yes             | 96        | 2 KB     |
| DMSS_AM62_PKTDMA_CFG_STATE       | 1      | ECC Wrapper | Inject with error capture | Yes             | 220       | 1 KB     |
| DMSS_AM62_PKTDMA_TPCFIFO_F0      | 2      | ECC Wrapper | Inject with error capture | Yes             | 141       | 3 KB     |
| DMSS_AM62_PKTDMA_TPCFIFO_F1      | 3      | ECC Wrapper | Inject with error capture | Yes             | 141       | 3 KB     |
| DMSS_AM62_PKTDMA_RPCFIFO_F0      | 4      | ECC Wrapper | Inject with error capture | Yes             | 128       | 2 KB     |
| DMSS_AM62_PKTDMA_RPCFIFO_F1      | 5      | ECC Wrapper | Inject with error capture | Yes             | 128       | 2 KB     |
| DMSS_AM62_PKTDMA_RPCFIFO_WC      | 6      | ECC Wrapper | Inject with error capture | Yes             | 22        | 792 B    |
| DMSS_AM62_PKTDMA_STATS_STST0     | 7      | ECC Wrapper | Inject with error capture | Yes             | 96        | 348 B    |
| DMSS_AM62_PKTDMA_STATS_STSR0     | 8      | ECC Wrapper | Inject with error capture | Yes             | 128       | 384 B    |
| DMSS_AM62_PKTDMA_RINGOCC_CNTR    | 9      | ECC Wrapper | Inject with error capture | Yes             | 18        | 675 B    |
| DMSS_AM62_BCDMA_CFG_CONFIG       | 10     | ECC Wrapper | Inject with error capture | Yes             | 86        | 1 KB     |
| DMSS_AM62_BCDMA_CFG_STATE        | 11     | ECC Wrapper | Inject with error capture | Yes             | 400       | 6 KB     |
| DMSS_AM62_BCDMA_PCFIFO_D FIFO_F0 | 12     | ECC Wrapper | Inject with error capture | Yes             | 128       | 3 KB     |
| DMSS_AM62_BCDMA_PCFIFO_D FIFO_F1 | 13     | ECC Wrapper | Inject with error capture | Yes             | 128       | 3 KB     |
| DMSS_AM62_BCDMA_TPCFIFO_F0       | 14     | ECC Wrapper | Inject with error capture | Yes             | 141       | 2 KB     |
| DMSS_AM62_BCDMA_TPCFIFO_F1       | 15     | ECC Wrapper | Inject with error capture | Yes             | 141       | 2 KB     |

**Table 4-185. Properties of ECC Aggregator Instance DMASS0 (continued)**

| RAM ID Name                                       | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| DMSS_AM62_BCDMA_RPCFIFO_F0                        | 16     | ECC Wrapper | Inject with error capture | Yes             | 128       | 4 KB     |
| DMSS_AM62_BCDMA_RPCFIFO_F1                        | 17     | ECC Wrapper | Inject with error capture | Yes             | 128       | 4 KB     |
| DMSS_AM62_BCDMA_RPCFIFO_WC                        | 18     | ECC Wrapper | Inject with error capture | Yes             | 19        | 1 KB     |
| DMSS_AM62_BCDMA_STATS_STST0                       | 19     | ECC Wrapper | Inject with error capture | Yes             | 96        | 648 B    |
| DMSS_AM62_BCDMA_STATS_STSR0                       | 20     | ECC Wrapper | Inject with error capture | Yes             | 96        | 720 B    |
| DMSS_AM62_BCDMA_RINGOCC_CNTR                      | 21     | ECC Wrapper | Inject with error capture | Yes             | 18        | 369 B    |
| DMSS_AM62_INTAGGR_STATREG_SR_SPRAM_184X128_SWW_SR | 22     | ECC Wrapper | Inject with error capture | Yes             | 128       | 3 KB     |
| DMSS_AM62_INTAGGR_COMMON_IM_TPRAM_1531X34_SWW_SR  | 23     | ECC Wrapper | Inject with error capture | Yes             | 34        | 6 KB     |
| DMSS_AM62_IPCSS_RINGACC_STRAM                     | 24     | ECC Wrapper | Inject with error capture | Yes             | 216       | 540 B    |
| DMSS_AM62_IPCSS_SEC_PROXY_BUF_STRAM               | 25     | ECC Wrapper | Inject with error capture | Yes             | 91        | 865 B    |
| DMSS_AM62_IPCSS_SEC_PROXY_BUFRAM                  | 26     | ECC Wrapper | Inject with error capture | Yes             | 64        | 64 B     |
| DMSS_AM62_IPCSS_MSRAM_ECC0                        | 27     | ECC Wrapper | Inject with error capture | Yes             | 64        | 16 KB    |

**Table 4-186. Properties of ECC Aggregator Instance ECC\_AGGR0**

| RAM ID Name             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| IMAILBOX1_MAIN_0_RAMECC | 0      | ECC Wrapper | Inject with error capture | Yes             | 32        | 256 B    |

**Table 4-187. Properties of ECC Aggregator Instance ECC\_AGGR0**

| RAM ID Name                                                                                                               | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|---------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                                                 | 1      | EDC Interconnect | Inject with error capture | Yes             | 73                     |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC                     | 2      | EDC Interconnect | Inject with error capture | Yes             | 54                     |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC                           | 3      | EDC Interconnect | Inject with error capture | Yes             | 15                     |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_DST_BUSECC | 4      | EDC Interconnect | Inject with error capture | Yes             | 4                      |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSECC | 5      | EDC Interconnect | Inject with error capture | Yes             | 15                     |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_DS_T_BUSECC                              | 6      | EDC Interconnect | Inject with error capture | Yes             | 4                      |

**Table 4-187. Properties of ECC Aggregator Instance ECC\_AGGR0 (continued)**

| RAM ID Name                                                                                                                                                            | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SR_C_BUSECC                                                                           | 7      | EDC Interconnect | Inject with error capture | Yes             | 15                     |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VB_USP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUSP_S_BRIDGE_BUSECC                                                                      | 8      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VB_USP_S_P2P_BRIDGE_ISMS_MAIN_0_TIFS_VBUSP_S_BRIDGE_BUSECC                                                                    | 9      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62 MCU_CBASS_DATA_L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62 MCU_CBASS_DATA_L0_BRIDGE_DST_BUSECC | 10     | EDC Interconnect | Inject with error capture | Yes             | 10                     |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62 MCU_CBASS_DATA_L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62 MCU_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 11     | EDC Interconnect | Inject with error capture | Yes             | 17                     |
| IP2P_SA3_DMSS_CFG_DST_BUSECC                                                                                                                                           | 12     | EDC Interconnect | Inject with error capture | Yes             | 4                      |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                           | 13     | EDC Interconnect | Inject with error capture | Yes             | 15                     |
| IP2P_SA3_PKTDMA_CRED_DST_BUSECC                                                                                                                                        | 14     | EDC Interconnect | Inject with error capture | Yes             | 4                      |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                        | 15     | EDC Interconnect | Inject with error capture | Yes             | 15                     |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 0        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 1        | 32    | EDC          |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 2        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 3        | 48    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 4        | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 5        | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 6        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 7        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 8        | 10    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 9        | 5     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 10       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 11       | 4     | Parity       |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 12       | 2     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 13       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 14       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 15       | 2     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 16       | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 17       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 18       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 19       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 20       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 21       | 32    | EDC          |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 22       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 23       | 48    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 24       | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 25       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 26       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 27       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 28       | 10    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 29       | 5     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 30       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 31       | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 32       | 2     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 33       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 34       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 35       | 2     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 36       | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 37       | 1     | Parity       |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 38       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 39       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 40       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 41       | 32    | EDC          |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 42       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 43       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 44       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 45       | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 46       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 47       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 48       | 10    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 49       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 50       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 51       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 52       | 32    | EDC          |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 53       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 54       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 55       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 56       | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 57       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 58       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 59       | 10    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 60       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 61       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 62       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC | 63       | 32    | EDC          |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 64       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 65       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 66       | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 67       | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 68       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 69       | 12    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 70       | 10    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 71       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_HSM_CLK_1_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_1_BUSECC                             | 72       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 0        | 1     | Redundant    |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 1        | 12    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 2        | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 3        | 10    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 4        | 48    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 5        | 2     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 6        | 3     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 7        | 4     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 8        | 3     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 9        | 3     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 10       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 11       | 2     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 12       | 8     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 13       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 14       | 4     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 15       | 2     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 16       | 1     | Redundant    |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 17       | 10    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 18       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 19       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 20       | 5     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 21       | 16    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 22       | 32    | EDC          |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 23       | 32    | EDC          |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 24       | 32    | EDC          |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 25       | 32    | EDC          |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 26       | 1     | Redundant    |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 27       | 1     | Redundant    |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 28       | 1     | Redundant    |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 29       | 1     | Redundant    |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 30       | 1     | Redundant    |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 31       | 12    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 32       | 4     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 33       | 12    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 34       | 10    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 35       | 10    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 36       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 37       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 38       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 39       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 40       | 4     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 41       | 3     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 42       | 3     | Parity       |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 43       | 1     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 44       | 32    | EDC          |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 45       | 32    | EDC          |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 46       | 3     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 47       | 1     | Redundant    |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 48       | 12    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 49       | 10    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 50       | 3     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 51       | 12    | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 52       | 4     | Parity       |
| IAM62_MAIN_IPCSS_CBASS_MAIN_0_AM62_MAIN_IPCSS_CBASS_HSM_CLK_2_CLK_EDC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC | 53       | 1     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 0        | 1     | Redundant    |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 1        | 32    | EDC          |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 2        | 1     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 3        | 24    | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 4        | 4     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 5        | 3     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 6        | 1     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 7        | 1     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 8        | 10    | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 9        | 2     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 10       | 3     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 11       | 1     | Parity       |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 12       | 1     | Redundant    |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 13       | 32    | EDC          |
| IAM62_MAIN_FW_CBASS_MAIN_0_AM62_MAIN_FW_CBASS_HSM_CLK_2_CLK_E_DC_CTRL_CBASS_INT_HSM_CLK_2_BUSECC      | 14       | 1     | Redundant    |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                     | Group ID | Width | Checker Type |
|----------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_DST_BUSEC_C | 0        | 1     | Redundant    |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_DST_BUSEC_C | 1        | 1     | Redundant    |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_DST_BUSEC_C | 2        | 10    | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_DST_BUSEC_C | 3        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 0        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 1        | 1     | Redundant    |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 2        | 10    | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 3        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 4        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 5        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 6        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 7        | 2     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 8        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 9        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 10       | 10    | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 11       | 5     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 12       | 3     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 13       | 4     | Parity       |
| AM62_MAIN_FW_CBASS_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_P2P_BRIDGE_IAM62 MCU_CBASS_MCU_0_CBASS_DMSC_SLV_BRIDGE_SRC_BUSE_CC | 14       | 2     | Parity       |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                         | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_DST_BUSECC    | 0        | 1     | Redundant    |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_DST_BUSECC    | 1        | 1     | Redundant    |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_DST_BUSECC    | 2        | 24    | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_DST_BUSECC    | 3        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 0        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 1        | 1     | Redundant    |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 2        | 24    | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 3        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 4        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 5        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 6        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 7        | 2     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 8        | 3     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 9        | 1     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 10       | 10    | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 11       | 5     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 12       | 3     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 13       | 4     | Parity       |
| AM62_MAIN_FW_CBASS_ISMS_MAIN_0_FWMGR_CFG_P2P_BRIDGE_ISMS_MAIN_0_FWMGR_CFG_BRIDGE_SRC_BUSECC    | 14       | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUP_S_BRIDGE_BUSECC | 0        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUP_S_BRIDGE_BUSECC | 1        | 32    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUP_S_BRIDGE_BUSECC | 2        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUP_S_BRIDGE_BUSECC | 3        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUP_S_BRIDGE_BUSECC | 4        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUP_S_BRIDGE_BUSECC | 5        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUP_S_P2P_BRIDGE_ISMS_MAIN_0_HSM_VBUP_S_BRIDGE_BUSECC | 6        | 1     | Redundant    |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                         | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_HSM_VBUSBP_S_BRIDGE_BUSECC                                                                         | 7        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_HSM_VBUSBP_S_BRIDGE_BUSECC                                                                         | 8        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_HSM_VBUSBP_S_BRIDGE_BUSECC                                                                         | 9        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_HSM_VBUSBP_S_BRIDGE_BUSECC                                                                         | 10       | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_HSM_VBUSBP_S_BRIDGE_BUSECC                                                                         | 11       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_HSM_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_HSM_VBUSBP_S_BRIDGE_BUSECC                                                                         | 12       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 0        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 1        | 32    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 2        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 3        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 4        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 5        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 6        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 7        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 8        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 9        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 10       | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 11       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_ISMS_MAIN_0_TIFS_VBUSBP_S_P2P_BRIDGE_IS<br>MS_MAIN_0_TIFS_VBUSBP_S_BRIDGE_BUSECC                                                                       | 12       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU_CBASS_DATA_L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU_CBASS_DATA_L0_BRIDGE_DST_BUSECC | 0        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU_CBASS_DATA_L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU_CBASS_DATA_L0_BRIDGE_DST_BUSECC | 1        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU_CBASS_DATA_L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU_CBASS_DATA_L0_BRIDGE_DST_BUSECC | 2        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU_CBASS_DATA_L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU_CBASS_DATA_L0_BRIDGE_DST_BUSECC | 3        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU_CBASS_DATA_L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU_CBASS_DATA_L0_BRIDGE_DST_BUSECC | 4        | 36    | Parity       |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                         | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_DST_BUSECC | 5        | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_DST_BUSECC | 6        | 32    | EDC          |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_DST_BUSECC | 7        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_DST_BUSECC | 8        | 8     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_DST_BUSECC | 9        | 14    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 0        | 32    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 1        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 2        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 3        | 1     | Redundant    |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 4        | 36    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 5        | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 6        | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 7        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 8        | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 9        | 2     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 10       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 11       | 1     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 12       | 10    | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 13       | 5     | Parity       |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                         | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 14       | 3     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 15       | 4     | Parity       |
| AM62_MAIN_CENTRAL_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_A<br>M62 MCU CBASS DATA L0_P2M_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CB<br>ASS_TO_AM62 MCU CBASS DATA L0_BRIDGE_SRC_BUSECC | 16       | 4     | Parity       |
| IP2P_SA3_DMSS_CFG_DST_BUSECC                                                                                                                                                   | 0        | 1     | Redundant    |
| IP2P_SA3_DMSS_CFG_DST_BUSECC                                                                                                                                                   | 1        | 1     | Redundant    |
| IP2P_SA3_DMSS_CFG_DST_BUSECC                                                                                                                                                   | 2        | 23    | Parity       |
| IP2P_SA3_DMSS_CFG_DST_BUSECC                                                                                                                                                   | 3        | 3     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 0        | 1     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 1        | 1     | Redundant    |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 2        | 23    | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 3        | 3     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 4        | 3     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 5        | 1     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 6        | 1     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 7        | 2     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 8        | 3     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 9        | 1     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 10       | 10    | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 11       | 5     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 12       | 3     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 13       | 4     | Parity       |
| IP2P_SA3_DMSS_CFG_SRC_BUSECC                                                                                                                                                   | 14       | 2     | Parity       |
| IP2P_SA3_PKTDMA_CRED_DST_BUSECC                                                                                                                                                | 0        | 1     | Redundant    |
| IP2P_SA3_PKTDMA_CRED_DST_BUSECC                                                                                                                                                | 1        | 1     | Redundant    |
| IP2P_SA3_PKTDMA_CRED_DST_BUSECC                                                                                                                                                | 2        | 10    | Parity       |
| IP2P_SA3_PKTDMA_CRED_DST_BUSECC                                                                                                                                                | 3        | 3     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 0        | 1     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 1        | 1     | Redundant    |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 2        | 10    | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 3        | 3     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 4        | 3     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 5        | 1     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 6        | 1     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 7        | 2     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 8        | 3     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 9        | 1     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 10       | 10    | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 11       | 5     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 12       | 3     | Parity       |
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC                                                                                                                                                | 13       | 4     | Parity       |

**Table 4-188. EDC checkers information for ECC Aggregator Instance ECC\_AGGR0 (continued)**

| Protected Interconnect          | Group ID | Width | Checker Type |
|---------------------------------|----------|-------|--------------|
| IP2P_SA3_PKTDMA_CRED_SRC_BUSECC | 14       | 2     | Parity       |

**Table 4-189. Properties of ECC Aggregator Instance FSS0**

| RAM ID Name         | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| OSPI_OSPI_WRAP_SRAM | 0      | ECC Wrapper | Inject with error capture | Yes             | 32        | 1 KB     |

**Table 4-190. Properties of ECC Aggregator Instance GICSS0**

| RAM ID Name | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|-------------|--------|-------------|-------------|-----------------|-----------|----------|
| ICB_RAMECC  | 0      | ECC Wrapper | Inject only | No              | 16        | 640 B    |
| ITE_RAMECC  | 1      | ECC Wrapper | Inject only | No              | 58        | 464 B    |
| LPI_RAMECC  | 2      | ECC Wrapper | Inject only | No              | 26        | 208 B    |

**Table 4-191. Properties of ECC Aggregator Instance ICSSM0**

| RAM ID Name                    | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|--------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| ICSS_M_CORE_DRAM0_ECC          | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 8 KB     |
| ICSS_M_CORE_DRAM1_ECC          | 1      | ECC Wrapper | Inject with error capture | No              | 32        | 8 KB     |
| ICSS_M_CORE_PR1_PDSP0_IRAM_ECC | 2      | ECC Wrapper | Inject with error capture | No              | 32        | 16 KB    |
| ICSS_M_CORE_PR1_PDSP1_IRAM_ECC | 3      | ECC Wrapper | Inject with error capture | No              | 32        | 16 KB    |
| ICSS_M_CORE_RAM_ECC            | 4      | ECC Wrapper | Inject with error capture | No              | 32        | 32 KB    |

**Table 4-192. Properties of ECC Aggregator Instance MCAN0**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MCANSS_MSGMEM_WRAP_MSGMEM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 17 KB    |

**Table 4-193. Properties of ECC Aggregator Instance MCAN0**

| RAM ID Name    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------|--------|------------------|---------------------------|-----------------|------------------------|
| CTRL_EDC_VBUSS | 1      | EDC Interconnect | Inject with error capture | Yes             | 1                      |

**Table 4-194. EDC checkers information for ECC Aggregator Instance MCAN0**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CTRL_EDC_VBUSS         | 0        | 32    | Parity       |

**Table 4-195. Properties of ECC Aggregator Instance MCU\_ECC\_AGGR0**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| ISAM62_MCU2CENTRAL_VBUSH_GASKET_MCU_0_RD_RAMECC | 9      | ECC Wrapper | Inject with error capture | Yes             | 76        | 38 B     |
| ISAM62_MCU2CENTRAL_VBUSH_GASKET_MCU_0_WR_RAMECC | 10     | ECC Wrapper | Inject with error capture | Yes             | 76        | 38 B     |
| ISAM62_MCU2DM_VBUSH_GASKET_MCU_1_RD_RAMECC      | 13     | ECC Wrapper | Inject with error capture | Yes             | 76        | 38 B     |
| ISAM62_MCU2DM_VBUSH_GASKET_MCU_1_WR_RAMECC      | 14     | ECC Wrapper | Inject with error capture | Yes             | 76        | 38 B     |

**Table 4-196. Properties of ECC Aggregator Instance MCU\_ECC\_AGGR0**

| RAM ID Name                                                                                                                 | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-----------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| BLAZAR_VBUSH_M_P2P_DST_BUSECC                                                                                               | 0      | EDC Interconnect | Inject with error capture | Yes             | 4                      |
| BLAZAR_VBUSH_M_P2P_SRC_BUSECC                                                                                               | 1      | EDC Interconnect | Inject with error capture | Yes             | 15                     |
| BLAZAR_VBUSH_S_P2P_DST_BUSECC                                                                                               | 2      | EDC Interconnect | Inject with error capture | Yes             | 5                      |
| BLAZAR_VBUSH_S_P2P_SRC_BUSECC                                                                                               | 3      | EDC Interconnect | Inject with error capture | Yes             | 17                     |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_S_ERR_SLV_P2P_BRIDGE_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC           | 4      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSH_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSH_S_BRIDGE_BUSECC                                         | 5      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| ISAM62_CENTRAL2MCU_VBUSH_GASKET_MCU_0_EDC_CTRL                                                                              | 6      | EDC Interconnect | Inject with error capture | Yes             | 1                      |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSH_GASKET_MCU_0_CFG_P2P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSH_GASKET_MCU_0_CFG_BRIDGE_BUSECC | 7      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| ISAM62_MCU2CENTRAL_VBUSH_GASKET_MCU_0_EDC_CTRL                                                                              | 8      | EDC Interconnect | Inject with error capture | Yes             | 69                     |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSH_GASKET_MCU_1_CFG_P2P_BRIDGE_ISAM62_MCU2DM_VBUSH_GASKET_MCU_1_CFG_BRIDGE_BUSECC           | 11     | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| ISAM62_MCU2DM_VBUSH_GASKET_MCU_1_EDC_CTRL                                                                                   | 12     | EDC Interconnect | Inject with error capture | Yes             | 69                     |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC                         | 15     | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYSCLK0_2_BUSECC                                                    | 16     | EDC Interconnect | Inject with error capture | Yes             | 215                    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYSCLK0_4_BUSECC                                                    | 17     | EDC Interconnect | Inject with error capture | Yes             | 103                    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_EDC_CTRL_BUSECC_0                                         | 18     | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_EDC_CTRL_BUSECC_1                                         | 19     | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_EDC_CTRL_BUSECC_2                                         | 20     | EDC Interconnect | Inject with error capture | Yes             | 22                     |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_EDC_CTRL_BUSECC_0                                         | 21     | EDC Interconnect | Inject with error capture | Yes             | 256                    |

**Table 4-196. Properties of ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| RAM ID Name                                                                                                                                               | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_EDC_CTRL_BUSECC_1                                                                       | 22     | EDC Interconnect | Inject with error capture | Yes             | 56                     |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDGE_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_DST_BUSECC                                     | 23     | EDC Interconnect | Inject with error capture | Yes             | 5                      |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDGE_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC                                     | 24     | EDC Interconnect | Inject with error capture | Yes             | 17                     |
| AM62_MCU_CBASS_DEFAULT_ERR_AM62_MCU_CBASS_DEFAULT_ERR_EDC_CTRL_BUSECC                                                                                     | 25     | EDC Interconnect | Inject with error capture | Yes             | 5                      |
| AM62_MCU_CBASS_DEFAULT_MMRS_AM62_MCU_CBA_S_DEFAULT_MMRS_EDC_CTRL_BUSECC                                                                                   | 26     | EDC Interconnect | Inject with error capture | Yes             | 8                      |
| AM62_MCU_CBASS_INT_DMSC_SCR_AM62_MCU_CBAS_S_INT_DMSC_SCR_EDC_CTRL_BUSECC                                                                                  | 27     | EDC Interconnect | Inject with error capture | Yes             | 42                     |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                                                                                                 | 28     | EDC Interconnect | Inject with error capture | Yes             | 19                     |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ER_R_SCR_EDC_CTRL_BUSECC                                                                                            | 29     | EDC Interconnect | Inject with error capture | Yes             | 42                     |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                   | 30     | EDC Interconnect | Inject with error capture | Yes             | 19                     |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 31     | EDC Interconnect | Inject with error capture | Yes             | 31                     |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_DST_BUSECC   | 32     | EDC Interconnect | Inject with error capture | Yes             | 5                      |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 33     | EDC Interconnect | Inject with error capture | Yes             | 17                     |
| SAM62_MCU_ECC_AGGR_EDC_CTRL                                                                                                                               | 34     | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0**

| Protected Interconnect         | Group ID | Width | Checker Type |
|--------------------------------|----------|-------|--------------|
| BLAZAR_VBUSBP_M_P2P_DST_BUSECC | 0        | 1     | Redundant    |
| BLAZAR_VBUSBP_M_P2P_DST_BUSECC | 1        | 1     | Redundant    |
| BLAZAR_VBUSBP_M_P2P_DST_BUSECC | 2        | 36    | Parity       |
| BLAZAR_VBUSBP_M_P2P_DST_BUSECC | 3        | 3     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 0        | 1     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 1        | 1     | Redundant    |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 2        | 36    | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 3        | 3     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 4        | 3     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 5        | 1     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 6        | 1     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 7        | 2     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 8        | 3     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC | 9        | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                              | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC                                                                                      | 10       | 10    | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC                                                                                      | 11       | 5     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC                                                                                      | 12       | 3     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC                                                                                      | 13       | 4     | Parity       |
| BLAZAR_VBUSBP_M_P2P_SRC_BUSECC                                                                                      | 14       | 2     | Parity       |
| BLAZAR_VBUSBP_S_P2P_DST_BUSECC                                                                                      | 0        | 1     | Redundant    |
| BLAZAR_VBUSBP_S_P2P_DST_BUSECC                                                                                      | 1        | 1     | Redundant    |
| BLAZAR_VBUSBP_S_P2P_DST_BUSECC                                                                                      | 2        | 1     | Redundant    |
| BLAZAR_VBUSBP_S_P2P_DST_BUSECC                                                                                      | 3        | 32    | Parity       |
| BLAZAR_VBUSBP_S_P2P_DST_BUSECC                                                                                      | 4        | 3     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 0        | 1     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 1        | 32    | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 2        | 1     | Redundant    |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 3        | 1     | Redundant    |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 4        | 32    | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 5        | 3     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 6        | 3     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 7        | 1     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 8        | 1     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 9        | 2     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 10       | 3     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 11       | 1     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 12       | 10    | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 13       | 5     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 14       | 3     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 15       | 4     | Parity       |
| BLAZAR_VBUSBP_S_P2P_SRC_BUSECC                                                                                      | 16       | 2     | Parity       |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 0        | 1     | Parity       |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 1        | 32    | Parity       |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 4        | 1     | Redundant    |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 5        | 1     | Redundant    |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 6        | 1     | Redundant    |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 7        | 8     | Parity       |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 8        | 8     | Parity       |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDG<br>E_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 9        | 8     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                         | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC                | 10       | 8     | Parity       |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC                | 11       | 1     | Parity       |
| AM62_MCU_CBASS_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_MCU_CBASS_MCU_0_CBASS_ERR_SLV_BRIDGE_BUSECC                | 12       | 1     | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 0        | 1     | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 1        | 32    | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 4        | 1     | Redundant    |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 5        | 1     | Redundant    |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 6        | 1     | Redundant    |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 7        | 8     | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 8        | 8     | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 9        | 8     | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 10       | 8     | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 11       | 1     | Parity       |
| AM62_MCU_CBASS_IBLAZAR_MCU_0_VBUSP_S_P2P_BRIDGE_IBLAZAR_MCU_0_VBUSP_S_BRIDGE_BUSECC                                            | 12       | 1     | Parity       |
| ISAM62_CENTRAL2MCU_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                 | 0        | 48    | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2_P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B_BUSECC | 0        | 1     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2_P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B_BUSECC | 1        | 32    | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2_P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B_BUSECC | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2_P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B_BUSECC | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2_P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B_BUSECC | 4        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2_P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B_BUSECC | 5        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2_P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B_BUSECC | 6        | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                              | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2<br>P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B<br>USECC | 7        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2<br>P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B<br>USECC | 8        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2<br>P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B<br>USECC | 9        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2<br>P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B<br>USECC | 10       | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2<br>P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B<br>USECC | 11       | 1     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_P2<br>P_BRIDGE_ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_CFG_BRIDGE_B<br>USECC | 12       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 0        | 1     | Redundant    |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 1        | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 2        | 4     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 3        | 10    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 4        | 32    | EDC          |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 5        | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 6        | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 7        | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 8        | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 9        | 30    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 10       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 11       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 12       | 10    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 13       | 12    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 14       | 4     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 15       | 3     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 16       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 17       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 18       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 19       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 20       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 21       | 10    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 22       | 10    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 23       | 12    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 24       | 4     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 25       | 3     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 26       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 27       | 10    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 28       | 3     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 29       | 3     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSM_GASKET_MCU_0_EDC_CTRL                                                                                      | 30       | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 31       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 32       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 33       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 34       | 3     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 35       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 36       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 37       | 1     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 38       | 30    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 39       | 6     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 40       | 6     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 41       | 6     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 42       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 43       | 10    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 44       | 3     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 45       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 46       | 4     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 47       | 5     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 48       | 4     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 49       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 50       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 51       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 52       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 53       | 22    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 54       | 22    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 55       | 10    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 56       | 3     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 57       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 58       | 4     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 59       | 5     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 60       | 4     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 61       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 62       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 63       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 64       | 2     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 65       | 55    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 66       | 55    | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 67       | 8     | Parity       |
| ISAM62_MCU2CENTRAL_VBUSHM_GASKET MCU_0_EDC_CTRL                                                                         | 68       | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_BRIDGE_BUSECC | 0        | 1     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_BRIDGE_BUSECC | 1        | 32    | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_BRIDGE_BUSECC | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET MCU_1_CFG_BRIDGE_BUSECC | 3        | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 4        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 5        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 6        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 7        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 8        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 9        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 10       | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 11       | 1     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_P2P_BRI<br>DGE_ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_CFG_BRIDGE_BUSECC | 12       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 0        | 1     | Redundant    |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 1        | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 2        | 4     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 3        | 10    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 4        | 32    | EDC          |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 5        | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 6        | 2     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 7        | 2     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 8        | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 9        | 30    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 10       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 11       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 12       | 10    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 13       | 12    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 14       | 4     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 15       | 3     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 16       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 17       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 18       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 19       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 20       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 21       | 10    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 22       | 10    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 23       | 12    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 24       | 4     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 25       | 3     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 26       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 27       | 10    | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 28       | 3     | Parity       |
| ISAM62_MCU2DM_VBUSHM_GASKET_MCU_1_EDC_CTRL                                                                              | 29       | 3     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                  | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 30       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 31       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 32       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 33       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 34       | 4     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 35       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 36       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 37       | 1     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 38       | 30    | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 39       | 6     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 40       | 6     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 41       | 6     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 42       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 43       | 10    | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 44       | 3     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 45       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 46       | 4     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 47       | 5     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 48       | 4     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 49       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 50       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 51       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 52       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 53       | 22    | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 54       | 22    | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 55       | 10    | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 56       | 3     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 57       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 58       | 4     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 59       | 5     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 60       | 4     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 61       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 62       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 63       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 64       | 2     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 65       | 55    | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 66       | 55    | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 67       | 8     | Parity       |
| ISAM62_MCU2DM_VBUSM_GASKET MCU_1_EDC_CTRL                                                               | 68       | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 0        | 1     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 1        | 32    | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 2        | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                  | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 4        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 5        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 6        | 1     | Redundant    |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 7        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 8        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 9        | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 10       | 8     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 11       | 1     | Parity       |
| AM62_MCU_CBASS_ISAM62_MCU_ECC_AGGR_MCU_0_CFG_P2P_BRIDGE_ISA<br>M62_MCU_ECC_AGGR_MCU_0_CFG_BRIDGE_BUSECC | 12       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 0        | 36    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 1        | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 2        | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 3        | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 4        | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 5        | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 6        | 25    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 7        | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 8        | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 9        | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 10       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 11       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 12       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 13       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 14       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC                            | 15       | 10    | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 16       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 17       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 18       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 19       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 20       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 21       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 22       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 23       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 24       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 25       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 26       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 27       | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 28       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 29       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 30       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 31       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 32       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 33       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 34       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 35       | 5     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 36       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 37       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 38       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 39       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 40       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 41       | 2     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                       | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 42       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 43       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 44       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 45       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 46       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 47       | 8     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 48       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 49       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 50       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 51       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 52       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 53       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 54       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 55       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 56       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 57       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 58       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 59       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 60       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 61       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 62       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 63       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 64       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 65       | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 66       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 67       | 9     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 68       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 69       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 70       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 71       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 72       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 73       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 74       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 75       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 76       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 77       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 78       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 79       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 80       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 81       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 82       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 83       | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 84       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 85       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 86       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 87       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 88       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 89       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 90       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 91       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 92       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 93       | 12    | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                       | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 94       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 95       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 96       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 97       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 98       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 99       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 100      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 101      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 102      | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 103      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 104      | 16    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 105      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 106      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 107      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 108      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 109      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 110      | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 111      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 112      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 113      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 114      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 115      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 116      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 117      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 118      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 119      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 120      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 121      | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 122      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 123      | 16    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 124      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 125      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 126      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 127      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 128      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 129      | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 130      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 131      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 132      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 133      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 134      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 135      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 136      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 137      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 138      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 139      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 140      | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 141      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 142      | 36    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 143      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 144      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 145      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                       | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 146      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 147      | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 148      | 5     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 149      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 150      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 151      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 152      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 153      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 154      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 155      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 156      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 157      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 158      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 159      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 160      | 8     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 161      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 162      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 163      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 164      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 165      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 166      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 167      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 168      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 169      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 170      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 171      | 4     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 172      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 173      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 174      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 175      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 176      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 177      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 178      | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 179      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 180      | 36    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 181      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 182      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 183      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 184      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 185      | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 186      | 5     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 187      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 188      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 189      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 190      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 191      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 192      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 193      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 194      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 195      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 196      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_2_BUSECC | 197      | 2     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                       | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 198      | 8     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 199      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 200      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 201      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 202      | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 203      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 204      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 205      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 206      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 207      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 208      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 209      | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 210      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 211      | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 212      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 213      | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_2_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_2_BUSECC | 214      | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 1        | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 2        | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 3        | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 4        | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 5        | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 6        | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 7        | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 8        | 12    | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 9        | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 10       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 11       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 12       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 13       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 14       | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 15       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 16       | 11    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 17       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 18       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 19       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 20       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 21       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 22       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 23       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 24       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 25       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 26       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 27       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 28       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 29       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 30       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 31       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 32       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 33       | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 34       | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                       | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 35       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 36       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 37       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 38       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 39       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 40       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 41       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 42       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 43       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 44       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 45       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 46       | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 47       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 48       | 8     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 49       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 50       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 51       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 52       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 53       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 54       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 55       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 56       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 57       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 58       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 59       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS<br>CLK0_4_BUSECC | 60       | 32    | EDC          |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 61       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 62       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 63       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 64       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 65       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 66       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 67       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 68       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 69       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 70       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 71       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 72       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 73       | 32    | EDC          |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 74       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 75       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 76       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 77       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 78       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 79       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 80       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 81       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 82       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 83       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 84       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 85       | 1     | Redundant    |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC | 86       | 32    | EDC          |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                               | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 87       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 88       | 8     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 89       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 90       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 91       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 92       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 93       | 10    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 94       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 95       | 4     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 96       | 12    | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 97       | 2     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 98       | 3     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 99       | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 100      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 101      | 1     | Parity       |
| AM62_MCU_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_MCU_SYS_CLK0_4_BUSECC            | 102      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 1        | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 2        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 3        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 4        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 5        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 6        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 7        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 8        | 2     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL_K2_SCR_EDC_CTRL_BUSECC_0 | 9        | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 10       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 11       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 12       | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 13       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 14       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 15       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 16       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 17       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 18       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 19       | 2     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 20       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 21       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 22       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 23       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 24       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 25       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 26       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 27       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 28       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 29       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 30       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 31       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 32       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 33       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 34       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 35       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 36       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 37       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 38       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 39       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 40       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 41       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 42       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 43       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 44       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 45       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 46       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 47       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 48       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 49       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 50       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 51       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 52       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 53       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 54       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 55       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 56       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 57       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 58       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 59       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 60       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 61       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 62       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 63       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 64       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 65       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 66       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 67       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 68       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 69       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 70       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 71       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 72       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 73       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 74       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 75       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 76       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 77       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 78       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 79       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 80       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 81       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 82       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 83       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 84       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 85       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 86       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 87       | 4     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 88       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 89       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 90       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 91       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 92       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 93       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 94       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 95       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 96       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 97       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 98       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 99       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 100      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 101      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 102      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 103      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 104      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 105      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 106      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 107      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 108      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 109      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 110      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 111      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 112      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 113      | 4     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 114      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 115      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 116      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 117      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 118      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 119      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 120      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 121      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 122      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 123      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 124      | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 125      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 126      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 127      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 128      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 129      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 130      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 131      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 132      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 133      | 13    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 134      | 18    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 135      | 14    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 136      | 15    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 137      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 138      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 139      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 140      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 141      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 142      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 143      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 144      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 145      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 146      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 147      | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 148      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 149      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 150      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 151      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 152      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 153      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 154      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 155      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 156      | 11    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 157      | 16    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 158      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 159      | 13    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 160      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 161      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 162      | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 163      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 164      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 165      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 166      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 167      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 168      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 169      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 170      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 171      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 172      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 173      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 174      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 175      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 176      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 177      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 178      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 179      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 180      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 181      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 182      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 183      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 184      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 185      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 186      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 187      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 188      | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 189      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 190      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 191      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 192      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 193      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 194      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 195      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 196      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 197      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 198      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 199      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 200      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 201      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 202      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 203      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 204      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 205      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 206      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 207      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 208      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 209      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 210      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 211      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 212      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 213      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 214      | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 215      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 216      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 217      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 218      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 219      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 220      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 221      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 222      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 223      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 224      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 225      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 226      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 227      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 228      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 229      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 230      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 231      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 232      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 233      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 234      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 235      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 236      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 237      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 238      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 239      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 240      | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 241      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 242      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 243      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 244      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 245      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 246      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 247      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 248      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 249      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 250      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 251      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 252      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 253      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 254      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_0 | 255      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 0        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 1        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 2        | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 3        | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 4        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 5        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 6        | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 7        | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 8        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 9        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 10       | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 11       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 12       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 13       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 14       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 15       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 16       | 9     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 17       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 18       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 19       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 20       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 21       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 22       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 23       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 24       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 25       | 9     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 26       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 27       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 28       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 29       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 30       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 31       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 32       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 33       | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 34       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 35       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 36       | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 37       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 38       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 39       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 40       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 41       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 42       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 43       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 44       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 45       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 46       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 47       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 48       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 49       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 50       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 51       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 52       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 53       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 54       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 55       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 56       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 57       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 58       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 59       | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 60       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 61       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 62       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 63       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 64       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 65       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 66       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 67       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 68       | 32    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 69       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 70       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 71       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 72       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 73       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 74       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 75       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 76       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 77       | 32    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 78       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 79       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 80       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 81       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 82       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 83       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 84       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 85       | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 86       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 87       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 88       | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 89       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 90       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 91       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 92       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 93       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 94       | 16    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 95       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 96       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 97       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 98       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 99       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 100      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 101      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 102      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 103      | 16    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 104      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 105      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 106      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 107      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 108      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 109      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 110      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 111      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 112      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 113      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 114      | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 115      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 116      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 117      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 118      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 119      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 120      | 16    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 121      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 122      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 123      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 124      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 125      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 126      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 127      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 128      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 129      | 16    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 130      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 131      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 132      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 133      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 134      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 135      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 136      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 137      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 138      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 139      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 140      | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 141      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 142      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 143      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 144      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 145      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 146      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 147      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 148      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 149      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 150      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 151      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 152      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 153      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 154      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 155      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 156      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 157      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 158      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 159      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 160      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 161      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 162      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 163      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 164      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 165      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 166      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 167      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 168      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 169      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 170      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 171      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 172      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 173      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 174      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 175      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 176      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 177      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 178      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 179      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 180      | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 181      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 182      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 183      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 184      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 185      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 186      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 187      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 188      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 189      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 190      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 191      | 19    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 192      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 193      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 194      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 195      | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 196      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 197      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 198      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 199      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 200      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 201      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 202      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 203      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 204      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 205      | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 206      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 207      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 208      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 209      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 210      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 211      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 212      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 213      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 214      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 215      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 216      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 217      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 218      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 219      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 220      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 221      | 12    | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 222      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 223      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 224      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 225      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 226      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 227      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 228      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 229      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 230      | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 231      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 232      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 233      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 234      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 235      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 236      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 237      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 238      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 239      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 240      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 241      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 242      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 243      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 244      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 245      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 246      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 247      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 248      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 249      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 250      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 251      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 252      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 253      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 254      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_1 | 255      | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 0        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 1        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 2        | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 3        | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 4        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 5        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 6        | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 7        | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 8        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 9        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 10       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 11       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 12       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 13       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 14       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 15       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 16       | 32    | EDC          |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 17       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 18       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 19       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 20       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK2_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K2_SCR_EDC_CTRL_BUSECC_2 | 21       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 1        | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 2        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 3        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 4        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 5        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 6        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 7        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 8        | 2     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 9        | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 10       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 11       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 12       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 13       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 14       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 15       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 16       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 17       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 18       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 19       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 20       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 21       | 12    | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 22       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 23       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 24       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 25       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 26       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 27       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 28       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 29       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 30       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 31       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 32       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 33       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 34       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 35       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 36       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 37       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 38       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 39       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 40       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 41       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 42       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 43       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 44       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 45       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 46       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 47       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 48       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 49       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 50       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 51       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 52       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 53       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 54       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 55       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 56       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 57       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 58       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 59       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 60       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 61       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 62       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 63       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 64       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 65       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 66       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 67       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 68       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 69       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 70       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 71       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 72       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 73       | 10    | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 74       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 75       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 76       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 77       | 36    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 78       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 79       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 80       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 81       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 82       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 83       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 84       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 85       | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 86       | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 87       | 13    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 88       | 9     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 89       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 90       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 91       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 92       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 93       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 94       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 95       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 96       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 97       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 98       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 99       | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 100      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 101      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 102      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 103      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 104      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 105      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 106      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 107      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 108      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 109      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 110      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 111      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 112      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 113      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 114      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 115      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 116      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 117      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 118      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 119      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 120      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 121      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 122      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 123      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 124      | 11    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 125      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 126      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 127      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 128      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 129      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 130      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 131      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 132      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 133      | 11    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 134      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 135      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 136      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 137      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 138      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 139      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 140      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 141      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 142      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 143      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 144      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 145      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 146      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 147      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 148      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 149      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 150      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 151      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 152      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 153      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 154      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 155      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 156      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 157      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 158      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 159      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 160      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 161      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 162      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 163      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 164      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 165      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 166      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 167      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 168      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 169      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 170      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 171      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 172      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 173      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 174      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 175      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 176      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 177      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 178      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 179      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 180      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 181      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 182      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 183      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 184      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 185      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 186      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 187      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 188      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 189      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 190      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 191      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 192      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 193      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 194      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 195      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 196      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 197      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 198      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 199      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 200      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 201      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 202      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 203      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 204      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 205      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 206      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 207      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 208      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 209      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 210      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 211      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 212      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 213      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 214      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 215      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 216      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 217      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 218      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 219      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 220      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 221      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 222      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 223      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 224      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 225      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 226      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 227      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 228      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 229      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 230      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 231      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 232      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 233      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 234      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 235      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 236      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 237      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 238      | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 239      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 240      | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 241      | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 242      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 243      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 244      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 245      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 246      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 247      | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 248      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 249      | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 250      | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 251      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 252      | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 253      | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 254      | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_0 | 255      | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 0        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 1        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 2        | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 3        | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 4        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 5        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 6        | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 7        | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 8        | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 9        | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 10       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 11       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 12       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 13       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 14       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 15       | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 16       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 17       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 18       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 19       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 20       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 21       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 22       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 23       | 12    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 24       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 25       | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 26       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 27       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 28       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 29       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 30       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 31       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 32       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 33       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 34       | 4     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 35       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 36       | 5     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 37       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 38       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 39       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 40       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 41       | 8     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 42       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 43       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 44       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 45       | 26    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 46       | 3     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 47       | 1     | Redundant    |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 48       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 49       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 50       | 32    | EDC          |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CL<br>K4_SCR_EDC_CTRL_BUSECC_1 | 51       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                 | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_EDC_CTRL_BUSECC_1                                    | 52       | 1     | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_EDC_CTRL_BUSECC_1                                    | 53       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_EDC_CTRL_BUSECC_1                                    | 54       | 10    | Parity       |
| AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_AM62_MCU_CBASS_SCRP_32B_CLK4_SCR_EDC_CTRL_BUSECC_1                                    | 55       | 1     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_DST_BUSECC | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_DST_BUSECC | 1        | 1     | Redundant    |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_DST_BUSECC | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_DST_BUSECC | 3        | 36    | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_DST_BUSECC | 4        | 3     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 0        | 1     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 1        | 32    | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 4        | 36    | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 5        | 3     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 6        | 3     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 7        | 1     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 8        | 1     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 9        | 2     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 10       | 3     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 11       | 1     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 12       | 10    | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 13       | 5     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 14       | 3     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 15       | 4     | Parity       |
| AM62_MCU_CBASS_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_P2P_BRIDG_E_BR_SCRP_32B_CLK2_TO_SCRP_32B_CLK4_L0_BRIDGE_SRC_BUSECC | 16       | 2     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_CBASS_DEFAULT_ERR_AM62_MCU_CBASS_CBASS_DEF<br>LT_ERR_EDC_CTRL_BUSECC     | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_DEFAULT_ERR_AM62_MCU_CBASS_CBASS_DEF<br>LT_ERR_EDC_CTRL_BUSECC     | 1        | 1     | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_ERR_AM62_MCU_CBASS_CBASS_DEF<br>LT_ERR_EDC_CTRL_BUSECC     | 2        | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_ERR_AM62_MCU_CBASS_CBASS_DEF<br>LT_ERR_EDC_CTRL_BUSECC     | 3        | 10    | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_ERR_AM62_MCU_CBASS_CBASS_DEF<br>LT_ERR_EDC_CTRL_BUSECC     | 4        | 32    | EDC          |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 0        | 32    | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 1        | 32    | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 3        | 1     | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 4        | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 5        | 10    | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 6        | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_DEFAULT_MMRS_AM62_MCU_CBASS_CBASS_DEF<br>AULT_MMRS_EDC_CTRL_BUSECC | 7        | 32    | EDC          |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 1        | 13    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 2        | 1     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 3        | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 4        | 3     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 5        | 1     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 6        | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 7        | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 8        | 2     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 9        | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 10       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 11       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT<br>DMSC_SCR_EDC_CTRL_BUSECC  | 12       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                              | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 13       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 14       | 12    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 15       | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 16       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 17       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 18       | 10    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 19       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 20       | 12    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 21       | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 22       | 1     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 23       | 4     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 24       | 7     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 25       | 2     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 26       | 3     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 27       | 3     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 28       | 26    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 29       | 3     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 30       | 3     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 31       | 26    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 32       | 3     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 33       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 34       | 1     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 35       | 1     | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 36       | 32    | EDC          |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 37       | 1     | Redundant    |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 38       | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                              | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 39       | 10    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 40       | 10    | Parity       |
| AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_AM62_MCU_CBASS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC | 41       | 1     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 0        | 1     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 1        | 1     | Redundant    |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 4        | 10    | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 5        | 3     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 6        | 3     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 7        | 1     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 8        | 1     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 9        | 2     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 10       | 3     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 11       | 1     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 12       | 10    | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 13       | 5     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 14       | 3     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 15       | 4     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 16       | 2     | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 17       | 10    | Parity       |
| AM62_MCU_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                           | 18       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 1        | 10    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 2        | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 3        | 4     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 4        | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 5        | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 6        | 4     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 7        | 4     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 8        | 2     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 9        | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 10       | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                      | 11       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                         | Group ID | Width | Checker Type |
|----------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 12       | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 13       | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 14       | 12    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 15       | 4     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 16       | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 17       | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 18       | 10    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 19       | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 20       | 12    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 21       | 4     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 22       | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 23       | 4     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 24       | 7     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 25       | 2     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 26       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 27       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 28       | 26    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 29       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 30       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 31       | 26    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 32       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 33       | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 34       | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 35       | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 36       | 32    | EDC          |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS ECC | 37       | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                     | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                                                                                             | 38       | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                                                                                             | 39       | 10    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                                                                                             | 40       | 10    | Parity       |
| AM62_MCU_CBASS_ERR_SCR_AM62_MCU_CBASS_ERR_SCR_EDC_CTRL_BUS_ECC                                                                                             | 41       | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 0        | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 1        | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 4        | 10    | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 5        | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 6        | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 7        | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 8        | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 9        | 2     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 10       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 11       | 1     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 12       | 10    | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 13       | 5     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 14       | 3     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 15       | 4     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 16       | 2     | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 17       | 10    | Parity       |
| AM62_MCU_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSECC                                                                                                    | 18       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 0        | 32    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 1        | 32    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 4        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 5        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 6        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C_BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 7        | 1     | Redundant    |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                            | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 8        | 36    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 9        | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 10       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 11       | 2     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 12       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 13       | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 14       | 10    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 15       | 4     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 16       | 2     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 17       | 4     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 18       | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 19       | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 20       | 4     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 21       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 22       | 10    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 23       | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 24       | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 25       | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 26       | 1     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                            | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 27       | 2     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 28       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 29       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM62_MCU_C<br>BASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_MAIN_CENTRAL_CBASS_TO_AM<br>62_MCU_CBASS_DATA_L0_BRIDGE_BUSECC | 30       | 4     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_DST_BUSECC   | 0        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_DST_BUSECC   | 1        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_DST_BUSECC   | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_DST_BUSECC   | 3        | 36    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_DST_BUSECC   | 4        | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 0        | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 1        | 32    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 2        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 3        | 1     | Redundant    |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 4        | 36    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 5        | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 6        | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 7        | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 8        | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAF<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC   | 9        | 2     | Parity       |

**Table 4-197. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                              | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CB<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 10       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CB<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 11       | 1     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CB<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 12       | 10    | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CB<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 13       | 5     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CB<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 14       | 3     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CB<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 15       | 4     | Parity       |
| AM62_MCU_CBASS_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CBA<br>SS_DATA_L0_P2P_BRIDGE_EXPORT_AM62_MCU_CBASS_TO_AM62_WKUP_SAFE_CB<br>E_CBASS_DATA_L0_BRIDGE_SRC_BUSECC | 16       | 2     | Parity       |
| SAM62_MCU_ECC_AGGR_EDC_CTRL                                                                                                                                         | 0        | 1     | Redundant    |
| SAM62_MCU_ECC_AGGR_EDC_CTRL                                                                                                                                         | 1        | 32    | EDC          |
| SAM62_MCU_ECC_AGGR_EDC_CTRL                                                                                                                                         | 2        | 1     | Parity       |
| SAM62_MCU_ECC_AGGR_EDC_CTRL                                                                                                                                         | 3        | 10    | Parity       |
| SAM62_MCU_ECC_AGGR_EDC_CTRL                                                                                                                                         | 4        | 4     | Parity       |
| SAM62_MCU_ECC_AGGR_EDC_CTRL                                                                                                                                         | 5        | 3     | Parity       |

**Table 4-198. Properties of ECC Aggregator Instance MCU\_M4FSS0**

| RAM ID Name      | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| BLAZAR_IIRAM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 192 KB   |
| BLAZAR_IDRAM_ECC | 1      | ECC Wrapper | Inject with error capture | No              | 32        | 64 KB    |

**Table 4-199. Properties of ECC Aggregator Instance MCU\_M4FSS0**

| RAM ID Name                                                     | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-----------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| BLAZAR_IIRAM_EDC_CTRL_0                                         | 2      | EDC Interconnect | Inject with error capture | Yes             | 19                     |
| BLAZAR_IDRAM_EDC_CTRL_0                                         | 3      | EDC Interconnect | Inject with error capture | Yes             | 19                     |
| BLAZAR_RAT_EDC_CTRL_0                                           | 4      | EDC Interconnect | Inject with error capture | Yes             | 43                     |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC           | 5      | EDC Interconnect | Inject with error capture | Yes             | 11                     |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC             | 6      | EDC Interconnect | Inject with error capture | Yes             | 11                     |
| BLAZAR_CBASS_BLAZAR_SCR_BLAZAR_CBASS_BLAZAR_SCR_EDC_CTRL_BUSECC | 7      | EDC Interconnect | Inject with error capture | Yes             | 128                    |

**Table 4-199. Properties of ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| RAM ID Name                                          | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 8      | EDC Interconnect | Inject with error capture | Yes             | 17                     |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0                   | 9      | EDC Interconnect | Inject with error capture | Yes             | 68                     |
| BLAZAR_IA2V_I_EDC_CTRL_0                             | 10     | EDC Interconnect | Inject with error capture | Yes             | 16                     |
| BLAZAR_IA2V_D_EDC_CTRL_0                             | 11     | EDC Interconnect | Inject with error capture | Yes             | 16                     |
| BLAZAR_SYS_GASKET_EDC_CTRL_0                         | 12     | EDC Interconnect | Inject with error capture | Yes             | 16                     |
| BLAZAR_ECC_EDC_CTRL                                  | 13     | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0**

| Protected Interconnect  | Group ID | Width | Checker Type |
|-------------------------|----------|-------|--------------|
| BLAZAR_IIRAM_EDC_CTRL_0 | 0        | 1     | Redundant    |
| BLAZAR_IIRAM_EDC_CTRL_0 | 1        | 32    | EDC          |
| BLAZAR_IIRAM_EDC_CTRL_0 | 2        | 1     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 3        | 18    | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 4        | 4     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 5        | 3     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 6        | 1     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 7        | 1     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 8        | 10    | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 9        | 12    | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 10       | 4     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 11       | 12    | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 12       | 2     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 13       | 3     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 14       | 1     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 15       | 1     | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 16       | 1     | Redundant    |
| BLAZAR_IIRAM_EDC_CTRL_0 | 17       | 64    | Parity       |
| BLAZAR_IIRAM_EDC_CTRL_0 | 18       | 28    | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 0        | 1     | Redundant    |
| BLAZAR_IDRAM_EDC_CTRL_0 | 1        | 32    | EDC          |
| BLAZAR_IDRAM_EDC_CTRL_0 | 2        | 1     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 3        | 16    | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 4        | 4     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 5        | 3     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 6        | 1     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 7        | 1     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 8        | 10    | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 9        | 12    | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 10       | 4     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 11       | 12    | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect  | Group ID | Width | Checker Type |
|-------------------------|----------|-------|--------------|
| BLAZAR_IDRAM_EDC_CTRL_0 | 12       | 2     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 13       | 3     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 14       | 1     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 15       | 1     | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 16       | 1     | Redundant    |
| BLAZAR_IDRAM_EDC_CTRL_0 | 17       | 64    | Parity       |
| BLAZAR_IDRAM_EDC_CTRL_0 | 18       | 28    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 0        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 1        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 2        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 3        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 4        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 5        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 6        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 7        | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 8        | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 9        | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 10       | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 11       | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 12       | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 13       | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 14       | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 15       | 6     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 16       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 17       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 18       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 19       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 20       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 21       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 22       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 23       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 24       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 25       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 26       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 27       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 28       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 29       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 30       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 31       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 32       | 4     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 33       | 4     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 34       | 4     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 35       | 4     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 36       | 4     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0   | 37       | 4     | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| BLAZAR_RAT_EDC_CTRL_0                                                   | 38       | 4     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0                                                   | 39       | 4     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0                                                   | 40       | 32    | Parity       |
| BLAZAR_RAT_EDC_CTRL_0                                                   | 41       | 1     | Parity       |
| BLAZAR_RAT_EDC_CTRL_0                                                   | 42       | 1     | Parity       |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 0        | 1     | Parity       |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 1        | 32    | Parity       |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 2        | 1     | Redundant    |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 3        | 1     | Redundant    |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 4        | 1     | Redundant    |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 5        | 1     | Redundant    |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 6        | 1     | Redundant    |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 7        | 8     | Parity       |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 8        | 8     | Parity       |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 9        | 8     | Parity       |
| BLAZAR_CBASS_VBUSB_S_P2P_BRIDGE_VBUSB_S_BRIDGE_BUSECC                   | 10       | 8     | Parity       |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 0        | 1     | Parity       |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 1        | 32    | Parity       |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 2        | 1     | Redundant    |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 3        | 1     | Redundant    |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 4        | 1     | Redundant    |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 5        | 1     | Redundant    |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 6        | 1     | Redundant    |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 7        | 8     | Parity       |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 8        | 8     | Parity       |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 9        | 8     | Parity       |
| BLAZAR_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 10       | 8     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 0        | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 1        | 32    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 2        | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 3        | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 4        | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 5        | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 6        | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 7        | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 8        | 2     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 9        | 1     | Redundant    |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 10       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 11       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 12       | 32    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 13       | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 14       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 15       | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 16       | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 17       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 18       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 19       | 2     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 20       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 21       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 22       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 23       | 32    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 24       | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 25       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 26       | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 27       | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 28       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 29       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 30       | 2     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 31       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 32       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 33       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 34       | 32    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 35       | 1     | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 36       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 37       | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 38       | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 39       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 40       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 41       | 2     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 42       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 43       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 44       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 45       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 46       | 10    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 47       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 48       | 12    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 49       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 50       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 51       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 52       | 10    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 53       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 54       | 12    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 55       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 56       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 57       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 58       | 10    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 59       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 60       | 12    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 61       | 4     | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 62       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 63       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 64       | 10    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 65       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 66       | 12    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 67       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 68       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 69       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 70       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 71       | 12    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 72       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 73       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 74       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 75       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 76       | 12    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 77       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 78       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 79       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 80       | 10    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 81       | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 82       | 12    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 83       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 84       | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 85       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 86       | 8     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 87       | 4     | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 88       | 5     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 89       | 8     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 90       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 91       | 5     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 92       | 7     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 93       | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 94       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 95       | 9     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 96       | 5     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 97       | 6     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 98       | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 99       | 26    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 100      | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 101      | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 102      | 26    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 103      | 4     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 104      | 35    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 105      | 26    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 106      | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 107      | 35    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 108      | 26    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 109      | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 110      | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 111      | 26    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 112      | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 113      | 3     | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 114      | 26    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 115      | 3     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 116      | 5     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 117      | 26    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 118      | 5     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 119      | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 120      | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 121      | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 122      | 32    | EDC          |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 123      | 1     | Redundant    |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 124      | 1     | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 125      | 10    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 126      | 10    | Parity       |
| BLAZAR_CBASS_BLAZAR_SCR_SCR_BLAZAR_CBASS_BLAZAR_SCR_SCR_EDC_CTRL_BUSECC | 127      | 1     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 0        | 1     | Redundant    |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 1        | 32    | EDC          |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 2        | 1     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 3        | 32    | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 4        | 4     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 5        | 3     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 6        | 1     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 7        | 1     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 8        | 10    | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 9        | 12    | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 10       | 4     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 11       | 12    | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 12       | 2     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 13       | 3     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 14       | 1     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 15       | 1     | Parity       |
| BLAZAR_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                    | 16       | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0                                      | 0        | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0                                      | 1        | 32    | EDC          |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0                                      | 2        | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0                                      | 3        | 32    | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect             | Group ID | Width | Checker Type |
|------------------------------------|----------|-------|--------------|
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 4        | 4     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 5        | 3     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 6        | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 7        | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 8        | 10    | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 9        | 5     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 10       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 11       | 3     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 12       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 13       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 14       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 15       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 16       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 17       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 18       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 19       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 20       | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 21       | 32    | EDC          |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 22       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 23       | 32    | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 24       | 4     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 25       | 3     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 26       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 27       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 28       | 10    | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 29       | 5     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 30       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 31       | 3     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 32       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 33       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 34       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 35       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 36       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 37       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 38       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 39       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 40       | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 41       | 32    | EDC          |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 42       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 43       | 32    | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 44       | 4     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 45       | 3     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 46       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 47       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 48       | 10    | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect             | Group ID | Width | Checker Type |
|------------------------------------|----------|-------|--------------|
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 49       | 5     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 50       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 51       | 3     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 52       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 53       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 54       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 55       | 1     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 56       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 57       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 58       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 59       | 2     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 60       | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 61       | 32    | EDC          |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 62       | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 63       | 3     | Parity       |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 64       | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 65       | 32    | EDC          |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 66       | 1     | Redundant    |
| BLAZAR_SYS_SCR_VBUS_CLK_EDC_CTRL_0 | 67       | 3     | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 0        | 1     | Redundant    |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 1        | 1     | Redundant    |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 2        | 3     | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 3        | 32    | EDC          |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 4        | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 5        | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 6        | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 7        | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 8        | 38    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 9        | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 10       | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 11       | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 12       | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 13       | 64    | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 14       | 1     | Parity       |
| BLAZAR_IA2V_I_EDC_CTRL_0           | 15       | 5     | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 0        | 1     | Redundant    |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 1        | 1     | Redundant    |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 2        | 3     | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 3        | 32    | EDC          |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 4        | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 5        | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 6        | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 7        | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 8        | 38    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0           | 9        | 64    | Parity       |

**Table 4-200. EDC checkers information for ECC Aggregator Instance MCU\_M4FSS0 (continued)**

| Protected Interconnect       | Group ID | Width | Checker Type |
|------------------------------|----------|-------|--------------|
| BLAZAR_IA2V_D_EDC_CTRL_0     | 10       | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0     | 11       | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0     | 12       | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0     | 13       | 64    | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0     | 14       | 1     | Parity       |
| BLAZAR_IA2V_D_EDC_CTRL_0     | 15       | 5     | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 0        | 1     | Redundant    |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 1        | 1     | Redundant    |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 2        | 3     | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 3        | 32    | EDC          |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 4        | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 5        | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 6        | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 7        | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 8        | 38    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 9        | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 10       | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 11       | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 12       | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 13       | 64    | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 14       | 1     | Parity       |
| BLAZAR_SYS_GASKET_EDC_CTRL_0 | 15       | 5     | Parity       |
| BLAZAR_ECC_EDC_CTRL          | 0        | 1     | Redundant    |
| BLAZAR_ECC_EDC_CTRL          | 1        | 32    | EDC          |
| BLAZAR_ECC_EDC_CTRL          | 2        | 1     | Parity       |
| BLAZAR_ECC_EDC_CTRL          | 3        | 10    | Parity       |
| BLAZAR_ECC_EDC_CTRL          | 4        | 4     | Parity       |
| BLAZAR_ECC_EDC_CTRL          | 5        | 3     | Parity       |

**Table 4-201. Properties of ECC Aggregator Instance MCU\_MCAN0**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MCANSS_MSGMEM_WRAP_MSGMEM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 17 KB    |

**Table 4-202. Properties of ECC Aggregator Instance MCU\_MCAN0**

| RAM ID Name    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------|--------|------------------|---------------------------|-----------------|------------------------|
| CTRL_EDC_VBUSS | 1      | EDC Interconnect | Inject with error capture | Yes             | 1                      |

**Table 4-203. EDC checkers information for ECC Aggregator Instance MCU\_MCAN0**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CTRL_EDC_VBUSS         | 0        | 32    | Parity       |

**Table 4-204. Properties of ECC Aggregator Instance MCU\_MCAN1**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MCANSS_MSGMEM_WRAP_MSGMEM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 17 KB    |

**Table 4-205. Properties of ECC Aggregator Instance MCU\_MCAN1**

| RAM ID Name    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------|--------|------------------|---------------------------|-----------------|------------------------|
| CTRL_EDC_VBUSS | 1      | EDC Interconnect | Inject with error capture | Yes             | 1                      |

**Table 4-206. EDC checkers information for ECC Aggregator Instance MCU\_MCAN1**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CTRL_EDC_VBUSS         | 0        | 32    | Parity       |

**Table 4-207. Properties of ECC Aggregator Instance MMCSD0**

| RAM ID Name               | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| EMMCSD8SS_SDHC_WRAP_TXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| EMMCSD8SS_SDHC_WRAP_RXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |

**Table 4-208. Properties of ECC Aggregator Instance MMCSD1**

| RAM ID Name               | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| EMMCSD4SS_SDHC_WRAP_RXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| EMMCSD4SS_SDHC_WRAP_TXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |

**Table 4-209. Properties of ECC Aggregator Instance MMCSD2**

| RAM ID Name               | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| EMMCSD4SS_SDHC_WRAP_RXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| EMMCSD4SS_SDHC_WRAP_TXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |

**Table 4-210. Properties of ECC Aggregator Instance PDMA0**

| RAM ID Name                                          | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| SAM62_PDMA_SPI_PDMA_CORE_TF0_F0_TPRAM_60X1_28_SBW_SR | 0      | ECC Wrapper | Inject with error capture | Yes             | 128       | 960 B    |
| SAM62_PDMA_SPI_PDMA_CORE_TF0_F1_TPRAM_60X1_28_SBW_SR | 1      | ECC Wrapper | Inject with error capture | Yes             | 128       | 960 B    |
| SAM62_PDMA_SPI_PDMA_CORE_RF0_F0_TPRAM_60X1_44_SBW_SR | 2      | ECC Wrapper | Inject with error capture | Yes             | 144       | 1 KB     |

**Table 4-210. Properties of ECC Aggregator Instance PDMA0 (continued)**

| RAM ID Name                                             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| SAM62_PDMA_SPI_PDMA_CORE_RF0_F1_TPRAM_60X1<br>44_SBW_SR | 3      | ECC Wrapper | Inject with error capture | Yes             | 144       | 1 KB     |

**Table 4-211. Properties of ECC Aggregator Instance PDMA1**

| RAM ID Name                                              | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|----------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| SAM62_PDMA_UART_PDMA_CORE_TF0_F0_TPRAM_28<br>X128_SBW_SR | 0      | ECC Wrapper | Inject with error capture | Yes             | 128       | 448 B    |
| SAM62_PDMA_UART_PDMA_CORE_TF0_F1_TPRAM_28<br>X128_SBW_SR | 1      | ECC Wrapper | Inject with error capture | Yes             | 128       | 448 B    |
| SAM62_PDMA_UART_PDMA_CORE_RF0_F0_TPRAM_28<br>X144_SBW_SR | 2      | ECC Wrapper | Inject with error capture | Yes             | 144       | 504 B    |
| SAM62_PDMA_UART_PDMA_CORE_RF0_F1_TPRAM_28<br>X144_SBW_SR | 3      | ECC Wrapper | Inject with error capture | Yes             | 144       | 504 B    |

**Table 4-212. Properties of ECC Aggregator Instance PSRAMECC0**

| RAM ID Name             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| PSRAM256X32E_PSRAM0_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 1 KB     |

**Table 4-213. Properties of ECC Aggregator Instance PSRAMECC\_16K0**

| RAM ID Name             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| PSRAM16KX32E_PSRAM0_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 64 KB    |

**Table 4-214. Properties of ECC Aggregator Instance SA3\_SS0**

| RAM ID Name                 | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-----------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| DMSS_HSM_PKTDMA_CFG_CONFIG  | 1      | ECC Wrapper | Inject with error capture | Yes             | 108       | 432 B    |
| DMSS_HSM_PKTDMA_CFG_STATE   | 2      | ECC Wrapper | Inject with error capture | Yes             | 256       | 192 B    |
| DMSS_HSM_PKTDMA_TPCFIFO_F0  | 3      | ECC Wrapper | Inject with error capture | Yes             | 141       | 212 B    |
| DMSS_HSM_PKTDMA_TPCFIFO_F1  | 4      | ECC Wrapper | Inject with error capture | Yes             | 141       | 212 B    |
| DMSS_HSM_PKTDMA_RPCFIFO_F0  | 5      | ECC Wrapper | Inject with error capture | Yes             | 128       | 384 B    |
| DMSS_HSM_PKTDMA_RPCFIFO_F1  | 6      | ECC Wrapper | Inject with error capture | Yes             | 128       | 384 B    |
| DMSS_HSM_PKTDMA_RPCFIFO_WC  | 7      | ECC Wrapper | Inject with error capture | Yes             | 22        | 132 B    |
| DMSS_HSM_PKTDMA_STATS_STST0 | 8      | ECC Wrapper | Inject with error capture | Yes             | 96        | 24 B     |
| DMSS_HSM_PKTDMA_STATS_STSR0 | 9      | ECC Wrapper | Inject with error capture | Yes             | 128       | 64 B     |

**Table 4-214. Properties of ECC Aggregator Instance SA3\_SS0 (continued)**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| DMSS_HSM_PKTDMA_RINGOCC_CNTR                    | 10     | ECC Wrapper | Inject with error capture | Yes             | 18        | 144 B    |
| DMSS_HSM_INTAGGR_STATREG_SR_SPRAM_8X128_S_WW_SR | 13     | ECC Wrapper | Inject with error capture | Yes             | 128       | 128 B    |
| DMSS_HSM_INTAGGR_COMMON_IM_TPRAM_158X34_S_WW_SR | 14     | ECC Wrapper | Inject with error capture | Yes             | 34        | 672 B    |
| DMSS_HSM_IPCSS_RINGACC_STRAM                    | 17     | ECC Wrapper | Inject with error capture | Yes             | 216       | 162 B    |
| DMSS_HSM_IPCSS_SEC_PROXY_BUF_STRAM              | 18     | ECC Wrapper | Inject with error capture | Yes             | 91        | 182 B    |
| DMSS_HSM_IPCSS_SEC_PROXY_BUFRAM                 | 19     | ECC Wrapper | Inject with error capture | Yes             | 64        | 64 B     |
| DMSS_HSM_IPCSS_MSRAM_ECC0                       | 24     | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| SA3_UL_PKTRAM0_ECC                              | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 512 B    |
| SA3_UL_PKTRAM1_ECC                              | 1      | ECC Wrapper | Inject with error capture | Yes             | 64        | 512 B    |
| SA3_UL_PKA_PROG_RAM_ECC                         | 2      | ECC Wrapper | Inject with error capture | Yes             | 24        | 15 KB    |
| SA3_UL_ENCR_CTXRAM_BANK01_ECC                   | 3      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_ENCR_CTXRAM_BANK23_ECC                   | 4      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_ENCR_CTXRAM_BANK4_ECC                    | 5      | ECC Wrapper | Inject with error capture | Yes             | 256       | 128 B    |
| SA3_UL_AUTH_CTXRAM_BANK01_ECC                   | 6      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_AUTH_CTXRAM_BANK23_ECC                   | 7      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_AUTH_CTXRAM_BANK45_ECC                   | 8      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_AUTH_CTXRAM_BANK67_ECC                   | 9      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_AUTH_CTXRAM_BANK89_ECC                   | 10     | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_AUTH_CTXRAM_BANK10_ECC                   | 11     | ECC Wrapper | Inject with error capture | Yes             | 256       | 128 B    |

**Table 4-215. Properties of ECC Aggregator Instance SA3\_SS0**

| RAM ID Name                       | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-----------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| DMSS_HSM_ECCAGGR_EDC_CTRL         | 0      | EDC Interconnect | Inject with error capture | Yes             | 6                      |
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 11     | EDC Interconnect | Inject with error capture | Yes             | 72                     |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 12     | EDC Interconnect | Inject with error capture | Yes             | 18                     |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 15     | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 16     | EDC Interconnect | Inject with error capture | Yes             | 57                     |

Table 4-215. Properties of ECC Aggregator Instance SA3\_SS0 (continued)

| RAM ID Name                                                  | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|--------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 20     | EDC Interconnect | Inject with error capture | Yes             | 67                     |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 21     | EDC Interconnect | Inject with error capture | Yes             | 72                     |
| DMSS_HSM_IPCSS_CBASS_SCR_EDC_CTRL_0                          | 22     | EDC Interconnect | Inject with error capture | Yes             | 132                    |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0                      | 23     | EDC Interconnect | Inject with error capture | Yes             | 3                      |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0                              | 25     | EDC Interconnect | Inject with error capture | Yes             | 63                     |
| DMSS_HSM_PSLSS_SAUL0_PSIL_SAFE_EDC_CTRL_0                    | 26     | EDC Interconnect | Inject with error capture | Yes             | 33                     |
| DMSS_HSM_PSLSS_PKTDMA_STRM_SAFE_EDC_CTRL_0                   | 27     | EDC Interconnect | Inject with error capture | Yes             | 33                     |
| DMSS_HSM_PSLSS_PKTDMA_CFGSTRM_SAFE_EDC_CTRL_0                | 28     | EDC Interconnect | Inject with error capture | Yes             | 30                     |
| DMSS_HSM_PSLSS_PSLCFG_CFGSTRM_SAFE_EDC_CTRL_0                | 29     | EDC Interconnect | Inject with error capture | Yes             | 30                     |
| DMSS_HSM_PSLSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0              | 30     | EDC Interconnect | Inject with error capture | Yes             | 101                    |
| DMSS_HSM_PSLSS_PSLCFG_CFGSTRM_BRIDGE_EDC_CTRL_0              | 31     | EDC Interconnect | Inject with error capture | Yes             | 101                    |
| DMSS_HSM_PSLSS_L2P_SAUL0_PSIL_EDC_CTRL_0                     | 32     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSLSS_L2P_PKTDMA_STRM_EDC_CTRL_0                    | 33     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSLSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0                 | 34     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSLSS_L2P_INTAGGR_EVT_EDC_CTRL_0                    | 35     | EDC Interconnect | Inject with error capture | Yes             | 2                      |
| DMSS_HSM_PSLSS_L2P_INTAGGR_CEV_EDC_CTRL_0                    | 36     | EDC Interconnect | Inject with error capture | Yes             | 2                      |
| DMSS_HSM_PSLSS_L2P_INTAGGR_MEVT_IN_EDC_CTRL_0                | 37     | EDC Interconnect | Inject with error capture | Yes             | 2                      |
| DMSS_HSM_PSLSS_L2P_PSLCFG_CFGSTRM_EDC_CTRL_0                 | 38     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSLSS_CFG_EDC_CTRL_0                                | 39     | EDC Interconnect | Inject with error capture | Yes             | 3                      |
| DMSS_HSM_PSLSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0                | 40     | EDC Interconnect | Inject with error capture | Yes             | 106                    |
| DMSS_HSM_PSLSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0                | 41     | EDC Interconnect | Inject with error capture | Yes             | 103                    |
| DMSS_HSM_PSLSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0                 | 42     | EDC Interconnect | Inject with error capture | Yes             | 131                    |
| DMSS_HSM_PSLSS_CBASS_ETL_VD2GCLK_EDC_CTRL_0                  | 43     | EDC Interconnect | Inject with error capture | Yes             | 10                     |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0            | 44     | EDC Interconnect | Inject with error capture | Yes             | 7                      |
| DMSS_HSM_CFG_CBASS_SCR_EDC_CTRL_0                            | 45     | EDC Interconnect | Inject with error capture | Yes             | 91                     |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0                        | 46     | EDC Interconnect | Inject with error capture | Yes             | 62                     |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0**

| Protected Interconnect     | Group ID | Width | Checker Type |
|----------------------------|----------|-------|--------------|
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 0        | 1     | Redundant    |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 1        | 32    | EDC          |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 2        | 1     | Parity       |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 3        | 10    | Parity       |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 4        | 4     | Parity       |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 5        | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 0        | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 1        | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 2        | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 3        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 4        | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 5        | 6     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 6        | 6     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 7        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 8        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 9        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 10       | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 11       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 12       | 16    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 13       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 14       | 16    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 15       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 16       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 17       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 18       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 19       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 20       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 21       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 22       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 23       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 24       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 25       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 26       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 27       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 28       | 10    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 29       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 31       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 32       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 33       | 5     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 34       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 35       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 36       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 37       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 38       | 12    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 39       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 40       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 41       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 42       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 43       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 44       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 45       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 46       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 47       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 48       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 49       | 4     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 50       | 32    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 51       | 10    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 52       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 53       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 54       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 55       | 4     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 56       | 2     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 57       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 58       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 59       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 60       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 61       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 62       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 63       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 64       | 10    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 65       | 10    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 66       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 67       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 68       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 69       | 4     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 70       | 2     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0  | 71       | 3     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 0        | 3     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 1        | 2     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 2        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 3        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 4        | 64    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 5        | 50    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 6        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 7        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 8        | 56    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 9        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 10       | 64    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0 | 11       | 50    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 12       | 64    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 13       | 12    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 14       | 2     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 15       | 2     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 16       | 8     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 17       | 28    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 1        | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 3        | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 4        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 6        | 48    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 8        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 10       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 11       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 12       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 13       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 16       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 17       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 18       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 19       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 20       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 21       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 23       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 25       | 3     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 27       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 28       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 29       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 30       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 31       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 32       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 34       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 35       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 36       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 37       | 32    | EDC          |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 38       | 32    | EDC          |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 40       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 41       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 42       | 22    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 44       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 45       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 46       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 47       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 48       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 49       | 3     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 50       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 51       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 52       | 32    | EDC          |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 53       | 32    | EDC          |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 54       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 55       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 56       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 57       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 58       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 59       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 60       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 61       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 62       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 63       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 64       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 65       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 66       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 67       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 68       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 69       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 70       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 71       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 72       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 73       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 74       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 75       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 76       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 77       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 78       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 79       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 80       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 81       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 82       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 83       | 9     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 84       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 85       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 86       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 87       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 88       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 89       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 90       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 91       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 92       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 93       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 94       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 95       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 96       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 97       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 98       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 99       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 100      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 101      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 102      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 103      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 104      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 105      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 106      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 107      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 108      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 109      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 110      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 111      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 112      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 113      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 114      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 115      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 116      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 117      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 118      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 119      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 120      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 121      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 122      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 123      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 124      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 125      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 126      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 127      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 128      | 12    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 129      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 130      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 131      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 132      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 133      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 134      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 135      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 136      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 137      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 138      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 139      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 140      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 141      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 142      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 143      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 144      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 145      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 146      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 147      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 148      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 149      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 150      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 151      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 152      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 153      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 154      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 155      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 156      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 157      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 158      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 159      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 160      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 161      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 162      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 163      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 164      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 165      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 166      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 167      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 168      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 169      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 170      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 171      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 172      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 173      | 2     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 174      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 175      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 176      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 177      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 178      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 179      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 180      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 181      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 182      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 183      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 184      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 185      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 186      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 187      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 188      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 189      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 190      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 191      | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 192      | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 193      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 194      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 195      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 196      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 197      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 198      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 199      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 200      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 201      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 202      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 203      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 204      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 205      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 206      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 207      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 208      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 209      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 210      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 211      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 212      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 213      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 214      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 215      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 216      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 217      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 218      | 4     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 219      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 220      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 221      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 222      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 223      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 224      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 225      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 226      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 227      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 228      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 229      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 230      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 231      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 232      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 233      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 234      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 235      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 236      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 237      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 238      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 239      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 240      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 241      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 242      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 243      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 244      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 245      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 246      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 247      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 248      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 249      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 250      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 251      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 252      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 253      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 254      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 255      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 0        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 1        | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 2        | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 3        | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 4        | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 5        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 6        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 7        | 10    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 8        | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 9        | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 10       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 11       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 12       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 13       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 14       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 15       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 16       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 17       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 18       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 19       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 20       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 21       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 22       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 23       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 24       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 25       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 26       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 27       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 28       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 29       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 30       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 31       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 32       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 33       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 34       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 35       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 36       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 37       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 38       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 39       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 40       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 41       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 42       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 43       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 44       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 45       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 46       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 47       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 48       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 49       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 50       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 51       | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 52       | 16    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 53       | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 54       | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 55       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 56       | 8     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 2        | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 3        | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 4        | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 6        | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 7        | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 8        | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 9        | 2     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 14       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 15       | 14    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 16       | 14    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 17       | 8     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 18       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 19       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 20       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 21       | 4     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 22       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 23       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 25       | 4     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 26       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 27       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 28       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 29       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 31       | 12    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 32       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 34       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 35       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 36       | 8     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 37       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 38       | 3     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 39       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 40       | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                                       | Group ID | Width | Checker Type |
|--------------------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 41       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 42       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 43       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 44       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 45       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 46       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 47       | 4     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 48       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 49       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 50       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 51       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 52       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 53       | 4     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 54       | 3     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 55       | 32    | EDC          |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 56       | 32    | EDC          |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 57       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 58       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 59       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 60       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 61       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 62       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 63       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 64       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 65       | 32    | EDC          |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                          | 66       | 32    | EDC          |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 0        | 24    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 1        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 3        | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 4        | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 5        | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 6        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 7        | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 8        | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 10       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 11       | 9     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 12       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 13       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 14       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 15       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 16       | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 17       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 18       | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                                       | Group ID | Width | Checker Type |
|--------------------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 19       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 20       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 21       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 22       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 23       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 25       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 28       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 29       | 9     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 31       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 32       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 34       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 35       | 9     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 36       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 37       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 38       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 39       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 40       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 41       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 43       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 44       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 45       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 46       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 47       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 48       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 49       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 50       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 51       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 52       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 53       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 54       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 55       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 56       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 57       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 58       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 59       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 60       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 61       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 62       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 63       | 1     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                                       | Group ID | Width | Checker Type |
|--------------------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 64       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 65       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 66       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 67       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 68       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 69       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 71       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 1        | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 3        | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 4        | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 5        | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 6        | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 7        | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 8        | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 9        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 10       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 11       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 12       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 13       | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 14       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 15       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 16       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 17       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 18       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 19       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 20       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 21       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 22       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 23       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 24       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 25       | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 26       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 27       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 28       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 29       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 30       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 31       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 32       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 34       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 35       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 36       | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                  | Group ID | Width | Checker Type |
|-----------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 37       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 38       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 40       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 41       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 42       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 43       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 44       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 46       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 47       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 48       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 49       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 50       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 51       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 52       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 53       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 54       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 55       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 56       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 57       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 58       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 59       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 60       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 61       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 62       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 63       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 66       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 67       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 68       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 69       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 70       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 71       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 72       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 73       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 74       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 75       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 76       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 77       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 78       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 79       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 80       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 81       | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                  | Group ID | Width | Checker Type |
|-----------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 82       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 83       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 84       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 85       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 86       | 7     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 87       | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 88       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 89       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 90       | 7     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 91       | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 92       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 93       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 94       | 7     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 95       | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 96       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 97       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 98       | 19    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 99       | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 100      | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 101      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 102      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 103      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 104      | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 105      | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 106      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 107      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 108      | 19    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 109      | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 110      | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 111      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 112      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 113      | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 114      | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 115      | 6     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 116      | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 117      | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 118      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 119      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 120      | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 121      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 122      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 123      | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 124      | 32    | EDC          |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 125      | 32    | EDC          |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 126      | 1     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                  | Group ID | Width | Checker Type |
|-----------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 127      | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 128      | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 129      | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 130      | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 131      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0 | 0        | 48    | Parity       |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0 | 1        | 48    | Parity       |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0 | 2        | 48    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 1        | 12    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 3        | 10    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 4        | 12    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 5        | 2     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 6        | 3     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 7        | 12    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 8        | 4     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 9        | 3     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 10       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 11       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 12       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 13       | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 14       | 10    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 15       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 16       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 17       | 4     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 18       | 8     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 19       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 20       | 32    | EDC          |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 21       | 32    | EDC          |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 22       | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 23       | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 24       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 25       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 26       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 27       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 28       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 29       | 38    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 30       | 54    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 31       | 46    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 32       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 33       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 34       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 35       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRRAM_EDC_CTRL_0        | 36       | 64    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 37       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 38       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 39       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 40       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 41       | 34    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 42       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 43       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 44       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 45       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 46       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 47       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 48       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 49       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 50       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 51       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 52       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 53       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 54       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 55       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 56       | 34    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 57       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 58       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 59       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 60       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 61       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0              | 62       | 36    | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 3        | 8     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 4        | 5     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 6        | 5     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 8        | 32    | EDC          |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 9        | 32    | EDC          |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 10       | 32    | EDC          |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 11       | 32    | EDC          |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 16       | 1     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 17       | 1     | Parity       |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGER_EDC_CTRL_0 | 18       | 1     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 19       | 4     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 20       | 3     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 22       | 8     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 23       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 24       | 12    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 25       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 27       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 28       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 29       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 30       | 16    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 31       | 16    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 32       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 3        | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 4        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 8        | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 9        | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 10       | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 11       | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 16       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 17       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 18       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 19       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 20       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 22       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 23       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 24       | 12    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 25       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 27       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 28       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 29       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 30       | 16    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEGR_EDC_CTRL_0     | 31       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEGR_EDC_CTRL_0     | 32       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 1        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 3        | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 4        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 6        | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 8        | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 10       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 16       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 17       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 19       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 20       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 21       | 12    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 22       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 23       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 24       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 25       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 27       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 28       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 29       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 3        | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 4        | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 6        | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 8        | 32    | EDC          |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 10       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 12       | 1     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                             | Group ID | Width | Checker Type |
|----------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 16       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 17       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 19       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 20       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 21       | 12    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 22       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 23       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 24       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 25       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 27       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 28       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGER_EDC_CTRL_0 | 29       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 1        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 3        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 8        | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 9        | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 10       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 11       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 12       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 13       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 14       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 15       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 16       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 17       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 20       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 21       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 22       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 23       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 24       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 25       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 26       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0   | 27       | 2     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                           | Group ID | Width | Checker Type |
|--------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 28       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 29       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 31       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 32       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 33       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 34       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 35       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 36       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 37       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 38       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 40       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 41       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 44       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 45       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 46       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 47       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 48       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 49       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 50       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 51       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 52       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 53       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 54       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 55       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 56       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 57       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 58       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 59       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 60       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 61       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 62       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 63       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 64       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 65       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 66       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 67       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 68       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 69       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 71       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 72       | 2     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 73       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 74       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 75       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 76       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 77       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 78       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 79       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 80       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 81       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 82       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 83       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 84       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 85       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 86       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 87       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 88       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 89       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 90       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 91       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 92       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 93       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 94       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 95       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 96       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 97       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 98       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 99       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 100      | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 1        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 3        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 8        | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 9        | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 12       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 13       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 14       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 15       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 16       | 2     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 17       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 20       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 21       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 22       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 23       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 25       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 27       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 28       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 29       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 31       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 32       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 33       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 34       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 35       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 36       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 37       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 38       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 40       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 41       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 44       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 45       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 46       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 47       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 48       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 49       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 50       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 51       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 52       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 53       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 54       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 55       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 56       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 57       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 58       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 59       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 60       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 61       | 1     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 62       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 63       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 64       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 65       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 66       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 67       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 68       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 69       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 71       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 72       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 73       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 74       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 75       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 76       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 77       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 78       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 79       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 80       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 81       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 82       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 83       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 84       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 85       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 86       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 87       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 88       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 89       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 90       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 91       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 92       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 93       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 94       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 95       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 96       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 97       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 98       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 99       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 100      | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0         | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0         | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0         | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0         | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0         | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0         | 5        | 4     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                     | Group ID | Width | Checker Type |
|--------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 10       | 10    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 25       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 29       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 31       | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0  | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 10       | 10    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0 | 15       | 1     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 25       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 29       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 31       | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 10       | 10    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 25       | 12    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 29       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 31       | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0            | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_EVT_EDC_CTRL_0               | 0        | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_EVT_EDC_CTRL_0               | 1        | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_INTAGGR_CEV <sub>T</sub> _EDC_CTRL_0 | 0        | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_CEV <sub>T</sub> _EDC_CTRL_0 | 1        | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_INTAGGR_MEVT_IN_EDC_CTRL_0           | 0        | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_MEVT_IN_EDC_CTRL_0           | 1        | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 10       | 10    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 25       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0           | 29       | 12    | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                         | Group ID | Width | Checker Type |
|------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 31       | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_CFG_EDC_CTRL_0                 | 0        | 12    | Parity       |
| DMSS_HSM_PSILSS_CFG_EDC_CTRL_0                 | 1        | 12    | Parity       |
| DMSS_HSM_PSILSS_CFG_EDC_CTRL_0                 | 2        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 1        | 48    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 3        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 4        | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 6        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 8        | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 9        | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 12       | 48    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 14       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 15       | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 16       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 17       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 18       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 20       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 21       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 23       | 48    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 25       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 26       | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 28       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 29       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 31       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 33       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 34       | 48    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 35       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 36       | 4     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 38       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 39       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 41       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 46       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 47       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 48       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 49       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 50       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 51       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 52       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 53       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 54       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 55       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 56       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 57       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 58       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 59       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 60       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 61       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 62       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 63       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 66       | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 67       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 68       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 69       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 71       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 72       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 73       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 74       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 75       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 76       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 77       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 78       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 79       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 80       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 81       | 9     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                         | Group ID | Width | Checker Type |
|------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 82       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 83       | 6     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 84       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 85       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 86       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 87       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 88       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 89       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 90       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 91       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 92       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 93       | 5     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 94       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 95       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 96       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 97       | 32    | EDC          |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 98       | 32    | EDC          |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 99       | 32    | EDC          |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 100      | 32    | EDC          |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 101      | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 102      | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 103      | 10    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 104      | 10    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 105      | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 1        | 32    | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 3        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 4        | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 6        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 8        | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 9        | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 12       | 32    | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 14       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 15       | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 16       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 17       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 18       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 20       | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 21       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 23       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 25       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 26       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 28       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 29       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 31       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 33       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 34       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 35       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 38       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 39       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 41       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 46       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 47       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 48       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 49       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 50       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 51       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 52       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 53       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 54       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 55       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 56       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 57       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 58       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 59       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 60       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 61       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 62       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 63       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 66       | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 67       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 68       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 69       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 71       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 72       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 73       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 74       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 75       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 76       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 77       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 78       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 79       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 80       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 81       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 82       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 83       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 84       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 85       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 86       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 87       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 88       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 89       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 90       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 91       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 92       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 93       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 94       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 95       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 96       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 97       | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 98       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 99       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 100      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 101      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 102      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 1        | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 2        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 3        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 4        | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 5        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 6        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 7        | 4     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 8        | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 9        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 12       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 14       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 15       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 16       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 17       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 18       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 20       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 21       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 23       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 25       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 26       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 28       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 29       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 31       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 33       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 34       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 35       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 38       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 39       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 41       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 45       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 46       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 47       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 48       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 49       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 50       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 51       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 52       | 2     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 53       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 54       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 55       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 56       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 57       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 58       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 59       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 60       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 61       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 62       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 63       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 66       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 67       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 68       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 69       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 70       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 71       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 72       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 73       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 74       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 75       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 76       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 77       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 78       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 79       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 80       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 81       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 82       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 83       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 84       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 85       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 86       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 87       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 88       | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 89       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 90       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 91       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 92       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 93       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 94       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 95       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 96       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 97       | 9     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 98       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 99       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 100      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 101      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 102      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 103      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 104      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 105      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 106      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 107      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 108      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 109      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 110      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 111      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 112      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 113      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 114      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 115      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 116      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 117      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 118      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 119      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 120      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 121      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 122      | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 123      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 124      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 125      | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 126      | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 127      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 128      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 129      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 130      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 0        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 1        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 2        | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 3        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 4        | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 5        | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 6        | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 7        | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 8        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 9        | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 0        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 1        | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 2        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 3        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 4        | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 5        | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 6        | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 0        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 1        | 23    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 2        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 3        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 4        | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 5        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 6        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 7        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 8        | 2     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 9        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 10       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 11       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 12       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 13       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 14       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 15       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 16       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 17       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 18       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 19       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 20       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 21       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 22       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 23       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 24       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 25       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 26       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 27       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 28       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 29       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 30       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 31       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 32       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 33       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 34       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 35       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 36       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 37       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 38       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 39       | 1     | Redundant    |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                | Group ID | Width | Checker Type |
|---------------------------------------|----------|-------|--------------|
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 40       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 41       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 45       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 46       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 47       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 48       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 49       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 50       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 51       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 52       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 53       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 54       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 55       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 56       | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 57       | 9     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 58       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 59       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 60       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 61       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 62       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 63       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 64       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 65       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 66       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 67       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 68       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 69       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 70       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 71       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 72       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 73       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 74       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 75       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 76       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 77       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 78       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 79       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 80       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 81       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 82       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 83       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 84       | 1     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                | Group ID | Width | Checker Type |
|---------------------------------------|----------|-------|--------------|
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 85       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 86       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 87       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 88       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 89       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 90       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 0        | 48    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 1        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 2        | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 3        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 4        | 17    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 5        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 6        | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 8        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 10       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 11       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 12       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 13       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 14       | 2     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 15       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 16       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 17       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 18       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 19       | 22    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 20       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 21       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 22       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 23       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 25       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 26       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 27       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 28       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 29       | 2     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 30       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 31       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 33       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 34       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 35       | 17    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 38       | 4     | Parity       |

**Table 4-216. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                | Group ID | Width | Checker Type |
|---------------------------------------|----------|-------|--------------|
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 39       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 41       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 42       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 44       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 45       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 46       | 9     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 47       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 48       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 49       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 50       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 51       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 52       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 53       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 54       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 55       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 56       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 57       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 58       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 59       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 60       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 61       | 1     | Parity       |

**Table 4-217. Properties of ECC Aggregator Instance SMS0**

| RAM ID Name   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| ISRAM0_RAMECC | 0      | ECC Wrapper | Inject with error capture | Yes             | 32        | 192 KB   |
| ISRAM1_RAMECC | 1      | ECC Wrapper | Inject with error capture | Yes             | 32        | 64 KB    |
| ISRAM0_RAMECC | 0      | ECC Wrapper | Inject with error capture | Yes             | 32        | 128 KB   |
| ISRAM1_RAMECC | 1      | ECC Wrapper | Inject with error capture | Yes             | 32        | 48 KB    |

**Table 4-218. Properties of ECC Aggregator Instance SMS0**

| RAM ID Name                                           | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| ISRAM0_BUSECC                                         | 2      | EDC Interconnect | Inject with error capture | Yes             | 20                     |
| ISRAM1_BUSECC                                         | 3      | EDC Interconnect | Inject with error capture | Yes             | 20                     |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 4      | EDC Interconnect | Inject with error capture | Yes             | 186                    |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC  | 5      | EDC Interconnect | Inject with error capture | Yes             | 13                     |

**Table 4-218. Properties of ECC Aggregator Instance SMS0 (continued)**

| RAM ID Name                                                               | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|---------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| SMS_HSM_CBASS_SMS_HSM_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_EDC_CTRL_BUSECC       | 6      | EDC Interconnect | Inject with error capture | Yes             | 166                    |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                               | 7      | EDC Interconnect | Inject with error capture | Yes             | 63                     |
| SMS_HSM_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_DEFAULT_MMRS_EDC_CTRL_BUSECC     | 8      | EDC Interconnect | Inject with error capture | Yes             | 8                      |
| SMS_HSM_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC     | 9      | EDC Interconnect | Inject with error capture | Yes             | 42                     |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                  | 10     | EDC Interconnect | Inject with error capture | Yes             | 19                     |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                                          | 11     | EDC Interconnect | Inject with error capture | Yes             | 16                     |
| SMS_HSM_ECC_EDC_CTRL                                                      | 12     | EDC Interconnect | Inject with error capture | Yes             | 6                      |
| ISRAM0_BUSECC                                                             | 2      | EDC Interconnect | Inject with error capture | Yes             | 20                     |
| ISRAM1_BUSECC                                                             | 3      | EDC Interconnect | Inject with error capture | Yes             | 20                     |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0                  | 4      | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1                  | 5      | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2                  | 6      | EDC Interconnect | Inject with error capture | Yes             | 26                     |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                     | 7      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                 | 8      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_EDC_CTRL_BUSECC_0 | 9      | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_EDC_CTRL_BUSECC_1 | 10     | EDC Interconnect | Inject with error capture | Yes             | 43                     |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                              | 11     | EDC Interconnect | Inject with error capture | Yes             | 63                     |
| SMS_TIFS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_DEFAULT_MMRS_EDC_CTRL_BUSECC   | 12     | EDC Interconnect | Inject with error capture | Yes             | 8                      |
| SMS_TIFS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_INT_DMSC_SCR_EDC_CTRL_BUSECC   | 13     | EDC Interconnect | Inject with error capture | Yes             | 42                     |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                 | 14     | EDC Interconnect | Inject with error capture | Yes             | 19                     |
| SMS_FWMGR_CBASS_SMS_SCR_SMS_FWMGR_CBASS_SMS_SCR_EDC_CTRL_BUSECC           | 15     | EDC Interconnect | Inject with error capture | Yes             | 66                     |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC         | 16     | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| SMS_TIFS_WWRTI_CM_EDC_CTRL_BUSECC                                         | 17     | EDC Interconnect | Inject with error capture | Yes             | 6                      |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                               | 18     | EDC Interconnect | Inject with error capture | Yes             | 36                     |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC                                           | 19     | EDC Interconnect | Inject with error capture | Yes             | 37                     |
| SMS_TIFS_ECC_EDC_CTRL                                                     | 20     | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0**

| Protected Interconnect                                | Group ID | Width | Checker Type |
|-------------------------------------------------------|----------|-------|--------------|
| ISRAM0_BUSECC                                         | 0        | 1     | Redundant    |
| ISRAM0_BUSECC                                         | 1        | 32    | EDC          |
| ISRAM0_BUSECC                                         | 2        | 1     | Parity       |
| ISRAM0_BUSECC                                         | 3        | 18    | Parity       |
| ISRAM0_BUSECC                                         | 4        | 4     | Parity       |
| ISRAM0_BUSECC                                         | 5        | 3     | Parity       |
| ISRAM0_BUSECC                                         | 6        | 1     | Parity       |
| ISRAM0_BUSECC                                         | 7        | 1     | Parity       |
| ISRAM0_BUSECC                                         | 8        | 10    | Parity       |
| ISRAM0_BUSECC                                         | 9        | 12    | Parity       |
| ISRAM0_BUSECC                                         | 10       | 4     | Parity       |
| ISRAM0_BUSECC                                         | 11       | 12    | Parity       |
| ISRAM0_BUSECC                                         | 12       | 2     | Parity       |
| ISRAM0_BUSECC                                         | 13       | 3     | Parity       |
| ISRAM0_BUSECC                                         | 14       | 1     | Parity       |
| ISRAM0_BUSECC                                         | 15       | 1     | Parity       |
| ISRAM0_BUSECC                                         | 16       | 1     | Parity       |
| ISRAM0_BUSECC                                         | 17       | 1     | Redundant    |
| ISRAM0_BUSECC                                         | 18       | 64    | Parity       |
| ISRAM0_BUSECC                                         | 19       | 28    | Parity       |
| ISRAM1_BUSECC                                         | 0        | 1     | Redundant    |
| ISRAM1_BUSECC                                         | 1        | 32    | EDC          |
| ISRAM1_BUSECC                                         | 2        | 1     | Parity       |
| ISRAM1_BUSECC                                         | 3        | 16    | Parity       |
| ISRAM1_BUSECC                                         | 4        | 4     | Parity       |
| ISRAM1_BUSECC                                         | 5        | 3     | Parity       |
| ISRAM1_BUSECC                                         | 6        | 1     | Parity       |
| ISRAM1_BUSECC                                         | 7        | 1     | Parity       |
| ISRAM1_BUSECC                                         | 8        | 10    | Parity       |
| ISRAM1_BUSECC                                         | 9        | 12    | Parity       |
| ISRAM1_BUSECC                                         | 10       | 4     | Parity       |
| ISRAM1_BUSECC                                         | 11       | 12    | Parity       |
| ISRAM1_BUSECC                                         | 12       | 2     | Parity       |
| ISRAM1_BUSECC                                         | 13       | 3     | Parity       |
| ISRAM1_BUSECC                                         | 14       | 1     | Parity       |
| ISRAM1_BUSECC                                         | 15       | 1     | Parity       |
| ISRAM1_BUSECC                                         | 16       | 1     | Parity       |
| ISRAM1_BUSECC                                         | 17       | 1     | Redundant    |
| ISRAM1_BUSECC                                         | 18       | 64    | Parity       |
| ISRAM1_BUSECC                                         | 19       | 28    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 0        | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 1        | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 2        | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 3        | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 4        | 3     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                | Group ID | Width | Checker Type |
|-------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 5        | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 6        | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 7        | 8     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 8        | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 9        | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 10       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 11       | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 12       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 13       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 14       | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 15       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 16       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 17       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 18       | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 19       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 20       | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 21       | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 22       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 23       | 8     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 24       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 25       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 26       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 27       | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 28       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 29       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 30       | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 31       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 32       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 33       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 34       | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 35       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 36       | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 37       | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 38       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 39       | 8     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 40       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 41       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 42       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 43       | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 44       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 45       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 46       | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 47       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 48       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 49       | 10    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                | Group ID | Width | Checker Type |
|-------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 50       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 51       | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 52       | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 53       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 54       | 8     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 55       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 56       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 57       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 58       | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 59       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 60       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 61       | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 62       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 63       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 64       | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 65       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 66       | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 67       | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 68       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 69       | 8     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 70       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 71       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 72       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 73       | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 74       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 75       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 76       | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 77       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 78       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 79       | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 80       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 81       | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 82       | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 83       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 84       | 8     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 85       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 86       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 87       | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 88       | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 89       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 90       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 91       | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 92       | 48    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 93       | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 94       | 32    | EDC          |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                | Group ID | Width | Checker Type |
|-------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 95       | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 96       | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 97       | 32    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 98       | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 99       | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 100      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 101      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 102      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 103      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 104      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 105      | 32    | EDC          |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 106      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 107      | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 108      | 32    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 109      | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 110      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 111      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 112      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 113      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 114      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 115      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 116      | 32    | EDC          |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 117      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 118      | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 119      | 32    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 120      | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 121      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 122      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 123      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 124      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 125      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 126      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 127      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 128      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 129      | 32    | EDC          |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 130      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 131      | 8     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 132      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 133      | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 134      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 135      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 136      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 137      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 138      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 139      | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                | Group ID | Width | Checker Type |
|-------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 140      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 141      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 142      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 143      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 144      | 32    | EDC          |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 145      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 146      | 32    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 147      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 148      | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 149      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 150      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 151      | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 152      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 153      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 154      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 155      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 156      | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 157      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 158      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 159      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 160      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 161      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 162      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 163      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 164      | 32    | EDC          |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 165      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 166      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 167      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 168      | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 169      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 170      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 171      | 10    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 172      | 5     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 173      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 174      | 4     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 175      | 12    | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 176      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 177      | 3     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 178      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 179      | 2     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 180      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 181      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 182      | 1     | Parity       |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 183      | 1     | Redundant    |
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC | 184      | 2     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC                           | 185      | 12    | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 0        | 1     | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 1        | 32    | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 2        | 1     | Redundant    |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 3        | 1     | Redundant    |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 4        | 1     | Redundant    |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 5        | 1     | Redundant    |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 6        | 1     | Redundant    |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 7        | 8     | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 8        | 8     | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 9        | 8     | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 10       | 8     | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 11       | 1     | Parity       |
| SMS_HSM_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC                            | 12       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 0        | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 1        | 32    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 2        | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 3        | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 4        | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 5        | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 6        | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 7        | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 8        | 2     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 9        | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 10       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 11       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 12       | 32    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 13       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 14       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 15       | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 16       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 17       | 4     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 18       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 19       | 2     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 20       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 21       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 22       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 23       | 32    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 24       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 25       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 26       | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 27       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 28       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 29       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 30       | 2     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 31       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 32       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 33       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 34       | 32    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 35       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 36       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 37       | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 38       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 39       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 40       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 41       | 2     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 42       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 43       | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 44       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 45       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 46       | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 47       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 48       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 49       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 50       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 51       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 52       | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 53       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 54       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 55       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 56       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 57       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 58       | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 59       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 60       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 61       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 62       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 63       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 64       | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 65       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 66       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 67       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 68       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 69       | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 70       | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 71       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 72       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 73       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 74       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 75       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 76       | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 77       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 78       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 79       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 80       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 81       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 82       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 83       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 84       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 85       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 86       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 87       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 88       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 89       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 90       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 91       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 92       | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 93       | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 94       | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 95       | 4     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 96       | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 97       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 98       | 8     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 99       | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 100      | 5     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 101      | 8     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 102      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 103      | 5     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 104      | 11    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 105      | 7     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 106      | 8     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 107      | 11    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 108      | 7     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 109      | 8     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 110      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 111      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 112      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 113      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 114      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 115      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 116      | 35    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 117      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 118      | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 119      | 35    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 120      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 121      | 3     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 122      | 35    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 123      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 124      | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 125      | 35    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 126      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 127      | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 128      | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 129      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 130      | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 131      | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 132      | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 133      | 12    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 134      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 135      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 136      | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 137      | 5     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 138      | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 139      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 140      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 141      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 142      | 32    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 143      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 144      | 3     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 145      | 5     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 146      | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 147      | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 148      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 149      | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 150      | 8     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 151      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 152      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 153      | 4     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 154      | 5     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 155      | 26    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 156      | 5     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 157      | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 158      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 159      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 160      | 32    | EDC          |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 161      | 1     | Redundant    |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 162      | 1     | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 163      | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 164      | 10    | Parity       |
| SMS_HSM_CBASS_SMS_HSM_SCR_SCR_SMS_HSM_CBASS_SMS_HSM_SCR_S<br>CR_EDC_CTRL_BUSECC | 165      | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 0        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 1        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 2        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 3        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 4        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 5        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 6        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 7        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 8        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 9        | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 10       | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 11       | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 12       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 13       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                     | 14       | 6     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 15       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 16       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 17       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 18       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 19       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 20       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 21       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 22       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 23       | 6     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 24       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 25       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 26       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 27       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 28       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 29       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 30       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 31       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 32       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 33       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 34       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 35       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 36       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 37       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 38       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 39       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 40       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 41       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 42       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 43       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 44       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 45       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 46       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 47       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 48       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 49       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 50       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 51       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 52       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 53       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 54       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 55       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 56       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 57       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 58       | 16    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC | 59       | 16    | Parity       |

Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                           | 60       | 32    | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                           | 61       | 1     | Parity       |
| SMS_HSM_RAT_EDC_CTRL_BUSECC                                                           | 62       | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 0        | 32    | Parity       |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 1        | 32    | Parity       |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 2        | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 3        | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 4        | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 5        | 16    | Parity       |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 6        | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_DEFAULT_MMRS_SMS_HSM_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 7        | 32    | EDC          |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 0        | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 1        | 19    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 2        | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 3        | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 4        | 3     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 5        | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 6        | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 7        | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 8        | 2     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 9        | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 10       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 11       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 12       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 13       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 14       | 12    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 15       | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 16       | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 17       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 18       | 10    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 19       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 20       | 12    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 21       | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 22       | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 23       | 4     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 24       | 7     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 25       | 2     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 26       | 3     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 27       | 3     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 28       | 26    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 29       | 3     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 30       | 3     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 31       | 26    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 32       | 3     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 33       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 34       | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 35       | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 36       | 32    | EDC          |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 37       | 1     | Redundant    |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 38       | 1     | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 39       | 10    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 40       | 10    | Parity       |
| SMS_HSM_CBASS_CBASS_INT_DMSC_SCR_SMS_HSM_CBASS_CBASS_INT_D<br>MSC_SCR_EDC_CTRL_BUSECC | 41       | 1     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                              | 0        | 1     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                              | 1        | 1     | Redundant    |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                              | 2        | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 3        | 1     | Redundant    |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 4        | 16    | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 5        | 3     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 6        | 3     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 7        | 1     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 8        | 1     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 9        | 2     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 10       | 3     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 11       | 1     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 12       | 10    | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 13       | 5     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 14       | 3     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 15       | 4     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 16       | 2     | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 17       | 16    | Parity       |
| SMS_HSM_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC | 18       | 3     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 0        | 32    | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 1        | 32    | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 2        | 4     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 3        | 4     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 4        | 3     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 5        | 4     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 6        | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 7        | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 8        | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 9        | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 10       | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 11       | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 12       | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 13       | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 14       | 1     | Parity       |
| SMS_HSM_WWRTI_CM_EDC_CTRL_BUSECC                         | 15       | 1     | Parity       |
| SMS_HSM_ECC_EDC_CTRL                                     | 0        | 1     | Redundant    |
| SMS_HSM_ECC_EDC_CTRL                                     | 1        | 32    | EDC          |
| SMS_HSM_ECC_EDC_CTRL                                     | 2        | 1     | Parity       |
| SMS_HSM_ECC_EDC_CTRL                                     | 3        | 10    | Parity       |
| SMS_HSM_ECC_EDC_CTRL                                     | 4        | 4     | Parity       |
| SMS_HSM_ECC_EDC_CTRL                                     | 5        | 3     | Parity       |
| ISRAM0_BUSECC                                            | 0        | 1     | Redundant    |
| ISRAM0_BUSECC                                            | 1        | 32    | EDC          |
| ISRAM0_BUSECC                                            | 2        | 1     | Parity       |
| ISRAM0_BUSECC                                            | 3        | 17    | Parity       |
| ISRAM0_BUSECC                                            | 4        | 4     | Parity       |
| ISRAM0_BUSECC                                            | 5        | 3     | Parity       |
| ISRAM0_BUSECC                                            | 6        | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| ISRAM0_BUSECC                                            | 7        | 1     | Parity       |
| ISRAM0_BUSECC                                            | 8        | 10    | Parity       |
| ISRAM0_BUSECC                                            | 9        | 12    | Parity       |
| ISRAM0_BUSECC                                            | 10       | 4     | Parity       |
| ISRAM0_BUSECC                                            | 11       | 12    | Parity       |
| ISRAM0_BUSECC                                            | 12       | 2     | Parity       |
| ISRAM0_BUSECC                                            | 13       | 3     | Parity       |
| ISRAM0_BUSECC                                            | 14       | 1     | Parity       |
| ISRAM0_BUSECC                                            | 15       | 1     | Parity       |
| ISRAM0_BUSECC                                            | 16       | 1     | Parity       |
| ISRAM0_BUSECC                                            | 17       | 1     | Redundant    |
| ISRAM0_BUSECC                                            | 18       | 64    | Parity       |
| ISRAM0_BUSECC                                            | 19       | 28    | Parity       |
| ISRAM1_BUSECC                                            | 0        | 1     | Redundant    |
| ISRAM1_BUSECC                                            | 1        | 32    | EDC          |
| ISRAM1_BUSECC                                            | 2        | 1     | Parity       |
| ISRAM1_BUSECC                                            | 3        | 16    | Parity       |
| ISRAM1_BUSECC                                            | 4        | 4     | Parity       |
| ISRAM1_BUSECC                                            | 5        | 3     | Parity       |
| ISRAM1_BUSECC                                            | 6        | 1     | Parity       |
| ISRAM1_BUSECC                                            | 7        | 1     | Parity       |
| ISRAM1_BUSECC                                            | 8        | 10    | Parity       |
| ISRAM1_BUSECC                                            | 9        | 12    | Parity       |
| ISRAM1_BUSECC                                            | 10       | 4     | Parity       |
| ISRAM1_BUSECC                                            | 11       | 12    | Parity       |
| ISRAM1_BUSECC                                            | 12       | 2     | Parity       |
| ISRAM1_BUSECC                                            | 13       | 3     | Parity       |
| ISRAM1_BUSECC                                            | 14       | 1     | Parity       |
| ISRAM1_BUSECC                                            | 15       | 1     | Parity       |
| ISRAM1_BUSECC                                            | 16       | 1     | Parity       |
| ISRAM1_BUSECC                                            | 17       | 1     | Redundant    |
| ISRAM1_BUSECC                                            | 18       | 64    | Parity       |
| ISRAM1_BUSECC                                            | 19       | 28    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 0        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 1        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 2        | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 3        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 4        | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 5        | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 6        | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 7        | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 8        | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 9        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 10       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 11       | 12    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 12       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 13       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 14       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 15       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 16       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 17       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 18       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 19       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 20       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 21       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 22       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 23       | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 24       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 25       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 26       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 27       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 28       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 29       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 30       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 31       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 32       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 33       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 34       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 35       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 36       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 37       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 38       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 39       | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 40       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 41       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 42       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 43       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 44       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 45       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 46       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 47       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 48       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 49       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 50       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 51       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 52       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 53       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 54       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 55       | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 56       | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 57       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 58       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 59       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 60       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 61       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 62       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 63       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 64       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 65       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 66       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 67       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 68       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 69       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 70       | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 71       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 72       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 73       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 74       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 75       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 76       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 77       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 78       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 79       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 80       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 81       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 82       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 83       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 84       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 85       | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 86       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 87       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 88       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 89       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 90       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 91       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 92       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 93       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 94       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 95       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 96       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 97       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 98       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 99       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 100      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 101      | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 102      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 103      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 104      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 105      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 106      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 107      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 108      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 109      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 110      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 111      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 112      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 113      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 114      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 115      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 116      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 117      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 118      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 119      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 120      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 121      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 122      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 123      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 124      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 125      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 126      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 127      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 128      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 129      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 130      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 131      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 132      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 133      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 134      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 135      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 136      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 137      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 138      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 139      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 140      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 141      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 142      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 143      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 144      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 145      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 146      | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 147      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 148      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 149      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 150      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 151      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 152      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 153      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 154      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 155      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 156      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 157      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 158      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 159      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 160      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 161      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 162      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 163      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 164      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 165      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 166      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 167      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 168      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 169      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 170      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 171      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 172      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 173      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 174      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 175      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 176      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 177      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 178      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 179      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 180      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 181      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 182      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 183      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 184      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 185      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 186      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 187      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 188      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 189      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 190      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 191      | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 192      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 193      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 194      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 195      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 196      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 197      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 198      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 199      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 200      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 201      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 202      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 203      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 204      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 205      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 206      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 207      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 208      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 209      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 210      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 211      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 212      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 213      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 214      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 215      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 216      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 217      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 218      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 219      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 220      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 221      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 222      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 223      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 224      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 225      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 226      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 227      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 228      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 229      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 230      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 231      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 232      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 233      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 234      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 235      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 236      | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 237      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 238      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 239      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 240      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 241      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 242      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 243      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 244      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 245      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 246      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 247      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 248      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 249      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 250      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 251      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 252      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 253      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 254      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_0 | 255      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 0        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 1        | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 2        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 3        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 4        | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 5        | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 6        | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 7        | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 8        | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 9        | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 10       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 11       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 12       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 13       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 14       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 15       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 16       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 17       | 48    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 18       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 19       | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 20       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 21       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 22       | 32    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 23       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 24       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 25       | 4     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 26       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 27       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 28       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 29       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 30       | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 31       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 32       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 33       | 32    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 34       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 35       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 36       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 37       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 38       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 39       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 40       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 41       | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 42       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 43       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 44       | 32    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 45       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 46       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 47       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 48       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 49       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 50       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 51       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 52       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 53       | 18    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 54       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 55       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 56       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 57       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 58       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 59       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 60       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 61       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 62       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 63       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 64       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 65       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 66       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 67       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 68       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 69       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 70       | 32    | EDC          |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 71       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 72       | 11    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 73       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 74       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 75       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 76       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 77       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 78       | 5     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 79       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 80       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 81       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 82       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 83       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 84       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 85       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 86       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 87       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 88       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 89       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 90       | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 91       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 92       | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 93       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 94       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 95       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 96       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 97       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 98       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 99       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 100      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 101      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 102      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 103      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 104      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 105      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 106      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 107      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 108      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 109      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 110      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 111      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 112      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 113      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 114      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 115      | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 116      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 117      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 118      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 119      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 120      | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 121      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 122      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 123      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 124      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 125      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 126      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 127      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 128      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 129      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 130      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 131      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 132      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 133      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 134      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 135      | 32    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 136      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 137      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 138      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 139      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 140      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 141      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 142      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 143      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 144      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 145      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 146      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 147      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 148      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 149      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 150      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 151      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 152      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 153      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 154      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 155      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 156      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 157      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 158      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 159      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 160      | 10    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 161      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 162      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 163      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 164      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 165      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 166      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 167      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 168      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 169      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 170      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 171      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 172      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 173      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 174      | 32    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 175      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 176      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 177      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 178      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 179      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 180      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 181      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 182      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 183      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 184      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 185      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 186      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 187      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 188      | 14    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 189      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 190      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 191      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 192      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 193      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 194      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 195      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 196      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 197      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 198      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 199      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 200      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 201      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 202      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 203      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 204      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 205      | 32    | EDC          |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                   | Group ID | Width | Checker Type |
|----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 206      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 207      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 208      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 209      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 210      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 211      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 212      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 213      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 214      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 215      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 216      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 217      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 218      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 219      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 220      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 221      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 222      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 223      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 224      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 225      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 226      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 227      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 228      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 229      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 230      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 231      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 232      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 233      | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 234      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 235      | 13    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 236      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 237      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 238      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 239      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 240      | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 241      | 5     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 242      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 243      | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 244      | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 245      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 246      | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 247      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 248      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 249      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1 | 250      | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                    | Group ID | Width | Checker Type |
|-----------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1  | 251      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1  | 252      | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1  | 253      | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1  | 254      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_1  | 255      | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 0        | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 1        | 32    | EDC          |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 2        | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 3        | 8     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 4        | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 5        | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 6        | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 7        | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 8        | 10    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 9        | 5     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 10       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 11       | 4     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 12       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 13       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 14       | 3     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 15       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 16       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 17       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 18       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 19       | 1     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 20       | 1     | Redundant    |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 21       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 22       | 2     | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 23       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 24       | 12    | Parity       |
| SMS_TIFS_CBASS_VBUS_CLK_EDC_CTRL_CBASS_INT_VBUS_BUSECC_2  | 25       | 12    | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 0        | 1     | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 1        | 32    | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 2        | 1     | Redundant    |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 3        | 1     | Redundant    |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 4        | 1     | Redundant    |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 5        | 1     | Redundant    |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 6        | 1     | Redundant    |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 7        | 8     | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 8        | 8     | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 9        | 8     | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 10       | 8     | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 11       | 1     | Parity       |
| SMS_TIFS_CBASS_IECC_S_P2P_BRIDGE_IECC_S_BRIDGE_BUSECC     | 12       | 1     | Parity       |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC | 0        | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                            | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 1        | 32    | Parity       |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 2        | 1     | Redundant    |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 3        | 1     | Redundant    |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 4        | 1     | Redundant    |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 5        | 1     | Redundant    |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 6        | 1     | Redundant    |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 7        | 8     | Parity       |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 8        | 8     | Parity       |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 9        | 8     | Parity       |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 10       | 8     | Parity       |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 11       | 1     | Parity       |
| SMS_TIFS_CBASS_IFWMGR_M_P2P_BRIDGE_IFWMGR_M_BRIDGE_BUSECC                         | 12       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 0        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 1        | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 2        | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 3        | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 4        | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 5        | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 6        | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 7        | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 8        | 2     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 9        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 10       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 11       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 12       | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 13       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 14       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 15       | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 16       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 17       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 18       | 4     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 19       | 2     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 20       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 21       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 22       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 23       | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 24       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 25       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 26       | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 27       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 28       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 29       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 30       | 2     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 31       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 32       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 33       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 34       | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 35       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 36       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 37       | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 38       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 39       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 40       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 41       | 2     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 42       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 43       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 44       | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 45       | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 46       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 47       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 48       | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 49       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 50       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 51       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 52       | 2     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 53       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 54       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 55       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 56       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 57       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 58       | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 59       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 60       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 61       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 62       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 63       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 64       | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 65       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 66       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 67       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 68       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 69       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 70       | 12    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 71       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 72       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 73       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 74       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 75       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 76       | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 77       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 78       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 79       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 80       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 81       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 82       | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 83       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 84       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 85       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 86       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 87       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 88       | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 89       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 90       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 91       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 92       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 93       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 94       | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 95       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 96       | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 97       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 98       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 99       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 100      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 101      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 102      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 103      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 104      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 105      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 106      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 107      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 108      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 109      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 110      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 111      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 112      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 113      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 114      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 115      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 116      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 117      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 118      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 119      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 120      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 121      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 122      | 10    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 123      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 124      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 125      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 126      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 127      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 128      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 129      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 130      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 131      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 132      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 133      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 134      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 135      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 136      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 137      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 138      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 139      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 140      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 141      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 142      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 143      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 144      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 145      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 146      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 147      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 148      | 12    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 149      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 150      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 151      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 152      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 153      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 154      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 155      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 156      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 157      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 158      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 159      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 160      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 161      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 162      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 163      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 164      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 165      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 166      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 167      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 168      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 169      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 170      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 171      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 172      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 173      | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 174      | 4     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 175      | 9     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 176      | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 177      | 6     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 178      | 9     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 179      | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 180      | 6     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 181      | 21    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 182      | 17    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 183      | 18    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 184      | 22    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 185      | 18    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 186      | 19    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 187      | 22    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 188      | 18    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 189      | 19    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 190      | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 191      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 192      | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 193      | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 194      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 195      | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 196      | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 197      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 198      | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 199      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 200      | 26    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 201      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 202      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 203      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 204      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 205      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 206      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 207      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 208      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 209      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 210      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 211      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 212      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 213      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 214      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 215      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 216      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 217      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 218      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 219      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 220      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 221      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 222      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 223      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 224      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 225      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 226      | 44    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 227      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 228      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 229      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 230      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 231      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 232      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 233      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 234      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 235      | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 236      | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 237      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 238      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 239      | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 240      | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 241      | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 242      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 243      | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 244      | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 245      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 246      | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 247      | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 248      | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 249      | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 250      | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 251      | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 252      | 5     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 253      | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 254      | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_0 | 255      | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 0        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 1        | 8     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 2        | 44    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 3        | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 4        | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 5        | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 6        | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 7        | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 8        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 9        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 10       | 12    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 11       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 12       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 13       | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 14       | 5     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 15       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 16       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 17       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 18       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 19       | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 20       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 21       | 3     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 22       | 5     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 23       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 24       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 25       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 26       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 27       | 8     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 28       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 29       | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 30       | 4     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 31       | 6     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 32       | 26    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 33       | 6     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 34       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 35       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 36       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 37       | 32    | EDC          |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 38       | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 39       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 40       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 41       | 10    | Parity       |
| SMS_TIFS_CBASS_SMS_TIFS_SCR_SCR_SMS_TIFS_CBASS_SMS_TIFS_SCR_S<br>CR_EDC_CTRL_BUSECC_1 | 42       | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 0        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 1        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 2        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 3        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 4        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 5        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 6        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 7        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 8        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 9        | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                          | 10       | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect       | Group ID | Width | Checker Type |
|------------------------------|----------|-------|--------------|
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 11       | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 12       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 13       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 14       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 15       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 16       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 17       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 18       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 19       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 20       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 21       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 22       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 23       | 6     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 24       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 25       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 26       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 27       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 28       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 29       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 30       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 31       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 32       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 33       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 34       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 35       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 36       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 37       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 38       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 39       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 40       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 41       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 42       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 43       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 44       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 45       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 46       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 47       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 48       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 49       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 50       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 51       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 52       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 53       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 54       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC | 55       | 16    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                            | 56       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                            | 57       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                            | 58       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                            | 59       | 16    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                            | 60       | 32    | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                            | 61       | 1     | Parity       |
| SMS_TIFS_RAT_EDC_CTRL_BUSECC                                                            | 62       | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 0        | 32    | Parity       |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 1        | 32    | Parity       |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 2        | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 3        | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 4        | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 5        | 17    | Parity       |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 6        | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_DEFAULT_MMRS_SMS_TIFS_CBASS_CBASS_DEF<br>LT_MMRS_EDC_CTRL_BUSECC   | 7        | 32    | EDC          |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 0        | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 1        | 20    | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 2        | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 3        | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 4        | 3     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 5        | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 6        | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 7        | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 8        | 2     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 9        | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 10       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 11       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 12       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 13       | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 14       | 12    | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 15       | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 16       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 17       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 18       | 10    | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 19       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 20       | 12    | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 21       | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 22       | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 23       | 4     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 24       | 7     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 25       | 2     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 26       | 3     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 27       | 3     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 28       | 26    | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 29       | 3     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 30       | 3     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 31       | 26    | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 32       | 3     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 33       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 34       | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 35       | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 36       | 32    | EDC          |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 37       | 1     | Redundant    |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 38       | 1     | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 39       | 10    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                                  | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------|----------|-------|--------------|
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 40       | 10    | Parity       |
| SMS_TIFS_CBASS_CBASS_INT_DMSC_SCR_SMS_TIFS_CBASS_CBASS_INT_DM<br>SC_SCR_EDC_CTRL_BUSECC | 41       | 1     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 0        | 1     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 1        | 1     | Redundant    |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 2        | 1     | Redundant    |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 3        | 1     | Redundant    |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 4        | 17    | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 5        | 3     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 6        | 3     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 7        | 1     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 8        | 1     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 9        | 2     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 10       | 3     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 11       | 1     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 12       | 10    | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 13       | 5     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 14       | 3     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 15       | 4     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 16       | 2     | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 17       | 17    | Parity       |
| SMS_TIFS_CBASS_DMSC_SLV_P2P_BRIDGE_DMSC_SLV_BRIDGE_BUSECC                               | 18       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 0        | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 1        | 24    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 2        | 1     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 3        | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 4        | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 5        | 1     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 6        | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 7        | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 8        | 2     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 9        | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 10       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 11       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_<br>EDC_CTRL_BUSECC             | 12       | 1     | Redundant    |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 13       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 14       | 12    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 15       | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 16       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 17       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 18       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 19       | 12    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 20       | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 21       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 22       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 23       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 24       | 12    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 25       | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 26       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 27       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 28       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 29       | 12    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 30       | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 31       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 32       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 33       | 10    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 34       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 35       | 12    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 36       | 4     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 37       | 1     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 38       | 4     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 39       | 9     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 40       | 5     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 41       | 6     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 42       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 43       | 26    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 44       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 45       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 46       | 26    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 47       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 48       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 49       | 26    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 50       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 51       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 52       | 26    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 53       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 54       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 55       | 26    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 56       | 3     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 57       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 58       | 1     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 59       | 1     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 60       | 32    | EDC          |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 61       | 1     | Redundant    |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 62       | 1     | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 63       | 10    | Parity       |
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 64       | 10    | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect                                                  | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------|----------|-------|--------------|
| SMS_FWMGR_CBASS_SMS_SCR_SCR_SMS_FWMGR_CBASS_SMS_SCR_SCR_EDC_CTRL_BUSECC | 65       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 0        | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 1        | 32    | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 2        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 3        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 4        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 5        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 6        | 1     | Redundant    |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 7        | 8     | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 8        | 8     | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 9        | 8     | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 10       | 8     | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 11       | 1     | Parity       |
| SMS_TIFS_CBASS_SMS_DMSS_HSM_P2P_BRIDGE_SMS_DMSS_HSM_BRIDGE_BUSECC       | 12       | 1     | Parity       |
| SMS_TIFS_WWRTI_CM_EDC_CTRL_BUSECC                                       | 0        | 32    | Parity       |
| SMS_TIFS_WWRTI_CM_EDC_CTRL_BUSECC                                       | 1        | 32    | Parity       |
| SMS_TIFS_WWRTI_CM_EDC_CTRL_BUSECC                                       | 2        | 4     | Parity       |
| SMS_TIFS_WWRTI_CM_EDC_CTRL_BUSECC                                       | 3        | 4     | Parity       |
| SMS_TIFS_WWRTI_CM_EDC_CTRL_BUSECC                                       | 4        | 3     | Parity       |
| SMS_TIFS_WWRTI_CM_EDC_CTRL_BUSECC                                       | 5        | 4     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 0        | 32    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 1        | 32    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 2        | 32    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 3        | 32    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 4        | 3     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 5        | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 6        | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 7        | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 8        | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 9        | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 10       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 11       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 12       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 13       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC                                             | 14       | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect          | Group ID | Width | Checker Type |
|---------------------------------|----------|-------|--------------|
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 15       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 16       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 17       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 18       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 19       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 20       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 21       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 22       | 4     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 23       | 12    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 24       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 25       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 26       | 1     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 27       | 24    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 28       | 32    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 29       | 32    | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 30       | 2     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 31       | 2     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 32       | 2     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 33       | 3     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 34       | 3     | Parity       |
| SMS_TIFS_CM_EDC_CTRL_BUSECC     | 35       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 0        | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 1        | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 2        | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 3        | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 4        | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 5        | 3     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 6        | 3     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 7        | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 8        | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 9        | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 10       | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 11       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 12       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 13       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 14       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 15       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 16       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 17       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 18       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 19       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 20       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 21       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 22       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 23       | 1     | Parity       |

**Table 4-219. EDC checkers information for ECC Aggregator Instance SMS0 (continued)**

| Protected Interconnect          | Group ID | Width | Checker Type |
|---------------------------------|----------|-------|--------------|
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 24       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 25       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 26       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 27       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 28       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 29       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 30       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 31       | 1     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 32       | 4     | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 33       | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 34       | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 35       | 32    | Parity       |
| SMS_TIFS_SEC_CM_EDC_CTRL_BUSECC | 36       | 32    | Parity       |
| SMS_TIFS_ECC_EDC_CTRL           | 0        | 1     | Redundant    |
| SMS_TIFS_ECC_EDC_CTRL           | 1        | 32    | EDC          |
| SMS_TIFS_ECC_EDC_CTRL           | 2        | 1     | Parity       |
| SMS_TIFS_ECC_EDC_CTRL           | 3        | 10    | Parity       |
| SMS_TIFS_ECC_EDC_CTRL           | 4        | 4     | Parity       |
| SMS_TIFS_ECC_EDC_CTRL           | 5        | 3     | Parity       |

**Table 4-220. Properties of ECC Aggregator Instance USB0**

| RAM ID Name                                                             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| USB2SS_16FFC_USB2SS_CORE_AXI2VBUSM_MST_KSB<br>US_AXI2VBUSM_RDATA_BUFFER | 0      | ECC Wrapper | Inject with error capture | Yes             | 66        | 4 KB     |
| USB2SS_16FFC_USB2SS_CORE_RAMs_MEM_CTRL_RA<br>M0                         | 1      | ECC Wrapper | Inject with error capture | Yes             | 64        | 56 KB    |

**Table 4-221. Properties of ECC Aggregator Instance USB1**

| RAM ID Name                                                             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| USB2SS_16FFC_USB2SS_CORE_AXI2VBUSM_MST_KSB<br>US_AXI2VBUSM_RDATA_BUFFER | 0      | ECC Wrapper | Inject with error capture | Yes             | 66        | 4 KB     |
| USB2SS_16FFC_USB2SS_CORE_RAMs_MEM_CTRL_RA<br>M0                         | 1      | ECC Wrapper | Inject with error capture | Yes             | 64        | 56 KB    |

**Table 4-222. Properties of ECC Aggregator Instance WKUP\_ECC\_AGGR0**

| RAM ID Name                                                                                       | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|---------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC                                | 0      | EDC Interconnect | Inject with error capture | Yes             | 26                     |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC                                | 1      | EDC Interconnect | Inject with error capture | Yes             | 22                     |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUSB_P2P_BRIDGE_IK3VTM_N16FFC_WKUP_0_VBUSB_BRIDGE_BUSECC | 2      | EDC Interconnect | Inject with error capture | Yes             | 13                     |

**Table 4-222. Properties of ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| RAM ID Name                                                                                                                                                                                          | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WK_UP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WK_UP_0_CFG_BRIDGE_DST_BUSECC                                                                                        | 3      | EDC Interconnect | Inject with error capture | Yes             | 7                      |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WK_UP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WK_UP_0_CFG_BRIDGE_SRC_BUSECC                                                                                        | 4      | EDC Interconnect | Inject with error capture | Yes             | 17                     |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WK_UP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 5      | EDC Interconnect | Inject with error capture | Yes             | 73                     |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WK_UP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 6      | EDC Interconnect | Inject with error capture | Yes             | 66                     |
| SAM62_DM_ECC_AGGR_EDC_CTRL                                                                                                                                                                           | 7      | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0**

| Protected Interconnect                                             | Group ID | Width | Checker Type |
|--------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 0        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 1        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 2        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 3        | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 4        | 4     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 5        | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 6        | 10    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 7        | 10    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 8        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 9        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 10       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 11       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 12       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 13       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 14       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 15       | 1     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                             | Group ID | Width | Checker Type |
|--------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 16       | 32    | EDC          |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 17       | 32    | EDC          |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 18       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 19       | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 20       | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 21       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 22       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 23       | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 24       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_1_CLK_EDC_CTRL_CBASS_INT_DM_CLK_1_BUSECC | 25       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 0        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 1        | 32    | EDC          |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 2        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 3        | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 4        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 5        | 4     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 6        | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 7        | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 8        | 10    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 9        | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 10       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 11       | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 12       | 32    | EDC          |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 13       | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 14       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC | 15       | 1     | Redundant    |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                      | Group ID | Width | Checker Type |
|-------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC                                          | 16       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC                                          | 17       | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC                                          | 18       | 12    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC                                          | 19       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC                                          | 20       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_DM_CLK_4_CLK_EDC_CTRL_CBASS_INT_DM_CLK_4_BUSECC                                          | 21       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 0        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 1        | 32    | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 2        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 3        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 4        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 5        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 6        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 7        | 8     | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 8        | 8     | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 9        | 8     | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 10       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 11       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_IK3VTM_N16FFC_WKUP_0_VBUPSP_P2P_BRIDGE_IK3_VTM_N16FFC_WKUP_0_VBUPSP_BRIDGE_BUSECC        | 12       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_DST_BUSECC | 0        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_DST_BUSECC | 1        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_DST_BUSECC | 2        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_DST_BUSECC | 3        | 10    | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_DST_BUSECC | 4        | 3     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_DST_BUSECC | 5        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_DST_BUSECC | 6        | 1     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                                              | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 0        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 1        | 32    | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 2        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 3        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 4        | 10    | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 5        | 3     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 6        | 3     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 7        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 8        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 9        | 2     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 10       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 11       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 12       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 13       | 5     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 14       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 15       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_DM_ECC_AGGR_WKUP_0_CFG_BRIDGE_SRC_BUSECC                                                                                         | 16       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 0        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 1        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 2        | 9     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 3        | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 4        | 10    | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 5        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 6        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 7        | 36    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 8        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 9        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 10       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 11       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 12       | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 13       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 14       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 15       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 16       | 9     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 17       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 18       | 10    | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 19       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 20       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 21       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 22       | 9     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 23       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 24       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 25       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 26       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 27       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 28       | 2     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 29       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 30       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 31       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 32       | 3     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 33       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 34       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 35       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 36       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 37       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 38       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 39       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 40       | 6     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 41       | 6     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 42       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 43       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 44       | 5     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 45       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 46       | 4     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 47       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 48       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 49       | 2     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 50       | 2     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 51       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 52       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 53       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 54       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 55       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 56       | 2     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 57       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 58       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 59       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 60       | 8     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 61       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 62       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 63       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 64       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 65       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 66       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 67       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 68       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 69       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 70       | 5     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 71       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_DST_EDC_CTRL_BUSECC | 72       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 0        | 24    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 1        | 1     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 2        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 3        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 4        | 36    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 5        | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 6        | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 7        | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 8        | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 9        | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 10       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 11       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 12       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 13       | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 14       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 15       | 1     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                                              | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 16       | 1     | Redundant    |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 17       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 18       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 19       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 20       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 21       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 22       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 23       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 24       | 10    | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 25       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 26       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 27       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 28       | 2     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 29       | 2     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 30       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 31       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 32       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 33       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 34       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 35       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 36       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 37       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 38       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 39       | 8     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 40       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 41       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 42       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 43       | 1     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 44       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 45       | 5     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 46       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 47       | 2     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 48       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 49       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 50       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 51       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 52       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 53       | 2     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 54       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 55       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 56       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 57       | 3     | Parity       |

**Table 4-223. EDC checkers information for ECC Aggregator Instance WKUP\_ECC\_AGGR0 (continued)**

| Protected Interconnect                                                                                                                                                                              | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 58       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 59       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 60       | 3     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC                           | 61       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 62       | 5     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 63       | 1     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 64       | 4     | Parity       |
| AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_AM62_WKUP_DM_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2M_BRIDGE_SRC_EDC_CTRL_BUSECC | 65       | 4     | Parity       |
| SAM62_DM_ECC_AGGR_EDC_CTRL                                                                                                                                                                          | 0        | 1     | Redundant    |
| SAM62_DM_ECC_AGGR_EDC_CTRL                                                                                                                                                                          | 1        | 32    | EDC          |
| SAM62_DM_ECC_AGGR_EDC_CTRL                                                                                                                                                                          | 2        | 1     | Parity       |
| SAM62_DM_ECC_AGGR_EDC_CTRL                                                                                                                                                                          | 3        | 10    | Parity       |
| SAM62_DM_ECC_AGGR_EDC_CTRL                                                                                                                                                                          | 4        | 4     | Parity       |
| SAM62_DM_ECC_AGGR_EDC_CTRL                                                                                                                                                                          | 5        | 3     | Parity       |

**Table 4-224. Properties of ECC Aggregator Instance WKUP\_R5FSS0**

| RAM ID Name      | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU0_ITAG_RAM0   | 0      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM1   | 1      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM2   | 2      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM3   | 3      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_IDATA_BANK0 | 4      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK1 | 5      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK2 | 6      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK3 | 7      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_DTAG_RAM0   | 8      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM1   | 9      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |

**Table 4-224. Properties of ECC Aggregator Instance WKUP\_R5FSS0 (continued)**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CPU0_DTAG_RAM2                                  | 10     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM3                                  | 11     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DDIRTY_RAM                                 | 12     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DDATA_RAM0                                 | 13     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM1                                 | 14     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM2                                 | 15     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM3                                 | 16     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM4                                 | 17     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM5                                 | 18     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM6                                 | 19     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM7                                 | 20     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| PULSAR_UL_ATCM0_BANK0                           | 21     | ECC Wrapper | Inject only               | No              | 39        | 20 KB    |
| PULSAR_UL_ATCM0_BANK1                           | 22     | ECC Wrapper | Inject only               | No              | 39        | 20 KB    |
| PULSAR_UL_B0TCM0_BANK0                          | 23     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_B0TCM0_BANK1                          | 24     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_B1TCM0_BANK0                          | 25     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_B1TCM0_BANK1                          | 26     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_PULSAR_KS_VIM_COMMON_CORE0_RAM        | 27     | ECC Wrapper | Inject with error capture | Yes             | 30        | 960 B    |
| PULSAR_UL_MEM_MST0_KSBUS_AXI2VBUSM_RDATA_BUFFER | 28     | ECC Wrapper | Inject with error capture | Yes             | 66        | 528 B    |

**Table 4-225. Properties of ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0**

| RAM ID Name                                                                                                                         | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0                                                                                                 | 0      | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1                                                                                                 | 1      | EDC Interconnect | Inject with error capture | Yes             | 214                    |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC                                                                                                    | 2      | EDC Interconnect | Inject with error capture | Yes             | 45                     |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0                                                                                        | 3      | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1                                                                                        | 4      | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                        | 5      | EDC Interconnect | Inject with error capture | Yes             | 172                    |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_BRIDGE_BUSECC | 6      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| ISAM62_DM2WS_VBUSEM_GASKET MCU_0_EDC_CTRL                                                                                           | 7      | EDC Interconnect | Inject with error capture | Yes             | 1                      |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC             | 8      | EDC Interconnect | Inject with error capture | Yes             | 13                     |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT MCU_SYSCLK0_4_BUSECC                                                      | 9      | EDC Interconnect | Inject with error capture | Yes             | 121                    |

**Table 4-225. Properties of ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0 (continued)**

| RAM ID Name                                                                                                                                                       | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_EDC_CTRL_BUS_ECC_0                                                                          | 10     | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_EDC_CTRL_BUS_ECC_1                                                                          | 11     | EDC Interconnect | Inject with error capture | Yes             | 154                    |
| AM62_WKUP_SAFE_CBASS_DEFAULT_ERR_AM62_WKUP_SAFE_CBASS_DEFAULT_ERR_EDC_CTRL_BUSECC                                                                                 | 12     | EDC Interconnect | Inject with error capture | Yes             | 5                      |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC                                                                                         | 13     | EDC Interconnect | Inject with error capture | Yes             | 42                     |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ER_R_SLV_BRIDGE_BUSECC                                                                                                    | 14     | EDC Interconnect | Inject with error capture | Yes             | 19                     |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 15     | EDC Interconnect | Inject with error capture | Yes             | 31                     |
| SAM62_WKUP_SAFE_ECC_AGGR_EDC_CTRL                                                                                                                                 | 16     | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 0        | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 1        | 28    | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 2        | 32    | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 3        | 32    | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 4        | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 5        | 6     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 6        | 6     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 7        | 6     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 8        | 6     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 9        | 6     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 10       | 6     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 11       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 12       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 13       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 14       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 15       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 16       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 17       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 18       | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 19       | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 20       | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 21       | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 22       | 3     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 23       | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 24       | 8     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 25       | 3     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_0 | 26       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 27       | 8     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 28       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 29       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 30       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 31       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 32       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 33       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 34       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 35       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 36       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 37       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 38       | 6     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 39       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 40       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 41       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 42       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 43       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 44       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 45       | 7     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 46       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 47       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 48       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 49       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 50       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 51       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 52       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 53       | 6     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 54       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 55       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 56       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 57       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 58       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 59       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 60       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 61       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 62       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 63       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 64       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 65       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 66       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 67       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 68       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 69       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 70       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 71       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 72       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 73       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 74       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 75       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 76       | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 77       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 78       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 79       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 80       | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 81       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 82       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 83       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 84       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 85       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 86       | 14    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 87       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 88       | 21    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 89       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 90       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 91       | 30    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 92       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 93       | 8     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 94       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 95       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 96       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 97       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 98       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 99       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 100      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 101      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 102      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 103      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 104      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 105      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 106      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 107      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 108      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 109      | 31    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 110      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 111      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 112      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 113      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 114      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 115      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 116      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 117      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 118      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 119      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 120      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 121      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 122      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 123      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 124      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 125      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 126      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 127      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 128      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 129      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 130      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 131      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 132      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 133      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 134      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 135      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 136      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 137      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 138      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 139      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 140      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 141      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 142      | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 143      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 144      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 145      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 146      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 147      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 148      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 149      | 6     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 150      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 151      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 152      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 153      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 154      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 155      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 156      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 157      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 158      | 3     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 159      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 160      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 161      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 162      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 163      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 164      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 165      | 6     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 166      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 167      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 168      | 6     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 169      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 170      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 171      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 172      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 173      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 174      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 175      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 176      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 177      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 178      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 179      | 5     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 180      | 7     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 181      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 182      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 183      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 184      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 185      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 186      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 187      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 188      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 189      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 190      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 191      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 192      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 193      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 194      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 195      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 196      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 197      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 198      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 199      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 200      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 201      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 202      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 203      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 204      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 205      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 206      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 207      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 208      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 209      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 210      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 211      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 212      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 213      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 214      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 215      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 216      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 217      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 218      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 219      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 220      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 221      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 222      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 223      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 224      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 225      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 226      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 227      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 228      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 229      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 230      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 231      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 232      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 233      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 234      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 235      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 236      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 237      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 238      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 239      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 240      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 241      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 242      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 243      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 244      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 245      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 246      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 247      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 248      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 249      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 250      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 251      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 252      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 253      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 254      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_0 | 255      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 0        | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 1        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 2        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 3        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 4        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 5        | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 6        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 7        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 8        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 9        | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 10       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 11       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 12       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 13       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 14       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 15       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 16       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 17       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 18       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 19       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 20       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 21       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 22       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 23       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 24       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 25       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 26       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 27       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 28       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 29       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 30       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 31       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 32       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 33       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 34       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 35       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 36       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 37       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 38       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 39       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 40       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 41       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 42       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 43       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 44       | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 45       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 46       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 47       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 48       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 49       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 50       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 51       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 52       | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 53       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 54       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 55       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 56       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 57       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 58       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 59       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 60       | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 61       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 62       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 63       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 64       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 65       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 66       | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 67       | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 68       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 69       | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 70       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 71       | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 72       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 73       | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 74       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 75       | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 76       | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 77       | 12    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 78       | 4     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 79       | 12    | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 80       | 4     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 81       | 12    | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 82       | 4     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 83       | 12    | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 84       | 4     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 85       | 32    | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 86       | 32    | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 87       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 88       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 89       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 90       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 91       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 92       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 93       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 94       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 95       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 96       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 97       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 98       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 99       | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 100      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 101      | 8     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 102      | 8     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 103      | 4     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 104      | 7     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 105      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 106      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 107      | 7     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 108      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 109      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 110      | 7     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 111      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 112      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 113      | 7     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 114      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 115      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 116      | 7     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 117      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 118      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 119      | 7     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 120      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 121      | 1     | Parity       |
| AM62 MCU CTRL_MMR_EDC_CTRL_BUSECC_1 | 122      | 7     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 123      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 124      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 125      | 7     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 126      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 127      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 128      | 7     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 129      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 130      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 131      | 7     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 132      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 133      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 134      | 7     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 135      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 136      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 137      | 7     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 138      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 139      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 140      | 7     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 141      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 142      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 143      | 7     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 144      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 145      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 146      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 147      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 148      | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 149      | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 150      | 4     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 151      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 152      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 153      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 154      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 155      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 156      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 157      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 158      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 159      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 160      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 161      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 162      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 163      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 164      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 165      | 1     | Parity       |
| AM62 MCU CTRL MMR EDC CTRL BUSECC_1 | 166      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 167      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 168      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 169      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 170      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 171      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 172      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 173      | 6     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 174      | 6     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 175      | 3     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 176      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 177      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 178      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 179      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 180      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 181      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 182      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 183      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 184      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 185      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 186      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 187      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 188      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 189      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 190      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 191      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 192      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 193      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 194      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 195      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 196      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 197      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 198      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 199      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 200      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 201      | 2     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 202      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 203      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 204      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 205      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 206      | 1     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 207      | 8     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 208      | 8     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 209      | 4     | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 210      | 32    | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 211      | 32    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 212      | 24    | Parity       |
| AM62 MCU_CTRL_MMR_EDC_CTRL_BUSECC_1 | 213      | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 0        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 1        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 2        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 3        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 4        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 5        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 6        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 7        | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 8        | 12    | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 9        | 24    | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 10       | 6     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 11       | 3     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 12       | 3     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 13       | 12    | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 14       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 15       | 3     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 16       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 17       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 18       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 19       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 20       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 21       | 8     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 22       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 23       | 5     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 24       | 4     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 25       | 7     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 26       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 27       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 28       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 29       | 7     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 30       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 31       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 32       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 33       | 7     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 34       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 35       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 36       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 37       | 7     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 38       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 39       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC    | 40       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC             | 41       | 7     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC             | 42       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC             | 43       | 1     | Parity       |
| AM62 MCU_PLL_MMR_EDC_CTRL_BUSECC             | 44       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 0        | 32    | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 1        | 32    | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 2        | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 3        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 4        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 5        | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 6        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 7        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 8        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 9        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 10       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 11       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 12       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 13       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 14       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 15       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 16       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 17       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 18       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 19       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 20       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 21       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 22       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 23       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 24       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 25       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 26       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 27       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 28       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 29       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 30       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 31       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 32       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 33       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 34       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 35       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 36       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 37       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 38       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 39       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 40       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 41       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 42       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 43       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 44       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 45       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 46       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 47       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 48       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 49       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 50       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 51       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 52       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 53       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 54       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 55       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 56       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 57       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 58       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 59       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 60       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 61       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 62       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 63       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 64       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 65       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 66       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 67       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 68       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 69       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 70       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 71       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 72       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 73       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 74       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 75       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 76       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 77       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 78       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 79       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 80       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 81       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 82       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 83       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 84       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 85       | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 86       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 87       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 88       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 89       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 90       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 91       | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 92       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 93       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 94       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 95       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 96       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 97       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 98       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 99       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 100      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 101      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 102      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 103      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 104      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 105      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 106      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 107      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 108      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 109      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 110      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 111      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 112      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 113      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 114      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 115      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 116      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 117      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 118      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 119      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 120      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 121      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 122      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 123      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 124      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 125      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 126      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 127      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 128      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 129      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 130      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 131      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 132      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 133      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 134      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 135      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 136      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 137      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 138      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 139      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 140      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 141      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 142      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 143      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 144      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 145      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 146      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 147      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 148      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 149      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 150      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 151      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 152      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 153      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 154      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 155      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 156      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 157      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 158      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 159      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 160      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 161      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 162      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 163      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 164      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 165      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 166      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 167      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 168      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 169      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 170      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 171      | 2     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 172      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 173      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 174      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 175      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 176      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 177      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 178      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 179      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 180      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 181      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 182      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 183      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 184      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 185      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 186      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 187      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 188      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 189      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 190      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 191      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 192      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 193      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 194      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 195      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 196      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 197      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 198      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 199      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 200      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 201      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 202      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 203      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 204      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 205      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 206      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 207      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 208      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 209      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 210      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 211      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 212      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 213      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 214      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 215      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 216      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 217      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 218      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 219      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 220      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 221      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 222      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 223      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 224      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 225      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 226      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 227      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 228      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 229      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 230      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 231      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 232      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 233      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 234      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 235      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 236      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 237      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 238      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 239      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 240      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 241      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 242      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 243      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 244      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 245      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 246      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 247      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 248      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 249      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 250      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 251      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 252      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 253      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 254      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_0 | 255      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 0        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 1        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 2        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 3        | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 4        | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 5        | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 6        | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 7        | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 8        | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 9        | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 10       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 11       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 12       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 13       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 14       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 15       | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 16       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 17       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 18       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 19       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 20       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 21       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 22       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 23       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 24       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 25       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 26       | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 27       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 28       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 29       | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 30       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 31       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 32       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 33       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 34       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 35       | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 36       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 37       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 38       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 39       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 40       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 41       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 42       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 43       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 44       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 45       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 46       | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 47       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 48       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 49       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 50       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 51       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 52       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 53       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 54       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 55       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 56       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 57       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 58       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 59       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 60       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 61       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 62       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 63       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 64       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 65       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 66       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 67       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 68       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 69       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 70       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 71       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 72       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 73       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 74       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 75       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 76       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 77       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 78       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 79       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 80       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 81       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 82       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 83       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 84       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 85       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 86       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 87       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 88       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 89       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 90       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 91       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 92       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 93       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 94       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 95       | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 96       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 97       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 98       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 99       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 100      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 101      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 102      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 103      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 104      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 105      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 106      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 107      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 108      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 109      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 110      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 111      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 112      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 113      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 114      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 115      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 116      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 117      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 118      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 119      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 120      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 121      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 122      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 123      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 124      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 125      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 126      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 127      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 128      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 129      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 130      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 131      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 132      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 133      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 134      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 135      | 2     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 136      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 137      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 138      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 139      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 140      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 141      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 142      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 143      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 144      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 145      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 146      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 147      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 148      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 149      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 150      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 151      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 152      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 153      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 154      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 155      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 156      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 157      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 158      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 159      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 160      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 161      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 162      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 163      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 164      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 165      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 166      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 167      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 168      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 169      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 170      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 171      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 172      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 173      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 174      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 175      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 176      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 177      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 178      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 179      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 180      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 181      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 182      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 183      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 184      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 185      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 186      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 187      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 188      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 189      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 190      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 191      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 192      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 193      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 194      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 195      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 196      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 197      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 198      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 199      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 200      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 201      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 202      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 203      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 204      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 205      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 206      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 207      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 208      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 209      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 210      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 211      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 212      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 213      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 214      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 215      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 216      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 217      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 218      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 219      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 220      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 221      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 222      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 223      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 224      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 225      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 226      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 227      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 228      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 229      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 230      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 231      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 232      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 233      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 234      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 235      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 236      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 237      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 238      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 239      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 240      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 241      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 242      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 243      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 244      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 245      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 246      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 247      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 248      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 249      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 250      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 251      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 252      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 253      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 254      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_1 | 255      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 0        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 1        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 2        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 3        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 4        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 5        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 6        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 7        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 8        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 9        | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 10       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 11       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 12       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 13       | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 14       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 15       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 16       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 17       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 18       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 19       | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 20       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 21       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 22       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 23       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 24       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 25       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 26       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 27       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 28       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 29       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 30       | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 31       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 32       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 33       | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 34       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 35       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 36       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 37       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 38       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 39       | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 40       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 41       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 42       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 43       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 44       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 45       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 46       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 47       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 48       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 49       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 50       | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 51       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 52       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 53       | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 54       | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 55       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 56       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 57       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 58       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 59       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 60       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 61       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 62       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 63       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 64       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 65       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 66       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 67       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 68       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 69       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 70       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 71       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 72       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 73       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 74       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 75       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 76       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 77       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 78       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 79       | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 80       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 81       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 82       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 83       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 84       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 85       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 86       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 87       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 88       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 89       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 90       | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 91       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 92       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 93       | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 94       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 95       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 96       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 97       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 98       | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 99       | 2     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 100      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 101      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 102      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 103      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 104      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 105      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 106      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 107      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 108      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 109      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 110      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 111      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 112      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 113      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 114      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 115      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 116      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 117      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 118      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 119      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 120      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 121      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 122      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 123      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 124      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 125      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 126      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 127      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 128      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 129      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 130      | 4     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 131      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 132      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 133      | 3     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 134      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 135      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 136      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 137      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 138      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 139      | 2     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 140      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 141      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 142      | 1     | Parity       |
| AM62XX_MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2 | 143      | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                                                               | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 144      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 145      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 146      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 147      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 148      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 149      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 150      | 4     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 151      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 152      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 153      | 3     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 154      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 155      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 156      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 157      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 158      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 159      | 2     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 160      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 161      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 162      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 163      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 164      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 165      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 166      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 167      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 168      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 169      | 1     | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 170      | 32    | Parity       |
| AM62XX MCU_PADCFG_CTRL_MMR_EDC_CTRL_BUSECC_2                                                                                         | 171      | 32    | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B_RIDGE_BUSECC | 0        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B_RIDGE_BUSECC | 1        | 32    | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B_RIDGE_BUSECC | 2        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B_RIDGE_BUSECC | 3        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B_RIDGE_BUSECC | 4        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B_RIDGE_BUSECC | 5        | 1     | Redundant    |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                                                               | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B RIDGE_BUSECC | 6        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B RIDGE_BUSECC | 7        | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B RIDGE_BUSECC | 8        | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B RIDGE_BUSECC | 9        | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B RIDGE_BUSECC | 10       | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B RIDGE_BUSECC | 11       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_P2P_BRIDGE_IAM62_WKUP_SAFE_CBASS_WKUP_0_CBASS_ERR_SLV_B RIDGE_BUSECC | 12       | 1     | Parity       |
| ISAM62_DM2WS_VBUSM_GASKET MCU_0_EDC_CTRL                                                                                             | 0        | 48    | Parity       |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 0        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 1        | 32    | Parity       |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 2        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 3        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 4        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 5        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 6        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 7        | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 8        | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 9        | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSECC              | 10       | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                                                   | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSE_CC | 11       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_P2P_BRIDGE_ISAM62_WKUP_SAFE_ECC_AGGR_WKUP_0_CFG_BRIDGE_BUSE_CC | 12       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 0        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 1        | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 2        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 3        | 9     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 4        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 5        | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 6        | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 7        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 8        | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 9        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 10       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 11       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 12       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 13       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 14       | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 15       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 16       | 15    | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 17       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 18       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 19       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 20       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 21       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC                                          | 22       | 2     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 23       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 24       | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 25       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 26       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 27       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 28       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 29       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 30       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 31       | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 32       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 33       | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 34       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 35       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 36       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 37       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 38       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 39       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 40       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 41       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 42       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 43       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 44       | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 45       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 46       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 47       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 48       | 3     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 49       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 50       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 51       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 52       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 53       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 54       | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 55       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 56       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 57       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 58       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 59       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 60       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 61       | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 62       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 63       | 17    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 64       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 65       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 66       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 67       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 68       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 69       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 70       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 71       | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 72       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 73       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 74       | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                          | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 75       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 76       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 77       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 78       | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 79       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 80       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 81       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 82       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 83       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 84       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 85       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 86       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 87       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 88       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 89       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 90       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 91       | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 92       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 93       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 94       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 95       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 96       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 97       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 98       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 99       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC | 100      | 4     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                   | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 101      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 102      | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 103      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 104      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 105      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 106      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 107      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 108      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 109      | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 110      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 111      | 9     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 112      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 113      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 114      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 115      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 116      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 117      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 118      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 119      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS MCU_SYSCLK0_4_CLK_EDC_CTRL_CBASS_INT_M CU_SYSCLK0_4_BUSECC          | 120      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS SCR_PSAFE_SCR_AM62_WKUP_SAFE_CBASS_SC RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 0        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS SCR_PSAFE_SCR_AM62_WKUP_SAFE_CBASS_SC RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 1        | 36    | Parity       |
| AM62_WKUP_SAFE_CBASS SCR_PSAFE_SCR_AM62_WKUP_SAFE_CBASS_SC RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 2        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS SCR_PSAFE_SCR_AM62_WKUP_SAFE_CBASS_SC RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 3        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS SCR_PSAFE_SCR_AM62_WKUP_SAFE_CBASS_SC RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 4        | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS SCR_PSAFE_SCR_AM62_WKUP_SAFE_CBASS_SC RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 5        | 1     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 6        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 7        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 8        | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 9        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 10       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 11       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 12       | 36    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 13       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 14       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 15       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 16       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 17       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 18       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 19       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 20       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 21       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 22       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 23       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 24       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 25       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 26       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 27       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 28       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 29       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 30       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 31       | 1     | Redundant    |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 32       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 33       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 34       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 35       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 36       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 37       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 38       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 39       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 40       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 41       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 42       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 43       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 44       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 45       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 46       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 47       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 48       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 49       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 50       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 51       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 52       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 53       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 54       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 55       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 56       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 57       | 4     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 58       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 59       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 60       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 61       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 62       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 63       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 64       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 65       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 66       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 67       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 68       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 69       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 70       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 71       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 72       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 73       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 74       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 75       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 76       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 77       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 78       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 79       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 80       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 81       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 82       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 83       | 1     | Redundant    |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 84       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 85       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 86       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 87       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 88       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 89       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 90       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 91       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 92       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 93       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 94       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 95       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 96       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 97       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 98       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 99       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 100      | 36    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 101      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 102      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 103      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 104      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 105      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 106      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 107      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 108      | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 109      | 10    | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 110      | 15    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 111      | 11    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 112      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 113      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 114      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 115      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 116      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 117      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 118      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 119      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 120      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 121      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 122      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 123      | 36    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 124      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 125      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 126      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 127      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 128      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 129      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 130      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 131      | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 132      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 133      | 15    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 134      | 11    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 135      | 12    | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 136      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 137      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 138      | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 139      | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 140      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 141      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 142      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 143      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 144      | 9     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 145      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 146      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 147      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 148      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 149      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 150      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 151      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 152      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 153      | 9     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 154      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 155      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 156      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 157      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 158      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 159      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 160      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 161      | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 162      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 163      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 164      | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 165      | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 166      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 167      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 168      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 169      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 170      | 15    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 171      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 172      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 173      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 174      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 175      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 176      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 177      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 178      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 179      | 15    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 180      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 181      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 182      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 183      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 184      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 185      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 186      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 187      | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 188      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 189      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 190      | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 191      | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 192      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 193      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 194      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 195      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 196      | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 197      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 198      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 199      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 200      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 201      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 202      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 203      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 204      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 205      | 8     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 206      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 207      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 208      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 209      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 210      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 211      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 212      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 213      | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 214      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 215      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 216      | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 217      | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 218      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 219      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 220      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 221      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 222      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 223      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 224      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 225      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 226      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 227      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 228      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 229      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 230      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 231      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 232      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 233      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 234      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 235      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 236      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 237      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 238      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 239      | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 240      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 241      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 242      | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 243      | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 244      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 245      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 246      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 247      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 248      | 17    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 249      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 250      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 251      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 252      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 253      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 254      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_0 | 255      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 0        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 1        | 17    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 2        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 3        | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 4        | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 5        | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 6        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 7        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 8        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 9        | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 10       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 11       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 12       | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 13       | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 14       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 15       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 16       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 17       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 18       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 19       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 20       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 21       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 22       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 23       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 24       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 25       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 26       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 27       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 28       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 29       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 30       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 31       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 32       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 33       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 34       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 35       | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 36       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 37       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 38       | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 39       | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 40       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 41       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 42       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 43       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 44       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 45       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 46       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 47       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 48       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 49       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 50       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 51       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 52       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 53       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 54       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 55       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 56       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 57       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 58       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 59       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 60       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 61       | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 62       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 63       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 64       | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 65       | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 66       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 67       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 68       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 69       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 70       | 9     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 71       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 72       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 73       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 74       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 75       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 76       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 77       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 78       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 79       | 9     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 80       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 81       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 82       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 83       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 84       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 85       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 86       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 87       | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 88       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 89       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 90       | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 91       | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 92       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 93       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 94       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 95       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 96       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 97       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 98       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 99       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 100      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 101      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 102      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 103      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 104      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 105      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 106      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 107      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 108      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 109      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 110      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 111      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 112      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 113      | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 114      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 115      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 116      | 19    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 117      | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 118      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 119      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 120      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 121      | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 122      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 123      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 124      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 125      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 126      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 127      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 128      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 129      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 130      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 131      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 132      | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 133      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 134      | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 135      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 136      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 137      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 138      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1 | 139      | 8     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                            | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 140      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 141      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 142      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 143      | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 144      | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 145      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 146      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 147      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 148      | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 149      | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 150      | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 151      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_SCRP_SAFE_SCR_AM62_WKUP_SAFE_CBASS_SC<br>RP_SAFE_SCR_EDC_CTRL_BUSECC_1       | 152      | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_CBASS_DEFAULT_ERR_AM62_WKUP_SAFE_CBASS<br>_CBASS_DEFAULT_ERR_EDC_CTRL_BUSECC | 0        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_CBASS_DEFAULT_ERR_AM62_WKUP_SAFE_CBASS<br>_CBASS_DEFAULT_ERR_EDC_CTRL_BUSECC | 1        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_CBASS_DEFAULT_ERR_AM62_WKUP_SAFE_CBASS<br>_CBASS_DEFAULT_ERR_EDC_CTRL_BUSECC | 2        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_CBASS_DEFAULT_ERR_AM62_WKUP_SAFE_CBASS<br>_CBASS_DEFAULT_ERR_EDC_CTRL_BUSECC | 3        | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_CBASS_DEFAULT_ERR_AM62_WKUP_SAFE_CBASS<br>_CBASS_DEFAULT_ERR_EDC_CTRL_BUSECC | 4        | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR<br>_EDC_CTRL_BUSECC                     | 0        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR<br>_EDC_CTRL_BUSECC                     | 1        | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR<br>_EDC_CTRL_BUSECC                     | 2        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR<br>_EDC_CTRL_BUSECC                     | 3        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR<br>_EDC_CTRL_BUSECC                     | 4        | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR<br>_EDC_CTRL_BUSECC                     | 5        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR<br>_EDC_CTRL_BUSECC                     | 6        | 4     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 7        | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 8        | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 9        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 10       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 11       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 12       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 13       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 14       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 15       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 16       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 17       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 18       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 19       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 20       | 12    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 21       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 22       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 23       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 24       | 7     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 25       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 26       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 27       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 28       | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 29       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 30       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 31       | 26    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 32       | 3     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                    | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 33       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 34       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 35       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 36       | 32    | EDC          |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 37       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 38       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 39       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 40       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SCR_AM62_WKUP_SAFE_CBASS_ERR_SCR_EDC_CTRL_BUSECC | 41       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 0        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 1        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 2        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 3        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 4        | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 5        | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 6        | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 7        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 8        | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 9        | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 10       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 11       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 12       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 13       | 5     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 14       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 15       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C            | 16       | 2     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                                                                                             | Group ID | Width | Checker Type |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C                                                                                                     | 17       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_ERR_SLV_P2P_BRIDGE_ERR_SLV_BRIDGE_BUSEC_C                                                                                                     | 18       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 0        | 32    | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 1        | 32    | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 2        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 3        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 4        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 5        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 6        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 7        | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 8        | 36    | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 9        | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 10       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 11       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 12       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 13       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 14       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 15       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU_P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 16       | 2     | Parity       |

**Table 4-226. EDC checkers information for ECC Aggregator Instance WKUP\_SAFE\_ECC\_AGGR0  
(continued)**

| Protected Interconnect                                                                                                                                                | Group ID | Width | Checker Type |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------------|
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 17       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 18       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 19       | 1     | Redundant    |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 20       | 4     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 21       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 22       | 10    | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 23       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 24       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 25       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 26       | 1     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 27       | 2     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 28       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 29       | 3     | Parity       |
| AM62_WKUP_SAFE_CBASS_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKU<br>P_SAFE_CBASS_DATA_L0_M2P_BRIDGE_EXPORT_AM62_WKUP_DM_CBASS_TO_AM62_WKUP_SAFE_CBASS_DATA_L0_BRIDGE_BUSECC | 30       | 4     | Parity       |
| SAM62_WKUP_SAFE_ECC_AGGR_EDC_CTRL                                                                                                                                     | 0        | 1     | Redundant    |
| SAM62_WKUP_SAFE_ECC_AGGR_EDC_CTRL                                                                                                                                     | 1        | 32    | EDC          |
| SAM62_WKUP_SAFE_ECC_AGGR_EDC_CTRL                                                                                                                                     | 2        | 1     | Parity       |
| SAM62_WKUP_SAFE_ECC_AGGR_EDC_CTRL                                                                                                                                     | 3        | 10    | Parity       |
| SAM62_WKUP_SAFE_ECC_AGGR_EDC_CTRL                                                                                                                                     | 4        | 4     | Parity       |
| SAM62_WKUP_SAFE_ECC_AGGR_EDC_CTRL                                                                                                                                     | 5        | 3     | Parity       |

**Table 4-227. Properties of ECC Aggregator Instance WKUP\_VTM0**

| RAM ID Name                                        | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL                      | 0      | EDC Interconnect | Inject with error capture | Yes             | 6                      |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 1      | EDC Interconnect | Inject with error capture | Yes             | 171                    |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 2      | EDC Interconnect | Inject with error capture | Yes             | 3                      |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 3      | EDC Interconnect | Inject with error capture | Yes             | 50                     |

**Table 4-228. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0**

| Protected Interconnect        | Group ID | Width | Checker Type |
|-------------------------------|----------|-------|--------------|
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 0        | 1     | Redundant    |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 1        | 32    | EDC          |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 2        | 1     | Parity       |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 3        | 10    | Parity       |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 4        | 4     | Parity       |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 5        | 3     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 0        | 1     | Redundant    |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 1        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 2        | 4     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 3        | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 4        | 4     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 5        | 32    | EDC          |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 6        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 7        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 8        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 9        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 10       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 11       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 12       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 13       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 14       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 15       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 16       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 17       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 18       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 19       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 20       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 21       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 22       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 23       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 24       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 25       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 26       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 27       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 28       | 8     | Parity       |

**Table 4-228. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 29       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 30       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 31       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 32       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 33       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 34       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 35       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 36       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 37       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 38       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 39       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 40       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 41       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 42       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 43       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 44       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 45       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 46       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 47       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 48       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 49       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 50       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 51       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 52       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 53       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 54       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 55       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 56       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 57       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 58       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 59       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 60       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 61       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 62       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 63       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 64       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 65       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 66       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 67       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 68       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 69       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 70       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 71       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 72       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 73       | 10    | Parity       |

**Table 4-228. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 74       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 75       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 76       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 77       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 78       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 79       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 80       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 81       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 82       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 83       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 84       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 85       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 86       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 87       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 88       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 89       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 90       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 91       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 92       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 93       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 94       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 95       | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 96       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 97       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 98       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 99       | 16    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 100      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 101      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 102      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 103      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 104      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 105      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 106      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 107      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 108      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 109      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 110      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 111      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 112      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 113      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 114      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 115      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 116      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 117      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 118      | 1     | Parity       |

**Table 4-228. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 119      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 120      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 121      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 122      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 123      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 124      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 125      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 126      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 127      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 128      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 129      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 130      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 131      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 132      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 133      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 134      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 135      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 136      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 137      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 138      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 139      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 140      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 141      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 142      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 143      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 144      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 145      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 146      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 147      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 148      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 149      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 150      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 151      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 152      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 153      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 154      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 155      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 156      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 157      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 158      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 159      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 160      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 161      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 162      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 163      | 1     | Parity       |

**Table 4-228. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect                             | Group ID | Width | Checker Type |
|----------------------------------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 164      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 165      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 166      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 167      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 168      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 169      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 170      | 8     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 0        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 1        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 2        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 0        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 1        | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 2        | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 3        | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 4        | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 5        | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 6        | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 7        | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 8        | 2     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 9        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 10       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 11       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 12       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 13       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 14       | 12    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 15       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 16       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 17       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 18       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 19       | 12    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 20       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 21       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 22       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 23       | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 24       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 25       | 12    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 26       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 27       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 28       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 29       | 7     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 30       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 31       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 32       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 33       | 26    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0      | 34       | 3     | Parity       |

**Table 4-228. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 35       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 36       | 26    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 38       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 39       | 26    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 40       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 41       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 42       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 43       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 44       | 32    | EDC          |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 46       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 47       | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 48       | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 49       | 1     | Parity       |

## 4.14 Graphics Processing Unit (GPU)

This section contains the integration details for the GPU module on this device. For further information, see the Graphics Processing Unit (GPU) section of the Peripherals chapter

### 4.14.1 GPU Unsupported Features

The following features are not supported on this family of devices:

- There are no unsupported features

### 4.14.2 Module Allocations

**Table 4-229. GPU Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| GPU0     |        |     | ✓    |

### 4.14.3 Resets, Interrupts, and Clocks

**Table 4-230. GPU Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------|
| GPU0            | PSC0_PSC_0             | PD_GPU       | LPSC_GPU      | 49    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-231. GPU Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| GPU0            | PSC0_PSC_0 | GPU0 reset  |

**Table 4-232. GPU Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description            | Type  |
|-----------------|-------------------------|-----------------------------|-------------|------------------------|-------|
| GPU0            | GPU0_gpu_os_irq_0       | GICSS0_spi_IN_118           | GICSS0      | GPU0 interrupt request | level |
| GPU0            | GPU0_gpu_os_irq_0       | GICSS0_spi_IN_119           | GICSS0      | GPU0 interrupt request | level |
| GPU0            | GPU0_gpu_os_irq_1       | GICSS0_spi_IN_118           | GICSS0      | GPU0 interrupt request | level |
| GPU0            | GPU0_gpu_os_irq_1       | GICSS0_spi_IN_119           | GICSS0      | GPU0 interrupt request | level |

**Table 4-233. GPU Clocks**

| Module Instance | Module Clock Input | Source Clock                | Source Control Register | Description |
|-----------------|--------------------|-----------------------------|-------------------------|-------------|
| GPU0            | GPU_CLK            | MAIN_PLL2_HSDIV4_CL<br>KOUT |                         |             |

## 4.15 Display Subsystem (DSS)

This section contains the integration details for the DSS module on this device. For further information, see the Display Subsystem (DSS) section of the Peripherals chapter

### 4.15.1 DSS\_UL Unsupported Features

The following features are not supported on this family of devices:

- Video output from Port 1 (dipi\_0 interface)
- Fragmented frame buffers
- OLDDITX does not support independent displays on each link. Links may be combined to support a single 2K display, or the second link can be used to mirror the first link.
- Video output > 1920x1080 @ 60Hz
- Write-back pipeline for memory-to-memory composition
- 2-D Tiled buffer access
- On-the-fly rotation
- Compressed data format

### 4.15.2 Module Allocations

**Table 4-234. DSS\_UL Modules Allocation within Device Domains**

| Instance | Domain |     |      |
|----------|--------|-----|------|
|          | WKUP   | MCU | Main |
| DSS0     |        |     | ✓    |

### 4.15.3 Resets, Interrupts, and Clocks

**Table 4-235. DSS\_UL Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain | Index | Default | Controllable | dependences  |
|-----------------|------------------------|--------------|---------------|-------|---------|--------------|--------------|
| DSS0            | PSC0_PSC_0             | PD_DSS       | LPSC_DSS      | 51    | OFF     | YES          | LPSC_MAIN_IP |

**Table 4-236. DSS\_UL Resets**

| Module Instance | Source     | Description |
|-----------------|------------|-------------|
| DSS0            | PSC0_PSC_0 | DSS0 reset  |

**Table 4-237. DSS\_UL Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input  | Destination       | Description            | Type  |
|-----------------|-------------------------|------------------------------|-------------------|------------------------|-------|
| DSS0            | DSS0_dispc_intr_req_0_0 | MCU_M4FSS0_COR_E0_nvic_IN_40 | MCU_M4FSS0_COR_E0 | DSS0 interrupt request | level |
| DSS0            | DSS0_dispc_intr_req_0_0 | GICSS0_spi_IN_116            | GICSS0            | DSS0 interrupt request | level |
| DSS0            | DSS0_dispc_intr_req_0_0 | R5FSS0_CORE0_intr_IN_24      | R5FSS0_CORE0      | DSS0 interrupt request | level |
| DSS0            | DSS0_dispc_intr_req_1_0 | MCU_M4FSS0_COR_E0_nvic_IN_41 | MCU_M4FSS0_COR_E0 | DSS0 interrupt request | level |
| DSS0            | DSS0_dispc_intr_req_1_0 | GICSS0_spi_IN_117            | GICSS0            | DSS0 interrupt request | level |
| DSS0            | DSS0_dispc_intr_req_1_0 | R5FSS0_CORE0_intr_IN_25      | R5FSS0_CORE0      | DSS0 interrupt request | level |

Table 4-238. DSS\_UL Clocks

| Module Instance | Module Clock Input | Source Clock                   | Source Control Register     | Description |
|-----------------|--------------------|--------------------------------|-----------------------------|-------------|
| DSS0            | DPI_0_IN_CLK       | MAIN_PLL16_HSDIV0_C<br>LKOUT   |                             |             |
|                 |                    | MAIN_PLL16_HSDIV0_C<br>LKOUT/7 |                             |             |
|                 | DPI_1_IN_CLK       | MAIN_PLL17_HSDIV0_C<br>LKOUT   | DSS_DISPC0_CLKSEL1[<br>0:0] |             |
|                 |                    | VOUT_EXTPCLKIN                 | DSS_DISPC0_CLKSEL1[<br>0:0] |             |
|                 | DSS_FUNC_CLK       | MAIN_SYSCLK0/2                 |                             |             |

#### 4.15.4 OLDI\_TX Integration Features

Single Link Mode - 1920x1440@60fps with a 200MHz pixel clock

- 1x OLDI\_TX - Duplicate Display

Dual Link Mode - 3840x1080@60fps with a 300MHz pixel clock

- 1x OLDI\_TX - Single, higher resolution image using both OLDI\_TX together

## 4.16 Spinlock

This section contains the integration details for the Spinlock module on this device. For further information, see the Spinlock section of the Peripherals chapter

### 4.16.1 SPINLOCK Unsupported Features

The following features are not supported on this family of devices:

- ARM Architectural Spinlock Instructions (LDREX, STREX)
- Any use model other than binary mutex (ex. counting semaphore, lockless programming) - Spinlock MMR is a single binary 0,1 implemented by a state machine
- 64 bit accesses - Spinlock MMRs are aligned on 32-bit boundaries meaning a 64 bit access affects the state of 2 spinlocks

### 4.16.2 Module Allocations

**Table 4-239. Spinlock Modules Allocation within Device Domains**

| Instance  | Domain |     |      |
|-----------|--------|-----|------|
|           | WKUP   | MCU | Main |
| SPINLOCK0 |        |     | ✓    |

### 4.16.3 Resets, Interrupts, and Clocks

**Table 4-240. Spinlock Integration Attributes**

| Module Instance | Power Sleep Controller | Power Domain | Module Domain   | Index | Default | Controllable | dependences        |
|-----------------|------------------------|--------------|-----------------|-------|---------|--------------|--------------------|
| SPINLOCK0       | PSC0_PSC_0             | GP_CORE_CTL  | LPSC_SMS_COMMON | 27    | ON      | YES          | LPSC_MAIN_ALWAYSON |

**Table 4-241. Spinlock Resets**

| Module Instance | Source | Description     |
|-----------------|--------|-----------------|
| SPINLOCK0       | PSC0   | SPINLOCK0 reset |

**Table 4-242. Spinlock Hardware Requests**

| Module Instance | Module Interrupt Signal | Destination Interrupt Input | Destination | Description | Type |
|-----------------|-------------------------|-----------------------------|-------------|-------------|------|
| SPINLOCK0       |                         |                             |             |             | NONE |

**Table 4-243. Spinlock Clocks**

| Module Instance | Module Clock Input | Source Clock              | Source Control Register | Description |
|-----------------|--------------------|---------------------------|-------------------------|-------------|
| SPINLOCK0       | VBUS_FCLK          | MAIN_PLL15_HSDIV0CLKOUT/2 |                         |             |

## Chapter 5 **Initialization**

---



This chapter describes the steps for non-secure device initialization.

|                                          |     |
|------------------------------------------|-----|
| <b>5.1 Initialization Overview</b> ..... | 471 |
| <b>5.2 Boot Process</b> .....            | 474 |
| <b>5.3 Boot Mode Pins</b> .....          | 479 |
| <b>5.4 Boot Modes</b> .....              | 481 |
| <b>5.5 PLL Configuration</b> .....       | 507 |
| <b>5.6 Boot Parameter Tables</b> .....   | 509 |
| <b>5.7 Boot Image Format</b> .....       | 519 |
| <b>5.8 Boot Memory Maps</b> .....        | 526 |

## 5.1 Initialization Overview

Figure 5-1 is an overview of the initialization process and its steps:

- **Preinitialization:** Power, clock, and control connections must be present, and the boot configuration pins must be held at the desired logical levels.
- **Power, clock, reset ramp sequence:** Specific sequence that is applied by the power-management chip(s)
- **ROM code:** Responsible for finding, for downloading, and for executing the initial software (SBL)
- **Initial software:** Software that loads, prepares, and passes control to application software or to the high-level operating system (HLOS)
- **High-Level Operating System** or bare-metal application which runs on main processor(s)



init-003

**Figure 5-1. Initialization Process**

The first two steps in the initialization process are hardware-oriented; however, they require an understanding of the process of configuring these system interface pins (balls on the device), which have software-configurable functionality. This configuration is an essential part of the chip configuration and is application-dependent. This chapter discusses these system-interface pins, the associated configuration registers, and memory structures that are vital to the correct initialization of the device.

### 5.1.1 ROM Code Overview

ROM bootloader (or ROM Code) is a software that resides in a on-chip read-only memory (ROM) to assist the customer in transferring and executing their application code. The device has two ROM codes operating in tandem – the Public ROM code, and the M4 ROM code.

In order to accommodate various system scenarios, the ROM Code supports several boot modes. These boot modes can be broadly classified as:

- Host boot modes
- Memory boot modes.

During a host boot, the device is configured to receive code from a host via the selected interface. Either the host writes the application code directly into internal memory or the ROM Code receives the application code on the selected interface and stores it in internal memory.

During a memory boot, the device transfers code from non-volatile memory to internal memory for execution.

In all boot modes, the entire boot operation can be partitioned into two sections:

1. Hardware initialization phase
2. Boot process.

During initialization, the ROM Code configures the device resources (PLLs, peripherals, pins) as needed to support the boot process. The resources used depend on the boot mode requirements.

During the boot process the boot image can be loaded into device memory and executed, or executed in place, depending on the boot peripheral. M4 will perform code verification and allow, or forbid, the image execution.

Main configuration source for boot after power-up are the BOOTMODE pins sampled automatically after reset release and stored in device status registers. At ROM Code startup, these pin values are read from the registers to create the boot peripheral list and the boot configuration tables used later to initialize and startup the PLLs and boot peripherals.

### 5.1.2 Bootloader Modes

Table 5-1 shows the boot modes supported by ROM code.

Table 5-1. ROM Code Boot Modes

| Boot Mode        | Boot Media/Host             | SoC Peripheral               | Can be a Backup Mode? <sup>(1)</sup> | Notes                                                                                       |
|------------------|-----------------------------|------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------|
| No-boot/Dev-boot | No media or host            | None                         | N                                    | No boot or development boot – debug modes                                                   |
| OSPI             | OSPI flash                  | FSS0_OSPI0                   | N                                    | On OSPI port                                                                                |
| QSPI             | QSPI flash                  | FSS0_OSPI0                   | N                                    | On OSPI port                                                                                |
| SPI              | SPI flash                   | FSS0_OSPI0                   | Y                                    | On OSPI port                                                                                |
| Ethernet         | External host               | CPSW0                        | Y                                    | In BOOTP mode. RGMII or RMII PHY                                                            |
| I2C              | I <sup>2</sup> C EEPROM     | I2C0                         | Y                                    | I2C target boot is not supported                                                            |
| UART             | External host               | UART0                        | Y                                    | XMODEM protocol                                                                             |
| MMCSD            | eMMC flash or SD card       | MMCS0 (8bit) or MMCS1 (4bit) | Y                                    | Boot from User Data Area (UDA) in raw or file system mode                                   |
| eMMC             | eMMC flash                  | MMCS0 (8bit)                 | N                                    | Boot from boot partition                                                                    |
| USB - target     | USB boot from external host | USB0                         | Y                                    | USB device mode boot using DFU (device firmware upgrade), Boot is running on USB2.0 speeds. |
| USB - host       | USB mass storage            | USB0                         | Y                                    | USB2.0 host mode, boot from FAT32 filesystem                                                |
| Serial Flash     | Serial Flash                | FSS0_OSPI0                   | N                                    | On OSPI port                                                                                |
| xSPI             | xSPI flash                  | FSS0_OSPI0                   | N                                    | On OSPI port                                                                                |
| GPMC             | NOR flash, NAND flash       | GPMC0                        | N                                    | CSn0 connected, 8 bit NAND flash only, 16-bit non-mux NOR flash only                        |

(1) The peripheral can be selected also as a backup boot mode. A backup mode is tried if primary boot mode fails.

### Note

Because different devices support different sets of peripherals, see the *device-specific Datasheet* to obtain the list of peripherals supported in your device.

#### 5.1.3 Terminology

- **Boot Mode Pins:** Boot mode pins provide vital information to ROM code for boot. These pins must be properly set up before power ramp.
- **Bootstrap:** Initial software launched by the ROM code during the memory booting phase.
- **Boot Header:** Optional structure that precedes the initial software and allows the redefinition of the ROM code default settings.
- **Downloaded software:** Initial software downloaded into on-chip RAM by the ROM code during the peripheral booting phase.
- **eFuse:** A one-time programmable memory location usually set at the factory.
- **Flash loader:** Downloaded software launched by the ROM code during the preflashing stage. It also programs an image in external memories.
- **GP device:** General-purpose device (SoC) or a non-secure device.
- **Initial software:** Software executed by any of the ROM code mechanisms (memory booting or peripheral booting). Initial software is a generic term for bootstrap and downloaded software. This can be the SBL (secondary bootloader) responsible for loading an OS.
- **Memory booting:** ROM code mechanism that consists of executing initial software from external memory.
- **Controller CPU:** The Arm® Cortex® CPU for which CPU-ID is 0. It configures the multicore platform and starts the ROM code to ensure device booting from a mass storage memory (memory booting) or a peripheral interface (peripheral booting).
- **Peripheral booting:** ROM code mechanism that consists of polling selected interfaces, downloading, and executing initial software (in this case, downloaded software) in the internal RAM.

- **Preflashing:** A specific case of peripheral booting where the ROM code mechanism is used to program the external flash memory.
- **ROM Code:** or ROM bootloader (RBL), the on-chip software in device ROM that executes first and implements booting.
- **ROM Code-controlled Boot Phase:** This phase covers the sequence operations from the time the platform releases the reset to the time first user- or customer-owned software starts execution. This phase is fully controlled by the device ROM code.
- **Booting Parameter Table:** A logical structure stored in the on-chip RAM memory and contains information for the boot, such as the boot file name or an address to boot from.

## 5.2 Boot Process

### 5.2.1 Public ROM Code Architecture

The Public ROM code has the following components (see also [Public ROM Code Architecture](#) ):

- Main
- Buffer manager
- X.509
- Log and Trace
- System
- Protocol
- Driver



Figure 5-2. Public ROM Code Architecture

#### 5.2.1.1 Main Module

The Main module contains the top level execution loop. This loop repeats until a boot image has been received or directed to sleep by the M4. The main loop has three different execution sub-paths based on the boot peripheral.

- **Image Path** This path is used by the OSPI, QSPI, SPI, and xSPI boot modes. In these cases the image data can be directly read by both the R5 and the M4 in place.
- **Block Path** This path is used by the I2C, USB-DFU, UART, eMMC, Ethernet, eMMC/SD cards in raw mode. In this mode data is received from the peripheral in blocks. Blocks are accumulated in the boot buffer until a full X.509 certificate header has been received, at which point this full certificate and any subsequent blocks are passed to the M4 as they arrive.
- **Filesystem Path** This path is used by the USB host (MSC) mode and eMMC/SD cards in filesystem mode. This mode executes exactly like in the block path, except that the boot image location is defined by a filesystem.

The main level is able to detect if a received boot image is in the correct format and reject non-conforming images. In some cases, detection of an invalid image is done after the initial data buffer has been sent to the M4. In that case the R5 must inform the M4 that the image was in fact invalid and it will be looking for the next image and try again.

### 5.2.1.2 X509 Module

The X509 module parses the boot header. The boot header is an X.509 certificate as defined in [RFC5280](#). Extensions specific to boot are described in [Section 5.7.2, X.509 Certificate](#).

This module also includes an OID decoder as well as defines OID values as C #define constants for any values that can be used during boot.

### 5.2.1.3 Buffer Manager Module

The buffer manager module is used to allocate buffers to hold boot data. The R5 code allocates a buffer when it is ready to read a block of data from the boot peripheral. Once the data is read the buffer ownership is passed to the M4. When the M4 has completed processing the data in the buffer ownership is returned to the R5, which then frees the buffer.

### 5.2.1.4 Log and Trace Module

The Log and Trace modules are not integral to the boot process. Instead, they provide ability to record operation of the ROM code and track unexpected occurrences.

Log and trace function is currently TI internal.

### 5.2.1.5 System Module

The system module provides services to other modules. These services are not directly related to boot drivers. The system module is the only module that operates in the supervisor mode of the R5 (a few services will run in user). The system module supports the following functions:

- Interrupt enable, disable, and service
- IPC
- Power
- Pinmux
- Clock
- Task switch

The main level is able to detect if a received boot image is in the correct format and reject non-conforming images.

### 5.2.1.6 Protocol Module

The protocol modules provide implementation of high-level data transfer protocols. The BOOTP/TFTP and XMODEM protocols reside in this layer. These modules provide services as defined in well-known standards.

### 5.2.1.7 Driver Module

The driver module implements the low level peripheral drivers.

## 5.2.2 M4 ROM Description

In a general-purpose (GP) device, M4 ROM performs the following functions:

- Device management
- Configures the boot vectors (in BOOT\_CFG) and controls reset release of R5 core. That is, M4 is the boot controller of R5 core.
- IPC configuration via Main DMSS rings and Secure Proxy
- PLL configuration (R5 and SA2UL)
- X509 certificate parsing
- SA2UL configuration to SHA512 for image integrity checks
- M4 firmware loading

### 5.2.3 Boot Process Flow

The R5 boot process flow is shown in [Figure 5-3](#).



init-001

Figure 5-3. Boot Process

The values of BOOTMODE[15:0] pins are latched into the Device Status register `CTRLMMR_MAIN_DEVSTAT[15:0]` by hardware as the device comes out of global cold reset, sampled after `MCU_PORz` deassertion. For more information how to set BOOTMODE pins, see [Section 5.3, Boot Mode Pins](#).

The M4 is the boot controller for the Public ROM. M4 performs the necessary configurations and releases R5's reset for CPU0.

The R5 checks the boot mode pins and then configures the appropriate peripheral interface to get access to a boot image. A cursory check of the image is made, and the image is passed to M4. M4 ROM then will perform code verification and route the boot image to the on-chip RAM. Once the image has been received, R5 enters a clean state and idles. M4 ROM code will assert reset to the R5, redirect the boot vector to the newly loaded image, and release the reset. This restarts the R5 with the Public ROM code fully disconnected.

The Public ROM code executes after a cold or warm reset.

---

**Note**

M4 ROM sets up a 3-minute watchdog timer (RTI0) timeout. During this time, the R5 boot needs to get completed, otherwise a WDT reset will occur. Once the R5 image is loaded (SBL/SPL), M4 ROM will restart the watchdog timer for additional 3 minutes upon entering the R5 SBL. The customer-provided R5 image needs to load and install the TI-provided SYSFW image into the M4, which will manage the watchdog timer during run time.

---

**Note**

The following system conditions must be met at POR to perform device boot:

- USB cable plug must be inserted
- Ethernet PHY is powered up and out of reset
- The SD card cage must be powered before entering the SD card boot mode. A SD/MMC card with pre-loaded image must be inserted
- Memory devices must be up and ready (power ramped up and reset completed) at device startup:
  - eMMC
  - xSPI/OSPI/QSPI/SPI and Serial flash
  - I2C EEPROM
  - NOR/NAND flash

Failing to meet these requirements may result in boot fail and performing a backup boot (if available for that mode).

---

Figure 5-4 describes the external bootloader (SBL) typical tasks.



**Figure 5-4. External Bootloader Tasks**

Upon R5 reset and SBL execution start, M4 ROM restarts the RTI watchdog timer for additional 180 seconds of timeout. During that time, SBL must load the M4 firmware provided by TI otherwise an R5 reset will occur as a preventive measure against software misbehavior.

One of the SBL's main tasks is to load the M4 firmware. Only after this task is performed, SBL can load the other processors' image and request a reset release from M4 firmware for those cores.

## 5.3 Boot Mode Pins

Boot Mode pins provide means to select the boot mode and options before the device is powered up. After every POR, they are the main source to populate the Boot Parameter Tables. See [Section 5.6, Boot Parameter Tables](#) for table list and description.

Boot mode pins can be divided into the following categories:

- **BOOTMODE[02:00]** – Denote system clock frequency (MCU\_OSC0\_XI/XO) to ROM code for PLL configuration.
- **BOOTMODE[06:03]** – Select the requested boot (primary) mode after POR, that is, the peripheral/memory to boot from.
- **BOOTMODE[09:07]** – These pins provide optional configurations for primary boot and are used in conjunction with the boot mode selected.
- **BOOTMODE[12:10]** – Select the backup boot mode, that is, the peripheral/memory to boot from, if primary boot device failed.
- **BOOTMODE[13]** – This pin provides optional configurations for the backup boot devices.
- **BOOTMODE[15:14]** – Reserved pins.

---

### Note

It is user's responsibility to set the boot mode pins (via pullups or pulldowns, and jumpers/switches) depending on the desired boot scenario.

---

### 5.3.1 BOOTMODE Pin Mapping

The ROM execution is directed through the main boot mode pins. This provides more flexibility and more booting peripherals to boot from. The Main domain must be powered and functional.

Main boot mode pins are shown in [Table 5-2](#).

Any Bootmode pins marked as Reserved or not used must be tied high or low with pull resistors. They should not be left floating.

**Table 5-2. BOOTMODE Pin Mapping**

| 15       | 14       | 13                      | 12               | 11 | 10 | 9 | 8                        | 7 | 6 | 5                 | 4 | 3 | 2 | 1          | 0 |
|----------|----------|-------------------------|------------------|----|----|---|--------------------------|---|---|-------------------|---|---|---|------------|---|
| Reserved | Reserved | Backup Boot Mode Config | Backup Boot Mode |    |    |   | Primary Boot Mode Config |   |   | Primary Boot Mode |   |   |   | PLL Config |   |

[Table 5-3](#) describes the BOOTMODE pins that need to be set according to the system clock provided to the device.

The ROM Code will configure any PLLs required during the boot process.

**Note**

Reference clock selections may be limited by the device. Please consult the device specific datasheet to determine which system clock frequencies are valid.

**Table 5-3. PLL Reference Clock Selection**

| PLL Config Pins |    |    | Ref Clock (MHz)   |
|-----------------|----|----|-------------------|
| B2              | B1 | B0 |                   |
| 0               | 0  | 0  | 19.2              |
| 0               | 0  | 1  | 20                |
| 0               | 1  | 0  | 24                |
| 0               | 1  | 1  | 25                |
| 1               | 0  | 0  | 26                |
| 1               | 0  | 1  | 27 <sup>(1)</sup> |
| 1               | 1  | 0  | Reserved          |
| 1               | 1  | 1  | Reserved          |

(1) USB DFU boot mode is not supported with the reference clock of 27 MHz.

#### 5.3.1.1 Primary Boot Mode Selection and Configuration

The primary boot mode is the first mode attempted after reset. [Table 5-4](#) lists all possible primary boot modes. All pins marked as reserved can be either 0 or 1. All boot mode signals must be pulled low or high through a pull resistor on the board, they must not be left floating

**Note**

All BOOTMODE[15:00] signals must be pulled high through a resistor to VDDSHV3, or pulled low to ground, including Reserved signals. Reserved BOOTMODE signals must not be left floating.

**Table 5-4. Primary Boot Mode Selection**

| Primary Boot Mode Config |             |             |    |    |    |    | Primary Boot Mode |
|--------------------------|-------------|-------------|----|----|----|----|-------------------|
| B9                       | B8          | B7          | B6 | B5 | B4 | B3 |                   |
| Reserved                 | Read Mode 2 | Read Mode 1 | 0  | 0  | 0  | 0  | Serial NAND       |
| Reserved                 | Iclk        | Csel        | 0  | 0  | 0  | 1  | OSPI              |
| Reserved                 | Iclk        | Csel        | 0  | 0  | 1  | 0  | QSPI              |

**Table 5-4. Primary Boot Mode Selection (continued)**

| Primary Boot Mode Config |           |           |    |    |    |    | Primary Boot Mode                                                                 |
|--------------------------|-----------|-----------|----|----|----|----|-----------------------------------------------------------------------------------|
| B9                       | B8        | B7        | B6 | B5 | B4 | B3 |                                                                                   |
| Reserved                 | Mode      | Csel      | 0  | 0  | 1  | 1  | SPI                                                                               |
| Clkout                   | 0         | Link Info | 0  | 1  | 0  | 0  | Ethernet RGMII                                                                    |
| Clkout                   | Clk src   | 0         | 0  | 1  | 0  | 1  | Ethernet RMII                                                                     |
| Bus reset                | Reserved  | Addr      | 0  | 1  | 1  | 0  | I2C                                                                               |
| Reserved                 | Reserved  | Reserved  | 0  | 1  | 1  | 1  | UART                                                                              |
| Port                     | Reserved  | Fs/raw    | 1  | 0  | 0  | 0  | MMCSd Boot ( <a href="#">SD Card Boot</a> or <a href="#">eMMC Boot</a> using UDA) |
| Reserved                 | Reserved  | Reserved  | 1  | 0  | 0  | 1  | eMMC Boot                                                                         |
| Core Volt                | Mode      | Lane Swap | 1  | 0  | 1  | 0  | USB                                                                               |
| Reserved                 | Reserved  | Reserved  | 1  | 0  | 1  | 1  | GPMC NAND                                                                         |
| Reserved                 | Reserved  | Reserved  | 1  | 1  | 0  | 0  | GPMC NOR                                                                          |
| Reserved                 | Reserved  | Reserved  | 1  | 1  | 0  | 1  | Reserved                                                                          |
| SFPD                     | Read Cmd  | Mode      | 1  | 1  | 1  | 0  | xSPI                                                                              |
| Reserved                 | ARM/Thumb | No/Dev    | 1  | 1  | 1  | 1  | No-boot/Dev boot                                                                  |

### 5.3.1.2 Backup Boot Mode Selection and Configuration

The backup boot mode is selected via pins within the main BOOTMODE map. [Table 5-5](#) lists all possible backup boot modes.

**Table 5-5. Backup Mode Selection**

| Backup Boot Config |     | Backup Boot Mode Selection |     |                                                                          | Backup Boot Mode Selected |
|--------------------|-----|----------------------------|-----|--------------------------------------------------------------------------|---------------------------|
| B13                | B12 | B11                        | B10 |                                                                          |                           |
| Reserved           | 0   | 0                          | 0   |                                                                          | None                      |
| Mode               | 0   | 0                          | 1   |                                                                          | USB                       |
| Reserved           | 0   | 1                          | 0   |                                                                          | Reserved                  |
| Reserved           | 0   | 1                          | 1   |                                                                          | UART                      |
| IF                 | 1   | 0                          | 0   |                                                                          | Ethernet                  |
| Port               | 1   | 0                          | 1   | MMCSd Boot ( <a href="#">SD Card Boot</a> or <a href="#">eMMC Boot</a> ) |                           |
| Reserved           | 1   | 1                          | 0   |                                                                          | SPI                       |
| Reserved           | 1   | 1                          | 1   |                                                                          | I2C                       |

## 5.4 Boot Modes

#### 5.4.1 OSPI\xSPI\QSPI\SPI Boot

The following apply to all or multiple boot modes that are SPI related.

- Octal SPI flash memories support various protocols, however, the OSPI boot mode of the device will only support a specific protocol defined in OSPI Bootloader Operation. If the flash memory is complaint with JEDEC xSPI standards JESD251 and JESD216D, then xSPI boot mode is additionally supported. Please refer to xSPI boot mode description for further details.
- Command protocols follow the JEDEC spec definition and indicate the number of active pins used for the instruction, address, and data, and also the data rate used for each (S = Single Data Rate, D= Double Data Rate). For example, 1S-1S-8S describes a protocol which uses 1 signal (D0) for command in SDR mode, 1 signal (D0) for address in SDR mode, and 8 signals (D7:D0) for data in SDR mode
- When using a OSPI\xSPI\QSPI\SPI flash device greater than 128Mb, a flash device package with a RESET signal (NOR type memories only) must be used. The reason is that the ROM only uses 3 byte addressing mode (address is 24bits). To address the full memory address range, software will typically switch to 4-byte addressing mode. If a reset to the processor occurs (eg, due to a warm reset), the ROM will execute expecting 3-byte addressing mode, but the flash will have been left in 4-byte addressing mode. In order for the flash device to return to 3-byte addressing mode, it must be reset using this signal. This typically can be achieved by using the RESET signal on the flash memory device. The ROM does not issue a software reset command.
- When booting from any of the SPI boot modes, BOOTMODE pin settings will depend on operation during normal operation
  - To support high speed OSPI with the DQS signal during normal operation, set BOOTMODE8=1 to use internal iclk during boot and ensure signal LBCLKO is a no connect (ie, absolutely no trace can be connected to LBCLKO). The ROM boot will operate OSPI at low speed (50MHz), and during normal operation, the OSPI interface can use the DQS signal to operate the interface at high speeds.
  - To support high speed OSPI or QSPI without DQS signal (ie, using the LBCLKO signal to support loopback clock), then set BOOTMODE8=0 to use external clock during boot. In this case, ROM boot and normal operation will use the externally looped back clock signal LBCLKO. Board designers should refer to the device specific datasheet to understand board routing guidelines for the LBCLKO signal.
  - To support only low speed OSPI\xSPI\QSPI\SPI operation (ie, <=50MHz OSPI clock), set BOOTMODE8=1 to use internal iclk, and ensure signal LBCLKO is a no connect (ie, absolutely no trace can be connected to LBCLKO). Operation for both ROM boot and normal operating mode will clock the interface at low speed and use the internally pad looped back clock. The DQS and LBCLKO signals will not be used during boot or normal operation

#### 5.4.1.1 OSPI Boot

Table 5-6 shows configuration pins assignment to functions when boot mode is the Octal SPI using the OSPI module. The BOOTMODE pin corresponding to the Iclk field determines the setting for LOOPCLK\_SEL bit field in CTRLMMR\_OSPi0\_CLKSEL register

**Table 5-6. OSPI Boot Configuration Fields**

| BOOTMODE Pins | Field | Value | Description                           |
|---------------|-------|-------|---------------------------------------|
| 8             | Iclk  | 0     | Iclock source external                |
|               |       | 1     | Iclock source internal (pad loopback) |
| 7             | Csel  | 0     | Boot Flash is on CS 0                 |
|               |       | 1     | Boot Flash is on CS 1                 |

Table 5-7 summarizes the OSPI pin configuration done by ROM code for OSPI boot device.

**Table 5-7. OSPI Boot Pin Usage**

| Device Pin   | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|--------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| OSPI0_CLK    | OSPI0_CLK     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG0                 |
| OSPI0_LBCLKO | OSPI0_LBCLKO  | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG1                 |
| OSPI0_DQS    | OSPI0_DQS     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG2                 |
| OSPI0_D0     | OSPI0_D0      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG3                 |
| OSPI0_D1     | OSPI0_D1      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG4                 |
| OSPI0_D2     | OSPI0_D2      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG5                 |
| OSPI0_D3     | OSPI0_D3      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG6                 |
| OSPI0_D4     | OSPI0_D4      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG7                 |
| OSPI0_D5     | OSPI0_D5      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG8                 |
| OSPI0_D6     | OSPI0_D6      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG9                 |
| OSPI0_D7     | OSPI0_D7      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG10                |
| OSPI0_CSn0   | OSPI0_CSn0    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG11                |
| OSPI0_CSn1   | OSPI0_CSn1    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG12                |

#### Note

All signals in the table will be configured even though some may not be used by this particular boot mode.

#### 5.4.1.1.1 OSPI Bootloader Operation

Please refer to [Section 5.4.1](#) for more information that applies to OSPI boot mode

The OSPI boot mode supports 1S-1S-8S mode only. The ROM will issue a Read Command (0x8B) followed by a 24 bit (3 byte) address (the starting address is all zeros), followed by 8 dummy cycles. The flash device should then respond with 8-bit data. The frequency of operation during the read portion is 50 MHz.

#### 5.4.1.1.1 OSPI Initialization Process

In the OSPI boot mode, the ROM Code initializes the OSPI module and the image is read from the OSPI flash connected to the selected chip-select. If the image fails to be read correctly from offset 0x0 of the flash memory, the ROM will attempt to obtain the image at offset 0x400000. This is the only redundant image location supported by the ROM. See [Section 5.4.1.1, OSPI Boot Device Configuration](#) for OSPI port settings.

A detailed summary of the OSPI boot parameter table and the boot configuration definitions are listed in [Section 5.6.3, OSPI Boot Parameter Table](#).

#### **5.4.1.1.2 OSPI Loading Process**

OSPI boot mode is not eXecute-In-Place (XIP). ROM code first copies boot image into on-chip RAM and then executes it.

#### 5.4.1.2 xSPI Boot

Table 5-8 shows configuration pins assignment to functions when boot mode is xSPI using the OSPI module.

**Table 5-8. xSPI Boot Configuration Fields**

| BOOTMODE Pins | Field    | Value | Description           |
|---------------|----------|-------|-----------------------|
| 9             | SFDP     | 0     | SFDP disabled         |
|               |          | 1     | SFDP enabled          |
| 8             | Read cmd | 0     | 0x0B Read Command     |
|               |          | 1     | 0xEE Read Command     |
| 7             | Mode     | 0     | 1S-1S-1S mode @ 50MHz |
|               |          | 1     | 8D-8D-8D mode @ 25MHz |

Table 5-9 summarizes the OSPI pin configuration done by ROM code for xSPI boot device on port 0.

**Table 5-9. xSPI Boot Pin Usage**

| Device Pin   | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|--------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| OSPI0_CLK    | OSPI0_CLK     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG0                 |
| OSPI0_LBCLK0 | OSPI0_LBCLK0  | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG1                 |
| OSPI0_DQS    | OSPI0_DQS     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG2                 |
| OSPI0_D0     | OSPI0_D0      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG3                 |
| OSPI0_D1     | OSPI0_D1      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG4                 |
| OSPI0_D2     | OSPI0_D2      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG5                 |
| OSPI0_D3     | OSPI0_D3      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG6                 |
| OSPI0_D4     | OSPI0_D4      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG7                 |
| OSPI0_D5     | OSPI0_D5      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG8                 |
| OSPI0_D6     | OSPI0_D6      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG9                 |
| OSPI0_D7     | OSPI0_D7      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG10                |
| OSPI0_CSn0   | OSPI0_CSn0    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG11                |
| OSPI0_CSn1   | OSPI0_CSn1    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG12                |

#### Note

All signals in the table will be configured even though some may not be used by this particular boot mode.

#### 5.4.1.2.1 xSPI Bootloader Operation

Please refer to [Section 5.4.1](#) for more information that applies to xSPI boot mode

The xSPI protocol defines 1S-1S-1S mode for general backwards compatibility, and 8D-8D-8D for maximum throughput.

For 1S-1S-1S mode of operation, the ROM will issue a Fast Read Output command (0x0B) followed by a 24 bit (3 byte) address (the starting address is all zeros), followed by 8 dummy cycles. The frequency of operation is 50 MHz.

For 8D-8D-8D mode of operation, the ROM will issue a Fast Read command (0x0B or 0xEE, depending on BOOTMODE signal), followed by a 32 bit (4 byte) address (the starting address is all zeros). The frequency of operation is 25 MHz.

When SFDP is enabled using a BOOTMODE signal, the ROM starts operation in 1S-1S-1S mode reads SFDP header from flash memory to get 8D-8D-8D switching sequence, Read Command, CMD Extension and Byte Order. SFDP parsing of ROM is described below and on successful parsing ROM will issue 8D-8D-8D command

switching sequence and then will read the boot image in 8D-8D-8D mode with read command specified in SFDP header

### 5.4.1.3 QSPI Boot

Table 5-10 shows configuration pins assignment to functions when boot mode is QSPI using the OSPI module. The BOOTMODE pin corresponding to the Iclk field determines the setting for LOOPCLK\_SEL bit field in CTRLMMR\_OSPIO\_CLKSEL register

**Table 5-10. QSPI Boot Configuration Fields**

| BOOTMODE Pins | Field | Value | Description                           |
|---------------|-------|-------|---------------------------------------|
| 8             | Iclk  | 0     | Iclock source external                |
|               |       | 1     | Iclock source internal (pad loopback) |
| 7             | Csel  | 0     | Boot Flash is on CS 0                 |
|               |       | 1     | Boot Flash is on CS 1                 |

Table 5-11 summarizes the OSPI pin configuration done by ROM code for QSPI boot device on port 0.

**Table 5-11. QSPI Boot Pin Usage**

| Device Pin   | Module Signal | Pull Enable | Pull Direction | Driver Strength Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|--------------|---------------|-------------|----------------|-----------------------|-----------|------------|----------------------------|
| OSPI0_CLK    | OSPI0_CLK     | Disable     | NA             | 0                     | Disable   | 0          | PADCONFIG0                 |
| OSPI0_LBCLKO | OSPI0_LBCLKO  | Disable     | NA             | 0                     | Enable    | 0          | PADCONFIG1                 |
| OSPI0_DQS    | OSPI0_DQS     | Disable     | NA             | 0                     | Enable    | 0          | PADCONFIG2                 |
| OSPI0_D0     | OSPI0_D0      | Disable     | NA             | 0                     | Enable    | 0          | PADCONFIG3                 |
| OSPI0_D1     | OSPI0_D1      | Disable     | NA             | 0                     | Enable    | 0          | PADCONFIG4                 |
| OSPI0_D2     | OSPI0_D2      | Disable     | NA             | 0                     | Enable    | 0          | PADCONFIG5                 |
| OSPI0_D3     | OSPI0_D3      | Disable     | NA             | 0                     | Enable    | 0          | PADCONFIG6                 |
| OSPI0_CSn0   | OSPI0_CSn0    | Disable     | NA             | 0                     | Disable   | 0          | PADCONFIG11                |
| OSPI0_CSn1   | OSPI0_CSn1    | Disable     | NA             | 0                     | Disable   | 0          | PADCONFIG12                |

#### Note

All signals in the table will be configured even though some may not be used by this particular boot mode.

### 5.4.1.3.1 QSPI Bootloader Operation

Please refer to [Section 5.4.1](#) for more information that applies to QSPI boot mode

The QSPI boot mode supports the 1S-1S-4S mode only. The ROM will issue a Fast Read Quad Output command (0x6B) followed by a 24 bit (3 byte) address (the starting address is all zeros), followed by 8 dummy cycles. The flash device should then respond with 4-bit data. The frequency of operation during the quad read portion is 50 MHz.

#### 5.4.1.3.1.1 QSPI Initialization Process

In the QSPI boot mode, the ROM Code initializes the OSPI module and the image is read from the QSPI flash connected to the selected chip-select. If the image fails to be read correctly from offset 0x0 of the flash memory, the ROM will attempt to obtain the image at offset 0x400000. This is the only redundant image location supported by the ROM. See [Section 5.4.1.3, QSPI Boot Device Configuration](#) for OSPI port settings.

A detailed summary of the QSPI boot parameter table and the boot configuration definitions are listed in [Section 5.6.3, QSPI Boot Parameter Table](#).

#### 5.4.1.3.1.2 QSPI Loading Process

QSPI boot mode is not eXecute-In-Place (XIP). ROM code first copies boot image into on-chip RAM and then executes it.

#### 5.4.1.4 SPI Boot

Table 5-12 shows configuration pins assignment to functions when boot mode is SPI using the OSPI module.

**Table 5-12. SPI Boot Configuration Fields**

| BOOTMODE Pins | Field | Value | Description           |
|---------------|-------|-------|-----------------------|
| 8             | Mode  | 0     | SPI Mode 0            |
|               |       | 1     | SPI Mode 3            |
| 7             | Csel  | 0     | Boot Flash is on CS 0 |
|               |       | 1     | Boot Flash is on CS 1 |

Table 5-13 summarizes the OSPI pin configuration done by ROM code for SPI boot device on port 0.

**Table 5-13. SPI Boot Pin Usage**

| Device Pin   | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|--------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| OSPI0_CLK    | OSPI0_CLK     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG0                 |
| OSPI0_LBCLKO | OSPI0_LBCLKO  | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG1                 |
| OSPI0_DQS    | OSPI0_DQS     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG2                 |
| OSPI0_D0     | OSPI0_D0      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG3                 |
| OSPI0_D1     | OSPI0_D1      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG4                 |
| OSPI0_CSn0   | OSPI0_CSn0    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG11                |
| OSPI0_CSn1   | OSPI0_CSn1    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG12                |

#### Note

All signals in the table will be configured even though some may not be used by this particular boot mode.

#### 5.4.1.4.1 SPI Bootloader Operation

Please refer to [Section 5.4.1](#) for more information that applies to SPI boot mode

The SPI boot mode supports the 1S-1S-1S mode only. The Read Command is 8-bits (0x03) followed by a 24 bit (3 byte) address. There are no dummy cycles issued after the read command. The frequency of operation supported is 6.250 MHz. OSPI0\_D0 will have data transfers **FROM** the processor **TO** the flash device, and OSPI0\_D1 will have data transfers **TO** the processor **FROM** the flash device

#### 5.4.1.4.1.1 SPI Initialization Process

In the SPI boot mode, the ROM Code initializes the OSPI peripheral to SPI mode and the image is read from the flash memory connected to the corresponding OSPI port and chip-select. A detailed summary of the SPI boot parameter table and the boot configuration definitions are listed in [Section 5.6.3, OSPI/QSPI/SPI Boot Parameter Table](#). If the image fails to be read correctly from offset 0x0 of the flash memory, the ROM will attempt to obtain the image at offset 0x400000. This is the only redundant image location supported by the ROM.

#### 5.4.1.4.1.2 SPI Loading Process

SPI boot mode is not eXecute-In-Place (XIP). ROM code first copies boot image into on-chip RAM and then executes it.

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

Table 5-14 shows configuration pins assignment to functions when boot mode is the I<sup>2</sup>C mode.

**Table 5-14. I<sup>2</sup>C Boot Configuration Fields**

| BOOTMODE Pins | Field     | Value | Description                       |
|---------------|-----------|-------|-----------------------------------|
| 9             | Bus reset | 0     | Hung bus reset attempt after 1 ms |
|               |           | 1     | No hung bus reset attempted       |
| 7             | Address   | 0     | EEPROM's address is 0x50          |
|               |           | 1     | EEPROM's address is 0x51          |

The I<sup>2</sup>C bus is considered inactive if the data line is low and clock remains high for the specified timeout time. Recovery consists of driving the clock a stop condition is detected. A stop condition is a transition on the data line from 0 to 1 while the clock line is high. If the clock line is stuck low there is no way to take control of the bus.

Table 5-15 summarizes the I<sup>2</sup>C pin configuration done by ROM code for I<sup>2</sup>C boot device.

**Table 5-15. I<sup>2</sup>C Pin Usage**

| Device Pin | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| I2C0_SCL   | I2C0_SCL      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG120               |
| I2C0_SDA   | I2C0_SDA      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG121               |

#### 5.4.2.1 I<sup>2</sup>C Bootloader Operation

##### 5.4.2.1.1 I<sup>2</sup>C Initialization Process

In the I<sup>2</sup>C boot mode, the ROM Code configures the Main Domain I2C0 in controller mode.

The boot controller drives the I<sup>2</sup>C target device where the image is stored. The image is copied to internal RAM, and is executed from there. If the image is not recognized, the ROM will attempt to read the image at offset 0x8000. This is the only redundant image supported by the ROM.

A detailed summary of the I<sup>2</sup>C boot parameter table and the BOOTMODE pins definitions are listed in Section 5.6.5, *I<sup>2</sup>C Boot Parameter Table* and Section 5.4.2, *I<sup>2</sup>C Boot Device Configuration*.

##### 5.4.2.1.1.1 Block Size

ROM code will read 0x800 bytes before processing the data. The last block must be padded to the next 0x800 byte boundary and it must be padded with zeros.

##### 5.4.2.1.1.2 Addressing

The boot code does not support byte address to bus address wrapping. So the maximum image size that can be accessed is 64 kbytes. For example, if the read address is 0xFF00, the read size is 0x200 and the I<sup>2</sup>C bus address is 0x50, then 0x100 bytes will be read from 0xFF00 at bus address 0x50, followed by 0x100 bytes from 0x0000 at bus address 0x50. The bus address does not increment when the address rolls over.

##### 5.4.2.1.2 I<sup>2</sup>C Loading Process

###### 5.4.2.1.2.1 Loading a Boot Image From EEPROM

In this mode, the Main Domain I2C0 peripheral is configured as I<sup>2</sup>C controller.

ROM Code will start reading from the I<sup>2</sup>C EEPROM at the specified I<sup>2</sup>C bus address. This read will be done beginning at the specified base address offset. Data will be read in 2-KB chunks. The data will be stored at the address specified in the boot header. It will continue reading image data until a complete image has been read. When the complete image has been read, the ROM Code will branch to the start address of the image.

### 5.4.3 SD Card Boot

Table 5-16 shows configuration pins assignment to functions when boot mode is the SD card boot mode.

**Table 5-16. SD Card Boot Configuration Fields**

| SD Card Boot Configuration Fields |        |       |                                                     |
|-----------------------------------|--------|-------|-----------------------------------------------------|
| BOOTMODE Pins                     | Field  | Value | Description                                         |
| 9 (13 <sup>(1)</sup> )            | Port   | 0     | Reserved                                            |
|                                   |        | 1     | MMC Port 1 (4 bit width). This bit must be set to 1 |
| 7                                 | FS/Raw | 0     | Filesystem mode                                     |
|                                   |        | 1     | Raw Mode                                            |

(1) When MMCSD is the backup mode.

Table 5-17 summarizes the MMCSD pin configuration done by ROM code for SD Card boot on port1 (MMCSD1). SD Card boot on Port 0 (MMCSD0) is not supported.

**Table 5-17. SD Card (MMCSD1) Pin Usage**

| Device Pin | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| MMC1_DAT3  | MMC1_DAT3     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG137               |
| MMC1_DAT2  | MMC1_DAT2     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG138               |
| MMC1_DAT1  | MMC1_DAT1     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG139               |
| MMC1_DAT0  | MMC1_DAT0     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG140               |
| MMC1_CLK   | MMC1_CLK      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG141               |
| MMC1_CLKLB | MMC1_CLKLB    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG142               |
| MMC1_CMD   | MMC1_CMD      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG143               |
| MMC1_SDCD  | MMC1_SDCD     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG144               |

#### Note

MMC1\_CLKLB signal is not pinned out on the device. The pinmux configuration enables the input buffer of the internal loopback clock.

#### Note

MMC1\_SDWP is not configured by ROM since the ROM never writes to the SD card.

#### 5.4.3.1 SD Card Bootloader Operation

SD Card boot is only available on Port 1 of the MMCSD controller (MMCSD1). The IOs on this port support both 1.8V and 3.3V operation, as well as dynamic voltage change. Thus, this port can support initial operation at 3.3V and remain at this voltage for legacy SD Cards, or support initial operation at 3.3V and change to 1.8V after ROM boot for UHS-I SD Cards.

The ROM will boot from SD cards using one of these methods:

- User Data Area (UDA) in raw mode
- User Data Area (UDA) in filesystem mode

The ROM is capable of booting from any size SD card because the MMCSD controller is responsible for addressing. Only single data rate with backward compatible interface timing is supported.

The MMCSD module depends on proper voltage level on the SD card detect signal (SDCD). If SDCD=1, the ROM will assume the card is not present and will fail the boot mode. The SDCD must be 0 for the ROM to

continue to attempt to boot. Card detect using DAT3 is not supported. If the card is detected, the initial discovery phase is performed:

1. Send CMD 0. (GO IDLE, both for MMC and SD)
2. Send CMD 55. If the card responds then the card type is assumed to be SD. On timeout the code sends CMD 1. If there is a response then the card type is MMC.

The ROM Code will start reading from the MMCSD memory boot sector, or filesystem, as specified by the BOOTMODE pins. Only FAT32 and FAT16 formats are supported in filesystem mode. It will continue reading data from the memory and storing it in internal RAM until a complete image has been read. In RAW mode only, the ROM supports a redundant image at offset 0x400000 in case the initial image fails to be recognized. When the complete image has been read and found in good integrity, the ROM Code will branch to the address defined in the Boot Info field of the boot header.

When SD Card boot is used as a backup boot option, only User Data Area (UDA) in filesystem mode is supported. Raw mode is not supported. Additionally, boot will only occur in 1-bit mode during backup booting.

#### 5.4.4 eMMC Boot

Table 5-18 shows configuration pins assignment to functions when boot mode is the eMMC Boot using a UDA boot mode (BOOTMODE[6:3]=1000b). Note that eMMC Boot using alternate eMMC Boot (BOOTMODE[6:3]=1001b) does not have any extra bootmode configuration fields. See Section 5.4.4.1 for more information.

**Table 5-18. eMMC Boot Configuration Fields (UDA mode)**

| eMMC Boot Configuration Fields |        |       |                                                       |
|--------------------------------|--------|-------|-------------------------------------------------------|
| BOOTMODE Pins                  | Field  | Value | Description                                           |
| 9 (13 <sup>(1)</sup> )         | Port   | 0     | MMCS0 Port 0 (8 bit width). This bit must be set to 0 |
|                                |        | 1     | Reserved                                              |
| 7                              | FS/Raw | 0     | Filesystem mode                                       |
|                                |        | 1     | Raw Mode                                              |

(1) When MMCS0 Boot is the backup mode.

Table 5-19 summarizes the MMCS0 pin configuration done by ROM code for eMMC boot on port0 (MMCS0). eMMC boot on Port 1 (MMCS1) is not supported.

**Table 5-19. eMMC (MMCS0 Port 0) Pin Usage**

| Device Pin | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| MMC0_DAT7  | MMC0_DAT7     | Enable      | Up             | 0            | Enable    | 0          | PADCONFIG126               |
| MMC0_DAT6  | MMC0_DAT6     | Enable      | Up             | 0            | Enable    | 0          | PADCONFIG127               |
| MMC0_DAT5  | MMC0_DAT5     | Enable      | Up             | 0            | Enable    | 0          | PADCONFIG128               |
| MMC0_DAT4  | MMC0_DAT4     | Enable      | Up             | 0            | Enable    | 0          | PADCONFIG129               |
| MMC0_DAT3  | MMC0_DAT3     | Enable      | Up             | 0            | Enable    | 0          | PADCONFIG130               |
| MMC0_DAT2  | MMC0_DAT2     | Enable      | Up             | 0            | Enable    | 0          | PADCONFIG131               |
| MMC0_DAT1  | MMC0_DAT1     | Enable      | Up             | 0            | Enable    | 0          | PADCONFIG132               |
| MMC0_DAT0  | MMC0_DAT0     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG133               |
| MMC0_CLK   | MMC0_CLK      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG134               |
| MMC0_CLKLB | MMC0_CLKLB    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG135               |
| MMC0_CMD   | MMC0_CMD      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG136               |

#### Note

MMC0\_CLKLB signal is not pinned out on the device. The pinmux configuration enables the input buffer of the internal loopback clock.

#### 5.4.4.1 eMMC Bootloader Operation

Booting from an eMMC device is only available on Port 0 of the MMCS0 controller (MMCS0). Booting from an eMMC device is not available on Port1 (MMCS1) or MMCS2. The IOs associated with MMCS0 port support both 1.8V and 3.3V eMMC operation

The ROM will boot from eMMC devices using one of these methods:

- User Data Area (UDA) in raw mode
- User Data Area (UDA) in filesystem mode
- eMMC bootmode (alternate)

To boot from UDA in either raw or filesystem mode, choose bootmode "MMCS0 Boot" (see Table 5-4).

A special alternate boot mode is available with eMMC devices which allows the ROM to boot from an image that is in a separate boot partition in the eMMC. To boot from this mode, choose "eMMC Boot" (see Table 5-4).

The ROM Code will start reading from the memory boot sector, filesystem, or boot partition as specified by the BOOTMODE pins. Only FAT32 and FAT16 formats are supported in filesystem mode. It will continue reading data from the memory and storing it in internal RAM until a complete image has been read. In RAW mode only, the ROM supports a redundant image at offset 0x400000 in case the initial image fails to be recognized. When the complete image has been read and found in good integrity, the ROM Code will branch to the address defined in the Boot Info field of the boot header.

When eMMC boot is used as a backup boot option, only User Data Area (UDA) in filesystem mode is supported. Raw mode is not supported. Additionally, boot will only occur in 1-bit mode during backup booting.

### 5.4.5 Ethernet Boot

Table 5-20 shows configuration pins assignment to functions when boot mode is the Ethernet RGMII mode.

**Table 5-20. Ethernet RGMII Boot Configuration Fields**

| BOOTMODE Pins | Field     | Value | Description                                       |
|---------------|-----------|-------|---------------------------------------------------|
| 9             | Clkout    | 0     | 25 MHz clock not generated on CLKOUT0             |
|               |           | 1     | 25 MHz clock generated on CLKOUT0                 |
| 8             | Delay     | 0     | Must be set to 0 for RGMII with internal Tx delay |
|               |           | 1     | Reserved                                          |
| 7             | Link info | 0     | MDIO PHY scan used for link parameters.           |
|               |           | 1     | Link parameters programmed by the ROM             |

Table 5-21 shows configuration pins assignment to functions when boot mode is the Ethernet RMII mode.

**Table 5-21. Ethernet RMII Boot Configuration Fields**

| BOOTMODE Pins | Field   | Value | Description                             |
|---------------|---------|-------|-----------------------------------------|
| 9             | Clkout  | 0     | 50 MHz clock not generated on CLKOUT0   |
|               |         | 1     | 50 MHz clock generated on CLKOUT0       |
| 8             | Clk src | 0     | External clock source for RMII1_REF_CLK |
|               |         | 1     | Internal clock source for RMII1_REF_CLK |
| 7             | RMII    | 0     | This bit must be set to 0               |
|               |         | 1     | Reserved                                |

**Table 5-22. Ethernet RMII Clocking**

| BOOTMODE Pin 9 (Clk out) | BOOTMODE Pin 8 (Clk src) | Description                                                                                                                           |
|--------------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0                        | 0                        | 50MHz external source to RMII_REF_CLK and to external Ethernet PHY input clock (CLKOUT0 is unused) These are the recommended settings |
| 0                        | 1                        | Not a valid configuration                                                                                                             |
| 1                        | 0                        | CLKOUT0 is configured to 50MHz and connect to both RMII1_REF_CLK and to external Ethernet PHY input clock                             |
| 1                        | 1                        | Not a valid configuration                                                                                                             |

Table 5-23 shows configuration pins assignment to functions when the backup boot mode Ethernet. The Interface configuration field chooses which interface will be used (RGMII or RMII)

**Table 5-23. Ethernet Backup Boot Configuration Field**

| BOOTMODE Pins | Field     | Value | Description                     |
|---------------|-----------|-------|---------------------------------|
| 13            | Interface | 0     | RGMII with internal TX delay    |
|               |           | 1     | RMII with external clock source |

Table 5-24 summarizes the RGMII pin configuration done by ROM code for Ethernet boot device on RGMII port.

**Table 5-24. RGMII Pin Usage**

| Device Pin    | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|---------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| RGMII1_TX_CTL | RGMII1_TX_CTL | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG75                |
| RGMII1_TXC    | RGMII1_TXC    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG76                |
| RGMII1_TD0    | RGMII1_TD0    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG77                |
| RGMII1_TD1    | RGMII1_TD1    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG78                |
| RGMII1_TD2    | RGMII1_TD2    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG79                |
| RGMII1_TD3    | RGMII1_TD3    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG80                |

**Table 5-24. RGMII Pin Usage (continued)**

| Device Pin    | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|---------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| RGMII1_RX_CTL | RGMII1_RX_CTL | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG81                |
| RGMII1_RXC    | RGMII1_RXC    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG82                |
| RGMII1_RD0    | RGMII1_RD0    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG83                |
| RGMII1_RD1    | RGMII1_RD1    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG84                |
| RGMII1_RD2    | RGMII1_RD2    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG85                |
| RGMII1_RD3    | RGMII1_RD3    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG86                |
| MDIO0_MDIO    | MDIO0_MDIO    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG87                |
| MDIO0_MDC     | MDIO0_MDC     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG88                |

Table 5-25 summarizes the RMII pin configuration done by ROM code for Ethernet boot device on RMII port.

**Table 5-25. RMII Pin Usage**

| Device Pin                 | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|----------------------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| RGMII1_RX_CTL              | RMII1_RX_ER   | Disable     | NA             | 0            | Enable    | 1          | PADCONFIG81                |
| RGMII1_RXC                 | RMII1_REF_CLK | Disable     | NA             | 0            | Enable    | 1          | PADCONFIG82                |
| RGMII1_RD0                 | RMII1_RXD0    | Disable     | NA             | 0            | Enable    | 1          | PADCONFIG83                |
| RGMII1_RD1                 | RMII1_RXD1    | Disable     | NA             | 0            | Enable    | 1          | PADCONFIG84                |
| RGMII1_TD0                 | RMII1_TXD0    | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG77                |
| RGMII1_TD1                 | RMII1_TXD1    | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG78                |
| RGMII1_TX_CTL              | RMII1_TX_EN   | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG75                |
| RGMII1_TXC                 | RMII1_CRS_DV  | Disable     | NA             | 0            | Enable    | 1          | PADCONFIG76                |
| EXT_REFCLK1 <sup>(1)</sup> | CLKOUT0       | Disable     | NA             | 0            | Disable   | 5          | PADCONFIG124               |
| MDIO0_MDIO                 | MDIO0_MDIO    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG87                |
| MDIO0_MDC                  | MDIO0_MDC     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG88                |

(1) Enabled when CLKOUT0 option is selected from boot pin selection.

#### 5.4.5.1 Ethernet Bootloader Operation

##### 5.4.5.1.1 Ethernet Initialization Process

When the device is set to boot through the Ethernet mode, the ROM Code configures the Ethernet module and the interface mode (RMII, RGMII) according to the the BOOTMODE pin settings, see [Section 5.4.5, Ethernet Boot Device Configuration](#). Also consult the boot parameter table for the Ethernet boot, see [Section 5.6.7, Ethernet Boot Parameter Table](#).

When Link Info = 0, the link parameters are read using MDIO scan. This is the typical setting when using an external PHY. With these parameters, the ROM identifies the PHY and establishes link with the supported speed and duplex mode.

When Link Info = 1, no MDIO scan is performed, and the link parameters are programmed by the ROM based on the RGMII status register. This is the typical setting when configured as a MAC to MAC RGMII interface whereby RGMII pins of two devices can be connected directly and establish link in force mode. The chosen configuration will be Gigabit, full duplex mode.

Note that booting from RGMII requires that an attached PHY be configured for RGMII-ID Mode immediately upon exiting reset. The ROM will not make this configuration change to the PHY.

The ROM will setup RGMII mode enabling internal delay mode.

#### 5.4.5.1.2 Ethernet Loading Process

After device configuration, the bootloader performs a standard BOOTP/TFTP boot. The device sends a BOOTP request with its MAC address to a host TFTP server to be assigned an IP from a pool of addresses. The timeout for each BOOTP packet is 4 seconds, and the ROM will attempt 10 BOOTP retries, after which the boot mode will fail. If the connection is established, the device initiates a TFTP download and is able to receive image data encapsulated in Ethernet packets, see [Section 5.4.5.1.2.1](#). There is a timeout of 1 second to receive a response for the READ request, and the ROM will retry the READ request 10 times, after which the boot mode will fail. If TFTP download is successful, data received is stripped of its network headers and the boot data is stored in internal RAM. When the transfer completes and the image is found in good integrity, the ROM Code will branch to the address defined in the Boot Info field of the boot header.

#### 5.4.5.1.2.1 Ethernet Boot Data Formats

Ethernet boot uses the BOOTP/TFTP protocol for downloads. Only IPv4 is supported.

##### 5.4.5.1.2.1.1 Limitations

- Received packets cannot be IP fragmented (should not be a problem in most systems since the BOOTP/TFTP packets have fixed lengths of small size)
- Only DIX Ethernet headers are supported.
  - 802.3 with SNAP/LLC not supported
  - DIX Ethernet with VLAN not supported
  - 802.3 with VLAN and SNAP/LLC not supported

##### 5.4.5.1.2.1.2 BOOTP Request

###### 5.4.5.1.2.1.2.1 MAC Header (DIX)

- Destination MAC = value from parameter table (default is broadcast)
- Source MAC = value from parameter table (default is e-fuse value)
- Type = IPv4 (0x0800)

###### 5.4.5.1.2.1.2.2 IPv4 Header

- Version = 4
- Header length = 0
- TOS = 0
- Len = computed during operation
- ID = 0x0001
- Flags + Fragment offset = 0
- TTL = 0x10
- Protocol = UDP (17)
- Header checksum = Computed during operation
- SRC IP = 0.0.0.0
- Dest IP = 255.255.255.255

###### 5.4.5.1.2.1.2.3 UDP Header

- Source port = BOOTP client (68 decimal)
- Destination Port = BOOTP server (67 decimal)
- Length = computed during operation
- Checksum = computed during operation

###### 5.4.5.1.2.1.2.4 BOOTP Payload

- Opcode = Request (1)
- HW Type = Ethernet (1)
- HW Addr Len = 6
- Hop Count = 0
- Transaction ID = 1
- Number of seconds = 0

- Client IP = 0.0.0.0
- Your IP = 0.0.0.0
- Server IP = 0.0.0.0
- Gateway IP = 0.0.0.0
- Client HW Address = Device MAC address (from parameter table)
- Server hostname = NULL
- Filename = NULL
- Option 60, Vendor ID string, from parameter table
- Option 61, Client ID string, from parameter table

#### **5.4.5.1.2.1.2.5 TFTP**

There are no ROM code specific TFTP configurations.

#### **5.4.5.1.3 Ethernet Hand Over Process**

Once the ROM Code receives the valid packet, it decodes it to get the image sections and loads them in the appropriate memory location. After the image is loaded and validated, the ROM Code starts the boot image execution.

### 5.4.6 USB Boot

Table 5-26 shows configuration pins assignment to functions when boot mode is the USB mode.

**Table 5-26. USB Boot Configuration Fields**

| USB Configuration Fields for Primary Boot Mode |             |       |                                   |
|------------------------------------------------|-------------|-------|-----------------------------------|
| BOOTMODE Pins                                  | Field       | Value | Description                       |
| 9                                              | CoreVoltage | 0     | 0.85V core voltage                |
|                                                |             | 1     | 0.75V core voltage                |
| 8 (13 <sup>(1)</sup> )                         | Mode        | 0     | DFU (USB device firmware upgrade) |
|                                                |             | 1     | Host (MSC boot)                   |
| 7                                              | Lane Swap   | 0     | D+/D- lines are not swapped       |
|                                                |             | 1     | D+/D- lines are swapped           |

(1) When USB is the backup mode.

Table 5-27 summarizes the USB pin configuration done by ROM code for USB boot device on port 0.

**Table 5-27. USB Port 0 Pin Usage**

| Device Pin   | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|--------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| USB0_DRVVBUS | USB0_DRVVBUS  | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG149               |

#### Note

Note that other USB pins do not have pin mux options. USB\_DRVVBUS is configured in DFU mode even though it is not used.

Note on USB backup boot:

- Lane Swap (D+/D- lines) are not allowed

Configurability (pins) of these options do not exist in the USB backup boot mode.

#### CAUTION

A USB Type-AB connector should not be connected to another host when the device is booting as a USB Host. This will prevent two USB power sources from being connected together.

### 5.4.6.1 USB Bootloader Operation

The USB boot mode is used to read the boot image from external USB host.

See [Section 5.4.6, USB Boot Device Configuration](#) and [Section 5.6.10, USB Boot Parameter Table](#) for the available configuration options.

More information about USB DFU protocol can be found at [http://www.usb.org/sites/default/files/DFU\\_1.1.pdf](http://www.usb.org/sites/default/files/DFU_1.1.pdf).

In DFU mode, the ROM will attempt an enumeration for 60 seconds, after which the boot mode will fail. If a successful enumeration is achieved, the ROM Code will start reading from the external host as specified by the BOOTMODE pins. It will continue reading data from the memory and storing it in internal RAM until a complete image has been read. When the complete image has been read and found in good integrity, the ROM Code will branch to the address defined in the Boot Info field of the boot header.

#### 5.4.6.1.1 USB-Specific Attributes

##### 5.4.6.1.1.1 DFU Device Mode

- Vendor ID = 0x451
- Product ID = 0x6165
- Device ID = 0

### 5.4.7 UART Boot

ROM Code always configures the UART port to 115200 kbaud, 8-n-1 mode, and the XMODEM protocol is used to transfer the boot data.

Table 5-28 summarizes the UART pin configuration done by ROM code for UART host on port 0.

**Table 5-28. UART Port 0 Pin Usage**

| Device Pin | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| UART0_TXD  | UART0_TXD     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG115               |
| UART0_RXD  | UART0_RXD     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG114               |

#### 5.4.7.1 UART Bootloader Operation

##### 5.4.7.1.1 Initialization Process

In the UART boot mode, the selected UART module (port) is the only peripheral configured. The baud rate, data, parity, and stop bits are configured based on the information in the UART boot parameter table. The boot parameter table definitions and the boot configuration values that can be set are in [Section 5.4.7, UART Boot Device Configuration](#) and [Section 5.6.4, UART Boot Parameter Table](#).

Once the ROM Code configures the UART, it sends the UART pings for few seconds, which can be seen in the host. The pings consist of an ASCII capital C character. The UART boot mode supports only the CRC mode of XMODEM and does not support CHECKSUM mode. Both 128 and 1024 byte block sizes are supported.

##### 5.4.7.1.2 UART Loading Process

Before the ping from the device stops, load the boot image from the host using the XMODEM protocol.

##### 5.4.7.1.2.1 UART XMODEM

The XMODEM protocol is used to transfer boot data. Only CRC mode is supported (not checksum), with both 128- and 1024-byte block sizes. The general format of received frames is shown in [Table 5-29](#) and [Table 5-30](#).

**Table 5-29. XMODEM 1024- and 128-byte Data Frames**

|     |           |               |                 |     |     |     |     |
|-----|-----------|---------------|-----------------|-----|-----|-----|-----|
| STX | Block Num | Inv Block Num | 1024 data bytes |     |     | CRC | CRC |
| SOH | Block Num | Inv Block Num | 128 data bytes  | CRC | CRC |     |     |

**Table 5-30. XMODEM Data Frame Fields**

| Field         | Value            | Description                                                                                |
|---------------|------------------|--------------------------------------------------------------------------------------------|
| STX           | 0x02             | The start character for 1024-byte CRC data blocks                                          |
| SOH           | 0x01             | The start character for 128-byte CRC data block                                            |
| Block Num     | 0x01-0xFF – 0x00 | The block number. The first block has value 1, and the block number wraps around 0xFF to 0 |
| Inv Block Num | 0xFE-0x00        | The inverse block number (bit inverse of the block number)                                 |
| CRC           | Calculated       | The 16-bit CRC generated from the polynomial 0x1021                                        |

The XMODEM protocol is implemented as a half-duplex protocol as shown in [Table 5-31](#).

**Table 5-31. Example of XMODEM Transfer protocol**

| Transmitter Sends | Receiver Sends  |
|-------------------|-----------------|
|                   | ← Ping ('C')    |
| Frame 1           | →               |
|                   | ← ACK (or NACK) |
| Frame 2           | →               |
|                   | ← ACK (or NACK) |
| EOT               | →               |

**Table 5-31. Example of XMODEM Transfer protocol  
(continued)**

| Transmitter Sends | Receiver Sends |
|-------------------|----------------|
| ←                 | ACK (or NACK)  |

**5.4.7.1.3 UART Hand-Over Process**

Once the complete image has been read and found in good integrity, the ROM Code will branch to the address defined in the Boot Info field of the boot header.

### 5.4.8 GPMC NOR Boot

There are no configuration fields for this boot mode. GPMC NOR boot only supports 16-bit non-mux memory.

Table 5-32 summarizes the GPMC pin configuration done by ROM code for GPMC NOR boot.

**Table 5-32. GPMC NOR Boot Pin Usage**

| Device Pin     | Module Signal  | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|----------------|----------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| GPMC0_AD0      | GPMC0_AD0      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG15                |
| GPMC0_AD1      | GPMC0_AD1      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG16                |
| GPMC0_AD2      | GPMC0_AD2      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG17                |
| GPMC0_AD3      | GPMC0_AD3      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG18                |
| GPMC0_AD4      | GPMC0_AD4      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG19                |
| GPMC0_AD5      | GPMC0_AD5      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG20                |
| GPMC0_AD6      | GPMC0_AD6      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG21                |
| GPMC0_AD7      | GPMC0_AD7      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG22                |
| GPMC0_AD8      | GPMC0_AD8      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG23                |
| GPMC0_AD9      | GPMC0_AD9      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG24                |
| GPMC0_AD10     | GPMC0_AD10     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG25                |
| GPMC0_AD11     | GPMC0_AD11     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG26                |
| GPMC0_AD12     | GPMC0_AD12     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG27                |
| GPMC0_AD13     | GPMC0_AD13     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG28                |
| GPMC0_AD14     | GPMC0_AD14     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG29                |
| GPMC0_AD15     | GPMC0_AD15     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG30                |
| VOUT0_DATA0    | GPMC_A0        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG46                |
| VOUT0_DATA1    | GPMC_A1        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG47                |
| VOUT0_DATA2    | GPMC_A2        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG48                |
| VOUT0_DATA3    | GPMC_A3        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG49                |
| VOUT0_DATA4    | GPMC_A4        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG50                |
| VOUT0_DATA5    | GPMC_A5        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG51                |
| VOUT0_DATA6    | GPMC_A6        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG52                |
| VOUT0_DATA7    | GPMC_A7        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG53                |
| VOUT0_DATA8    | GPMC_A8        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG54                |
| VOUT0_DATA9    | GPMC_A9        | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG55                |
| VOUT0_DATA10   | GPMC_A10       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG56                |
| VOUT0_DATA11   | GPMC_A11       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG57                |
| VOUT0_DATA12   | GPMC_A12       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG58                |
| VOUT0_DATA13   | GPMC_A13       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG59                |
| VOUT0_DATA14   | GPMC_A14       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG60                |
| VOUT0_DATA15   | GPMC_A15       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG61                |
| VOUT0_HSYNC    | GPMC_A16       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG62                |
| VOUT0_DE       | GPMC_A17       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG63                |
| VOUT0_VSYNC    | GPMC_A18       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG64                |
| VOUT0_PCLK     | GPMC_A19       | Disable     | NA             | 0            | Disable   | 1          | PADCONFIG65                |
| GPMC0_CSn3     | GPMC_A20       | Disable     | NA             | 0            | Disable   | 2          | PADCONFIG45                |
| GPMC0_ADVn_ALE | GPMC0_ADVn_ALE | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG33                |
| GPMC0_OEn_REN  | GPMC0_OEn_Ren  | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG34                |
| GPMC0_WEN      | GPMC0_WEN      | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG35                |

**Table 5-32. GPMC NOR Boot Pin Usage (continued)**

| Device Pin     | Module Signal  | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|----------------|----------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| GPMC0_BE0n_CLE | GPMC0_BEOn_CLE | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG36                |
| GPMC0_BE1n     | GPMC0_BE1n     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG37                |
| GPMC0_CSn0     | GPMC0_CSn0     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG42                |

**Note**

Only 21 address lines (GPMC0\_A0 – GPMC0\_A20) are used because the GPMC0\_A21 and GPMC0\_A22 lines are muxed with GPMC0\_WAIT1 and GPMC0\_WPn respectively.

GPMC0\_A20 is muxed with GPMC0\_CSn3, and ROM uses GPMC0\_A20 for this address line. Thus, no CSn3 support when using GPMC NOR boot.

All signals in the table will be configured even though some may not be used by this particular boot mode.

**5.4.8.1 GPMC NOR Bootloader Operation**

In this mode, the ROM Code configures the GPMC interface based on the configuration parameters specified in the boot parameter table for the GPMC NOR boot mode [Section 5.6.11](#), see *GPMC NOR Boot Parameter Table*.

Timing registers are programmed as follows for NOR flash boot:

**Table 5-33. GPMC NOR Timing Configuration**

| GPMC register | Value      |
|---------------|------------|
| GPMC_CONFIG1  | 0x00001010 |
| GPMC_CONFIG2  | 0x00101c01 |
| GPMC_CONFIG3  | 0x23060917 |
| GPMC_CONFIG4  | 0x1005bc1a |
| GPMC_CONFIG5  | 0x011b111e |
| GPMC_CONFIG6  | 0x8f070000 |
| GPMC_CONFIG7  | 0x00000c50 |

GPMC NOR boot mode is not executable-in-place (XIP). ROM code first copies boot image into on-chip RAM and then executes it. Only non-muxed memory is supported. If the initial image at offset 0x0 is not recognized, the ROM will attempt to read a redundant image from offset 0x100000. This is the only redundant image supported by the ROM.

### 5.4.9 GPMC NAND Boot

Table 5-34 summarizes the GPMC pin configuration done by ROM code for NAND boot.

**Table 5-34. GPMC NAND Boot Pin Usage**

| Device Pin     | Module Signal  | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|----------------|----------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| GPMC0_AD0      | GPMC0_AD0      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG15                |
| GPMC0_AD1      | GPMC0_AD1      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG16                |
| GPMC0_AD2      | GPMC0_AD2      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG17                |
| GPMC0_AD3      | GPMC0_AD3      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG18                |
| GPMC0_AD4      | GPMC0_AD4      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG19                |
| GPMC0_AD5      | GPMC0_AD5      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG20                |
| GPMC0_AD6      | GPMC0_AD6      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG21                |
| GPMC0_AD7      | GPMC0_AD7      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG22                |
| GPMC0_ADVn_ALE | GPMC0_ADVn_ALE | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG33                |
| GPMC0_OEn_Ren  | GPMC0_OEn_Ren  | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG34                |
| GPMC0_Wen      | GPMC0_Wen      | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG35                |
| GPMC0_BEOn_CLE | GPMC0_BEOn_CLE | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG36                |
| GPMC0_WAIT0    | GPMC0_WAIT0    | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG38                |
| GPMC0_CSn0     | GPMC0_CSn0     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG42                |

#### 5.4.9.1 GPMC NAND Bootloader Operation

Timing registers are programmed as follows for NAND flash boot:

**Table 5-35. GPMC NAND Timing Configuration**

| GPMC register | Value       |
|---------------|-------------|
| GPMC_CONFIG1  | 0x000000813 |
| GPMC_CONFIG2  | 0x00080b00  |
| GPMC_CONFIG3  | 0x22080810  |
| GPMC_CONFIG4  | 0x05006890  |
| GPMC_CONFIG5  | 0x0107080b  |
| GPMC_CONFIG6  | 0x80000180  |
| GPMC_CONFIG7  | 0x00000f50  |

GPMC NAND boot only supports boot from ONFI 1.0 compatible 8 bit parallel NAND memory up to 2Gbytes in size connected to GPMC CS0 with the following geometries:

- 2Kbyte page and spare area of at least 64 bytes or
- 4Kbyte page size and spare area of at least 128 bytes.
- Non-ECC part only:
  - ROM uses ELM to handle ECC
  - ECC is BCH8 using D[7:0] for data
  - The param page CRC is checked and in case of failure the redundant page is used

GPMC is setup to comply with mode 0 timing for NAND flash.

### 5.4.10 Serial NAND Boot

Serial NAND Configuration Fields table shows configuration pins assignment to functions when boot mode is Serial NAND.

**Table 5-36. Serial NAND Configuration Fields**

| BOOTMODE Pins | Field       | Value | Description                                                                      |
|---------------|-------------|-------|----------------------------------------------------------------------------------|
| 8             | Read Mode 2 | 0     | Reserved (Read mode is taken from Read Mode 1)                                   |
|               |             | 1     | SPI/ 1-1-1 mode (Read mode is taken from Read Mode 2 and Read Mode 1 is ignored) |
| 7             | Read Mode 1 | 0     | OSPI/ 1-1-8 Mode (valid only when Read Mode 2 is 0)                              |
|               |             | 1     | OSPI/ 1-1-4 Mode (valid only when Read Mode 2 is 0)                              |

Serial NAND Pin Usage table summarizes the pin configuration done by ROM code for the Serial NAND device.

**Table 5-37. Serial NAND Pin Usage**

| Device Pin   | Module Signal | Pull Enable | Pull Direction | Driver Index | Rx En/Dis | Pinmux Sel | Pad Configuration Register |
|--------------|---------------|-------------|----------------|--------------|-----------|------------|----------------------------|
| OSPI0_CLK    | OSPI0_CLK     | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG0                 |
| OSPI0_LBCLKO | OSPI0_LBCLKO  | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG1                 |
| OSPI0_DQS    | OSPI0_DQS     | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG2                 |
| OSPI0_D0     | OSPI0_D0      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG3                 |
| OSPI0_D1     | OSPI0_D1      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG4                 |
| OSPI0_D2     | OSPI0_D2      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG5                 |
| OSPI0_D3     | OSPI0_D3      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG6                 |
| OSPI0_D4     | OSPI0_D4      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG7                 |
| OSPI0_D5     | OSPI0_D5      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG8                 |
| OSPI0_D6     | OSPI0_D6      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG9                 |
| OSPI0_D7     | OSPI0_D7      | Disable     | NA             | 0            | Enable    | 0          | PADCONFIG10                |
| OSPI0_CSn0   | OSPI0_CSn0    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG11                |
| OSPI0_CSn1   | OSPI0_CSn1    | Disable     | NA             | 0            | Disable   | 0          | PADCONFIG12                |

#### Note

All signals in the table will be configured even though some may not be used by this particular boot mode.

### 5.4.10.1 Serial NAND Bootloader Operation

Serial NAND defines 1S-1S-1S mode for general backwards compatibility, and 1S-1S-8S for maximum throughput (S here means \*S\*ingle Data rate). Serial NAND memory array is organized into pages of size 2KB/4KB. Read is a two-step process where a complete page is first read into flash's internal buffer/cache using Page read command and then the host controller reads from internal buffer in 1- or 4- or 8-bit mode using the read commands. Page read command that is issued is 0x13, followed by 24 address bits. The frequency of operation supported is 50 MHz.

For 1S-1S-1S mode of operation (Bit-width =1, Single Data Rate). The Command and Address issued are 8 bits and 16 bits respectively. The Read Command that is issued is 0x0B, followed by address bits and 8 dummy cycles.

For 1S-1S-8S mode of operation (Bit-width =8, Single Data Rate). The Command and Address issued are 8 bits and 16 bits respectively. The Read Command that is issued is 0x8B, followed by address bits and 8 dummy

cycles. Additionally, flash is configured in 8-bit mode after POR through volatile configuration register if the manufacturer is Winbond.

For 1S-1S-4S mode of operation (Bit-width =4, Single Data Rate). The Command and Address issued are 8 bits and 16 bits respectively. The Read Command that is issued is 0x6B, followed by address bits and 8 dummy cycles. Note that in 8-bit mode pin mux is done for all 8 OSPI data lines and in 4-bit/1-bit mode pin mux is done for 4 OSPI data lines. This is done to disable the HOLD functionality feature in 1-bit mode.

Serial NAND boot expects ECC to be auto-managed by the flash. Most of the flashes have the ECC enabled by default and can do 1-bit correction and 2-bit detection for ECC errors. ROM checks for 2-bit ECC error via status register 3 (address 0xC0) bit 5 after every page load. In case of 2-bit ECC error the boot will fail and ROM will take the fallback option.

Serial NAND boot also manages bad blocks that can be present in the flash at time of shipment or develop during the lifetime. Bad block marker is a non-FFh data byte stored at Byte 0 of spare area of Page 0 for each bad block and ROM checks for the same while reading the first page of a memory block. ROM will skip the particular block if it is marked as bad and move to the next one.

The Serial NAND driver in ROM does not support devices that have multiple planes as they require special handling to read even numbered blocks

#### **5.4.10.2 Serial NAND Initialization Process**

In the OSPI boot mode, the ROM Code initializes the OSPI module and the image is read from the OSPI flash connected to the selected chip-select. If the image fails to be read correctly from offset 0x0 of the flash memory, the ROM will attempt to obtain the image at offset 0x400000. This is the only redundant image location supported by the ROM. See [Section 5.4.1.1, OSPI Boot Device Configuration](#) for OSPI port settings.

A detailed summary of the OSPI boot parameter table and the boot configuration definitions are listed in [Section 5.6.3, OSPI Boot Parameter Table](#).

#### **5.4.10.3 Serial NAND Loading Process**

OSPI boot mode is not eXecute-In-Place (XIP). ROM code first copies boot image into on-chip RAM and then executes it.

#### 5.4.11 No boot/Development boot

Table 5-38 shows configuration pins assignment to functions when boot mode is the No-boot mode.

**Table 5-38. No-boot/Dev-boot Configuration Fields**

| Field     | Value | Description      |
|-----------|-------|------------------|
| No/Dev    | 0     | Development Boot |
|           | 1     | No boot          |
| ARM/Thumb | 0     | ARM mode         |
|           | 1     | Thumb mode       |

These boot modes are useful for debugging purposes to preclude the execution of the ROM.

During the Development boot (BOOTMODE[7] = 0), the SMS M4F ROM code will act as if boot of the primary image has completed, and the SMS M4F ROM then will be waiting for a firmware load message from DM R5. Thus the user can load a standard u-boot/SPL image to the DM R5 RAM. U-boot/SPL will then load the SMS firmware and complete the full boot.

In No-boot (BOOTMODE[7] = 1), both the SMS M4F and DM R5 ROMs are bypassed and both CPUs are held in a dummy branch-to-self loop. No-boot is the most minimal device touch state by the ROM - only minimal hardware configurations are done and none of the PLLs is locked/configured. No-boot is suitable if user wants to load his own PLL, Pad config, and other basic settings.

## 5.5 PLL Configuration

ROM code must be aware of the reference clock provided to PLLs. That is, the speed of the quartz crystal, or the clock supplied by an external clock oscillator. On how to indicate the PLL reference clock, see [PLL Reference Clock Selection](#)

ROM code configures only PLLs which are required during boot. Therefore, if a PLL is required for the backup boot mode but not the primary boot mode, and if the backup boot mode never executes, then the PLLs required for backup boot are not enabled.

The following tables show the HSDIV values that are programmed by the R5 ROM if a boot mode uses it. A value of NA means that the ROM does not program that HSDIV

**Table 5-39. MAIN\_PLL0 (MAIN PLL) (2000MHz)**

| PLL POSTDIV | HSDIV  | Value | Frequency(MHz) | Boot Peripheral/IP |
|-------------|--------|-------|----------------|--------------------|
| 0           | HSDIV0 | 4     | 500            | MAIN SYSCLK0       |
| 0           | HSDIV1 | 10    | 200            | OSPI               |
| 0           | HSDIV2 | 0     | NA             | WKUP_CLKOUT        |
| 0           | HSDIV3 | 15    | 133            | GPMC NOR/GPMC NAND |
| 0           | HSDIV4 | 0     | NA             | MCAN               |
| 1           | HSDIV5 | 5     | 200            | eMMC0              |
| 1           | HSDIV6 | 0     | NA             | CPTS               |
| 1           | HSDIV7 | 4     | 250            | TIMER              |
| 1           | HSDIV8 | 0     | NA             | USB0               |
| 1           | HSDIV9 | 0     | NA             | PRUSS              |

**Table 5-40. MAIN\_PLL1 (PER0 PLL) (1920MHz)**

| PLL POSTDIV | HSDIV  | Value | Frequency(MHz) | Boot Peripheral/IP |
|-------------|--------|-------|----------------|--------------------|
| 0           | HSDIV0 | 10    | 192            | UART               |
| 0           | HSDIV1 | 12    | 160            | UART               |
| 0           | HSDIV2 | 0     | NA             | WKUP_CLKOUT        |
| 0           | HSDIV3 | 0     | NA             | TIMER              |
| 0           | HSDIV4 | 0     | NA             | Reserved           |
| 1           | HSDIV5 | 0     | NA             | OSPI               |
| 1           | HSDIV6 | 0     | NA             | McASP              |

**Table 5-41. MAIN\_PLL2 (PER1 PLL) (2000MHz)**

| PLL POSTDIV | HSDIV  | Value | Frequency(MHz) | Boot Peripheral/IP |
|-------------|--------|-------|----------------|--------------------|
| 0           | HSDIV0 | 0     | NA             | PRUSS core         |
| 0           | HSDIV1 | 8     | 250            | CP_GEMAC           |
| 0           | HSDIV2 | 10    | 200            | eMMC1              |
| 0           | HSDIV3 | 0     | NA             | DebugSS            |
| 0           | HSDIV4 | 0     | NA             | GPU                |
| 1           | HSDIV5 | 0     | NA             | PRUSS IEP          |
| 1           | HSDIV6 | 0     | NA             | TIMER              |
| 1           | HSDIV7 | 0     | NA             | GPMC               |
| 1           | HSDIV8 | 0     | NA             | McASP              |
| 1           | HSDIV9 | 0     | NA             | WKUP_CLKOUT        |

**Table 5-42. MAIN\_PLL15 (2000MHz)**

| HSDIV  | Value | Frequency(MHz) | Boot Peripheral/IP |
|--------|-------|----------------|--------------------|
| HSDIV0 | 5     | 400            | HSM/SMS/DM         |
| HSDIV1 | 5     | 400            | SA3_UL PKA         |

**Note**

All other PLLs are not used or programmed by the ROM

**Note**

The bringup and configuration of bootmode-specific PLLs by ROM code will result in a bootmode-specific device clocking setup which for example has an impact on which peripheral modules can readily be clocked and used by SBL/SPL prior to loading and bringing up System Firmware (SYSFW)

## 5.6 Boot Parameter Tables

The boot parameter tables direct the main module boot process. On cold boot the tables are created based on pin strapped values (see [Section 5.3, Boot Mode Pins](#)) and built-in data. The ROM Code supports two parameter tables stored as an array in a fixed memory address in the internal RAM, each of size 512 bytes. The ROM will attempt to boot using the primary table. On boot failure, ROM Code will retry using the second table.

Using two tables handles two cases.

- The first is in initial board manufacture where the primary boot table specifies boot from a flash device, and the flash is blank. ROM Code would then switch to the secondary boot mode which would receive the image externally (Ethernet, USB, UART) and this image would flash the boot image.
- The second case is failure due to total flash corruption. In flash parameter tables, there exists backup addresses within the primary boot mode. This covers the problem of a flash update failure with a backup image present on the same flash device. Note for SD Card/eMMC boot, the backup addresses are only applicable in raw boot mode

The boot tables reside at a fixed location in memory which is described in [Section 5.8.1, Global Memory Addresses Used by ROM Code](#).

### 5.6.1 Common Header

These boot parameter tables have certain parameters common across all the boot modes, while the rest of the parameters are unique to the boot modes. The common entries in the boot parameter table are shown in [Table 5-43](#).

**Table 5-43. Boot Parameter Table Common Header**

| Byte Offset | Size (bytes) | Name         | Description                                                                                                    |
|-------------|--------------|--------------|----------------------------------------------------------------------------------------------------------------|
| 0           | 2            | Length       | The length of the table                                                                                        |
| 2           | 2            | Checksum     | Ones complement checksum over length bytes in the table. If 0 the checksum is not validated.                   |
| 4           | 2            | Peripheral   | Identifies the boot peripheral and format of the table after the common header. See <a href="#">Table 5-44</a> |
| 6           | 2            | Reserved     | Reserved                                                                                                       |
| 8           | 4            | Timeout      | Timeout for this boot mode, in milliseconds                                                                    |
| 12          | 4            | Magic        | Magic value 0x01AD0911                                                                                         |
| 16          | 40           | PLL Config 0 | PLL Configuration 0. See <a href="#">Table 5-45</a>                                                            |
| 56          | 40           | PLL Config 1 | PLL Configuration 1                                                                                            |
| 96          | 40           | PLL Config 2 | PLL Configuration 2                                                                                            |
| 136         | 40           | PLL Config 3 | PLL Configuration 3                                                                                            |
| 176         | 40           | PLL Config 4 | PLL Configuration 4                                                                                            |
| 216         | 40           | PLL Config 5 | PLL Configuration 5                                                                                            |

[Table 5-44](#) lists the possible boot modes used in the boot parameter tables.

**Table 5-44. Boot Peripheral Selection**

| Peripheral Field Value | Description                   |
|------------------------|-------------------------------|
| 0                      | Sleep (No boot)               |
| 10                     | Ethernet Reserved             |
| 20                     | Ethernet BOOTP/TFTP (general) |
| 21                     | Ethernet RGMII specific       |
| 22                     | Ethernet RMII specific        |
| 30                     | Reserved                      |
| 31                     | Reserved                      |
| 32                     | Reserved                      |

**Table 5-44. Boot Peripheral Selection (continued)**

| Peripheral Field Value | Description         |
|------------------------|---------------------|
| 40                     | I2C                 |
| 50                     | SPI                 |
| 60                     | UART                |
| 70                     | USB DFU             |
| 71                     | USB Reserved        |
| 72                     | USB Host MSC        |
| 80                     | QSPI                |
| 85                     | OSPI                |
| 90                     | Reserved            |
| 100                    | MMCS Card (general) |
| 101                    | eMMC (general)      |
| 102                    | MMC 1-bit           |
| 103                    | MMC 4-bit           |
| 104                    | MMC 8-bit           |
| 110                    | GPMC NOR            |
| 120                    | Reserved            |
| 130                    | xSPI                |
| 140                    | GPMC NAND           |

### 5.6.2 PLL Setup

Table 5-45 through Table 5-49 describe the PLL configuration fields.

**Table 5-45. Boot Parameter Table PLL Configuration**

| Byte Offset | Size (bytes) | Name                               | Description                                                                                                      |
|-------------|--------------|------------------------------------|------------------------------------------------------------------------------------------------------------------|
| 0           | 1            | Domain/cfg                         | See Table 5-46                                                                                                   |
| 1           | 1            | PLL number                         | PLL number indexed from 0.                                                                                       |
| 2           | 1            | Input source                       | See Table 5-48                                                                                                   |
| 3           | 1            | PLL Type                           | This field must be 1 to indicate an SCPLL                                                                        |
| 4           | 4            | Input Ref Clock                    | The PLL input clock, in Q16.16 format                                                                            |
| 8           | 4            | Feed back divider, integer part    | Integer value of feedback divider                                                                                |
| 12          | 4            | Feed back divider, fractional part | Fractional portion of feedback divider. Total divider is the Integer part + (Fractional part / 2 <sup>24</sup> ) |
| 16          | 1            | Ref divider                        | Input clock pre-divider                                                                                          |
| 17          | 1            | Post divider 1                     | Output post divider 1                                                                                            |
| 18          | 1            | Post divider 2                     | Output post divider 2                                                                                            |
| 19          | 1            | Reserved                           | Reserved                                                                                                         |
| 20          | 2            | Hsdiv Enable                       | Bit map. A set bit indicates that the corresponding hsdiv is enabled.                                            |
| 22          | 2            | Reserved                           | Reserved                                                                                                         |
| 24          | 16           | Hsdiv[16]                          | Array of hs divider values.                                                                                      |

**Table 5-46. PLL Domain and Enable Configuration**

|          |   |        |   |          |   |   |        |
|----------|---|--------|---|----------|---|---|--------|
| 7        | 6 | 5      | 4 | 3        | 2 | 1 | 0      |
| Reserved |   | Enable |   | Reserved |   |   | Domain |

**Table 5-47. PLL Domain and Enable Field Description**

| Field  | Value | Description        |
|--------|-------|--------------------|
| Enable | 0     | PLL not configured |

**Table 5-47. PLL Domain and Enable Field Description (continued)**

| Field  | Value | Description                                                                                                   |
|--------|-------|---------------------------------------------------------------------------------------------------------------|
| Enable | 1     | PLL enabled only if currently disabled or in bypass                                                           |
|        | 2     | PLL is unconditionally enabled. If currently enabled with a different configuration the PLL is first disabled |
|        | 3     | PLL is unconditionally disabled                                                                               |
| Domain | 0     | PLL is in the MCU domain                                                                                      |
|        | 1     | PLL is in the MAIN domain                                                                                     |

**Table 5-48. PLL Reference Source Bit Fields**

| 7           | 6 | 5 | 4 | 3            | 2 | 1 | 0 |
|-------------|---|---|---|--------------|---|---|---|
| Source Type |   |   |   | Source Index |   |   |   |

**Table 5-49. PLL Reference Source Field Description**

| Field        | Value | Description                                                                                                                                                                        |
|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source Type  | 0     | Source is HFOSC                                                                                                                                                                    |
|              | 1     | Source is external pin                                                                                                                                                             |
|              | 2     | Reserved                                                                                                                                                                           |
|              | 3-7   | Reserved                                                                                                                                                                           |
| Source Index | 0-31  | Source index (HFOSC[0-31] or pin[0-31], depending on Source Type)<br>HFOSC[0] – WKUP_HFOSC0<br>PIN[1] – EXT_REFCLK1 pin (not all PLLs, see <a href="#">Section 6.4, Clocking</a> ) |

### 5.6.3 OSPI/QSPI/SPI Boot Parameter Table

[Table 5-50](#) shows the boot parameter table for OSPI, QSPI, or SPI boot. Must be preceded with the common boot parameters described in [Table 5-43](#).

**Table 5-50. OSPI/QSPI/SPI Boot Parameter Table**

| Byte Offset | Size (bytes) | Name           | Default Value            | Description                                                                                                     |
|-------------|--------------|----------------|--------------------------|-----------------------------------------------------------------------------------------------------------------|
| 256         | 1            | Port           | 0                        | Physical port number                                                                                            |
| 257         | 1            | Mode on        | From Pins                | If non-zero, the mode byte will be sent                                                                         |
| 258         | 1            | Instruct Width | From Pins                | Number of pins used to send instructions (1, 2, 4, 8)                                                           |
| 259         | 1            | Address Width  | From Pins                | Number of pins used to send address (1, 2, 4, 8)                                                                |
| 260         | 1            | Data Width     | From Pins                | Number of pins used to received data (1, 2, 4, 8)                                                               |
| 261         | 1            | Address Size   | 24                       | 24, and 32 bits are the valid address sizes                                                                     |
| 262         | 1            | Mode           | 0                        | OSPI clock polarity and phase mode                                                                              |
| 263         | 1            | CSEL           | From Pins                | Chip select number (0–3)                                                                                        |
| 264         | 1            | Read Cmd       | From Pins                | Command used to read read data                                                                                  |
| 265         | 1            | Mode byte      | 0                        | Value used for the mode byte (when active)                                                                      |
| 266         | 1            | Dummy Cycles   | From pins                | Number of dummy cycles sent after the read command                                                              |
| 267         | 1            | clkRecovery    | From pins                | Clock recovery                                                                                                  |
| 268         | 1            | dqsEnable      | 0                        | Enable DQS                                                                                                      |
| 269         | 1            | Reserved       | 0                        | Reserved                                                                                                        |
| 270         | 2            | Module Freq    | 0                        | The OSPI module frequency after PLL enable, in kHz. If 0, ROM code uses the value from the module clock tables. |
| 272         | 4            | Bus Frequency  | From pins                | The OSPI bus frequency, in kHz                                                                                  |
| 276         | 4            | Delay          | 0x08080808 or 0x01010101 | The chip select read delays. Default value is based on the read command                                         |

**Table 5-50. OSPI/QSPI/SPI Boot Parameter Table (continued)**

| Byte Offset | Size (bytes) | Name         | Default Value            | Description                                                                                                                                            |
|-------------|--------------|--------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 280         | 4            | Tap Delay    | 0xFFFFFFFF               | The read tap selection. If 0xFFFFFFFF, the ROM code will scan the taps to find the best delay. The result will then overwrite the value in this table. |
| 284         | 4            | Internal Clk | From pins                | 0 = external (dqs) 1 = internal                                                                                                                        |
| 288         | 4            | notDAC       | From pins                | When 0, DAC mode is used                                                                                                                               |
| 292         | 4            | Read Index   | 0                        | Index to the active read address (0-1)                                                                                                                 |
| 296         | 4            | Read Addr 0  | 0x000000                 | The initial flash read address                                                                                                                         |
| 300         | 4            | Read Addr 1  | 0x400000<br>(0x4000 SPI) | Backup read address                                                                                                                                    |
| 304         | 4            | Reserved     | 0                        | Reserved                                                                                                                                               |
| 308         | 4            | Reserved     | 0                        | Reserved                                                                                                                                               |

#### 5.6.4 UART Boot Parameter Table

Table 5-51 shows the boot parameter table for UART boot. Must be preceded with the common boot parameters described in [Table 5-43](#).

**Table 5-51. UART Boot Parameter Table**

| Byte Offset | Size (bytes) | Name            | Default Value | Description                               |
|-------------|--------------|-----------------|---------------|-------------------------------------------|
| 256         | 1            | Magic           | 0x49          | Required Magic value                      |
| 257         | 1            | Protocol        | 63 (0x3F)     | Specifies the transfer protocol = XMODEM  |
| 258         | 2            | Reserved        | 0             | Reserved                                  |
| 260         | 1            | Max error Count | 10            | Error count resulting in boot abort       |
| 261         | 1            | Ack timeout     | 3             | Timeout in seconds on ack                 |
| 262         | 1            | Char timeout    | 20            | Inter-character timeout in milliseconds   |
| 263         | 1            | Reserved        | 0             | Reserved                                  |
| 264         | 4            | Port            | From Pins     | Physical port number                      |
| 268         | 4            | Mod Ref Clk     | 48000         | Module reference clock, in kHz            |
| 272         | 4            | Data Rate       | 115200        | Baud rate (bps)                           |
| 276         | 1            | Parity          | 0             | 0=none, 1=odd, 2=even                     |
| 277         | 1            | Data bits       | 8             | Only 8 data bit width is supported        |
| 278         | 1            | Stop bits       | 2             | Stop bits in Q7.1 format (2 = 1 stop bit) |
| 279         | 1            | Flow Control    | 0             | 0=none, 1= RTS/CTS                        |
| 280         | 1            | Over sample     | 16            | Only 16x and 13x oversample are supported |
| 281         | 1            | Magic 2         | 0xB7          | Required magic value                      |

#### 5.6.5 I2C Boot Parameter Table

Table 5-52 shows the boot parameter table for I2C boot. Must be preceded with the common boot parameters described in [Table 5-43](#).

**Table 5-52. I2C Boot Parameter Table**

| Byte Offset | Size (bytes) | Name     | Default Value | Description                                 |
|-------------|--------------|----------|---------------|---------------------------------------------|
| 256         | 1            | Port     | 0             | Physical port number                        |
| 257         | 1            | Mode     | From Pins     | 0x4E = I2C Controller, 0x72 = I2C target    |
| 258         | 1            | Dev Addr | From Pins     | I2C address when target mode (0x10 or 0x11) |
| 259         | 1            | Reserved | 0             | Reserved                                    |

**Table 5-52. I2C Boot Parameter Table (continued)**

| Byte Offset | Size (bytes) | Name          | Default Value | Description                                                                                                                                    |
|-------------|--------------|---------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 260         | 4            | Mod Clock     | 0             | I2C Module input clock. If 0, it is computed by ROM code.                                                                                      |
| 264         | 2            | Bus Freq      | 400           | I2C Controller mode bus frequency, in kHz                                                                                                      |
| 266         | 2            | Bus Addr      | From Pins     | I2C Controller mode storage device's address (0x50 or 0x51)                                                                                    |
| 268         | 2            | Read Index    | 0             | Index to the active read offset (0 or 1)                                                                                                       |
| 270         | 2            | Read Offset 0 | 0x0000        | I2C Controller mode read offset                                                                                                                |
| 272         | 2            | Read Offset 1 | 0x8000        | I2C Controller mode backup read offset                                                                                                         |
| 274         | 2            | Reserved      | 0             | Reserved                                                                                                                                       |
| 276         | 2            | Reserved      | 0             | Reserved                                                                                                                                       |
| 280         | 2            | Busy Timeout  | From pins     | Number of $\mu$ s before a bus recovery is attempted. In units of microseconds in Q3 number format. Value of 0 disables bus recovery attempts. |

### 5.6.6 MMCSD/eMMC Boot Parameter Table

MMCSd/eMMC Boot Parameter Table shows the boot parameter table for eMMC, MMC or SD card boot. Must be preceded with the common boot parameters described in [Table 5-43](#).

**Table 5-53. MMCSd/eMMC Boot Parameter Table**

| Byte Offset | Size (bytes) | Name         | Default Value                        | Description                                                                                                                   |
|-------------|--------------|--------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 256         | 1            | Port         | From Pins                            | Physical port number                                                                                                          |
| 257         | 1            | eMMC         | From Pins                            | 0 = SD/MMC, else eMMC                                                                                                         |
| 258         | 1            | bootAck      | 1 for eMMC<br>0 for SD/MMC           | If 1 and in eMMC mode the controller expects a boot ack from the eMMC                                                         |
| 259         | 1            | Media        | 1 for eMMC<br>0 for SD/MMC<br>2 = SD | 0 = auto detect card type<br>1 = MMC<br>2 = SD                                                                                |
| 260         | 1            | busWidth     | 8 for eMMC<br>From Pins for SD/MMC   | Number of data pins (1, 4, or 8). If 0, max supported pins of the port are used.                                              |
| 261         | 1            | bootAlt      | 1 for eMMC<br>0 for SD/MMC           | If 1 and in eMMC mode, the controller uses the alt boot method (CMD1 with arg 0xFFFF_FFFA) to initiate data transfer          |
| 262         | 1            | sigVolt      | 0x18 for port0<br>0x33 for port1     | Sets the signal voltage for the controller.<br>0x18 = 1.8V<br>0x33 = 3.3V                                                     |
| 263         | 1            | Reserved     | 0                                    | Reserved                                                                                                                      |
| 264         | 4            | Max Bus Freq | 0                                    | Max bus frequency in kHz. If 0, the value is determined by reading the CSD register from the card (still maxes out at 25 MHz) |
| 268         | 4            | refClkkHz    | 0                                    | Module reference clock frequency, in kHz. If 0, the ROM code computes the value.                                              |
| 272         | 4            | respTimeout  | 40000                                | The timeout period on initial card read, in milli-seconds, Q3 number format                                                   |
| 276         | 128          | Filename     | "\tiboot3.bin"                       | For SD/MMC, boot filename in 16-bit Unicode characters (max 64)                                                               |
| 404         | 4            | Mode         | 0x1144D091                           | 0x1144D091 = file system boot<br>0x1144C180 = raw image boot                                                                  |
| 408         | 4            | CardIsInit   | 0                                    | 0 = card not yet initialized<br>1 = card has been initialized                                                                 |
| 412         | 4            | Rsvd         | 0                                    | Reserved                                                                                                                      |
| 416         | 4            | RawIndex     | 0                                    | Current active read offset (0 or 1)                                                                                           |

**Table 5-53. MMCSD/eMMC Boot Parameter Table (continued)**

| Byte Offset | Size (bytes) | Name         | Default Value | Description            |
|-------------|--------------|--------------|---------------|------------------------|
| 420         | 4            | Rsvd         | 0             | Reserved               |
| 424         | 4            | Raw Offset 0 | 0x000000      | Raw read offset        |
| 428         | 4            | Raw Offset 1 | 0x400000      | Backup raw read offset |
| 432         | 4            | Rsvd         | 0             | Reserved               |
| 436         | 4            | Rsvd         | 0             | Reserved               |

### 5.6.7 Ethernet Boot Parameter Table

Table 5-54 is shown segmented into four sections:

1. The first section contains information required to configure the device hardware
2. The second section contains information used by the top level Ethernet module to execute the boot
3. The third section contains information for the Ethernet stack code.
4. The fourth section contains information for creating the BOOTP packet (vendor string, ID string and debug string), and holds information returned in the BOOTP response (Default route and file name)

Table 5-54 shows the boot parameter table for Ethernet boot. Must be preceded with the common boot parameters described in Table 5-43.

**Table 5-54. Ethernet Boot Parameter Table**

| Byte Offset                    | Size (bytes) | Name             | Default Value | Description                                                                                                                                             |
|--------------------------------|--------------|------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardware Configuration Options |              |                  |               |                                                                                                                                                         |
| 256                            | 2            | Mod Freq         | 0             | Module clock frequency, kHz. If 0, ROM code computes the value.                                                                                         |
| 258                            | 1            | Port Num         | 0             | Physical port number                                                                                                                                    |
| 259                            | 1            | Interface        | From Pins     | 0 = RGMII with internal delay<br>1 = RGMII with external delay<br>2 = RMII                                                                              |
| 260                            | 1            | Init Level       | 0             | 0 = Initialize only not enabled modules<br>1 = Full ethernet sub-system initialization                                                                  |
| 261                            | 1            | Clock out enable | From pins     | 0x10 = CLKOUT0 enable<br>0x11 = CLKOUT0 disable                                                                                                         |
| 262                            | 1            | Clk out freq     | From pins     | 0x20 = CLKOUT0 25 MHz (RGMII)<br>0x21 = CLKOUT0 50 MHz (RMII)                                                                                           |
| 263                            | 1            | RMII Clk In      | From pins     | 0x60 = RMII internal (SoC) clock<br>0x61 = RMII external clock                                                                                          |
| 264                            | 1            | Port Enable      | 0x01          | Bit map. A set bit indicates that the corresponding physical port will be enabled                                                                       |
| 265                            | 1            | Phy Query        | From pins     | 0x30 = speed/duplex determined from RGMII status register<br>0x31 = MDIO used to query PHY<br>0x32 = Use fixed speed/duplex values from offset 266/267. |
| 266                            | 1            | Speed            |               | 0x40 = full speed (1Gbit for RGMII, 100Mbit for RMII)<br>0x41 = slow speed (100Mbit for RGMII, 10Mbit for RMII)                                         |
| 267                            | 1            | Duplex           |               | 0x50 = full duplex<br>0x51 = half duplex                                                                                                                |
| Main Level Boot Control        |              |                  |               |                                                                                                                                                         |
| 268                            | 1            | Bootp enable     | 1             | 0 = Image information already in this structure<br>1 = Use BOOTP to get boot image information                                                          |
| 269                            | 1            | Reserved         | 0             | Reserved                                                                                                                                                |
| 270                            | 2            | Bootp Timeout    | 4000          | BOOTP timeout in milli-seconds                                                                                                                          |
| 272                            | 2            | TFTP timeout     | 1000          | TFTP timeout in milli-seconds                                                                                                                           |
| 274                            | 2            | Bootp retries    | 10            | Number of BOOTP retries before fail                                                                                                                     |

**Table 5-54. Ethernet Boot Parameter Table (continued)**

| Byte Offset                                       | Size (bytes) | Name           | Default Value               | Description                                                  |
|---------------------------------------------------|--------------|----------------|-----------------------------|--------------------------------------------------------------|
| 276                                               | 2            | TFTP retries   | 10                          | Number of TFTP retries before fail                           |
| 278                                               | 2            | Reserved       | 0                           | Reserved                                                     |
| Network Stack Configuration (plus TFTP server ID) |              |                |                             |                                                              |
| 280                                               | 6            | MAC Address    | From E-fuse                 | MAC address of the device                                    |
| 286                                               | 2            | Reserved       | 0                           | Reserved                                                     |
| 288                                               | 4            | Device IP      | 0                           | IP address of the device. Valid only if BOOTP not enabled    |
| 292                                               | 4            | Net Mask       | 0                           | Net mask. Valid only if BOOTP not enabled                    |
| 296                                               | 4            | Tftp server IP | 0                           | TFTP server IP. Valid only if BOOTP not enabled              |
| BOOTP send and receive Information                |              |                |                             |                                                              |
| 300                                               | 20           | Vendor String  | "TI K3 Bootp Boot"          | BOOTP request vendor string. Valid only if BOOTP not enabled |
| 320                                               | 9            | Client ID      | 1-mac-address-0             | Client ID. See <a href="#">RFC1700</a>                       |
| 329                                               | 1            | ID len         | 7                           | Client ID length                                             |
| 330                                               | 45           | Debug array    | SOC ID up to size available | Debug array output                                           |
| 375                                               | 1            | Debug len      | Varies                      | The number of valid bytes in debug array                     |
| 376                                               | 4            | Next hop       | 0                           | Next hop IP address. Valid only if bootp not enabled         |
| 380                                               | 4            | Default Route  | 0                           | IP default route IP address. Valid only if bootp not enabled |
| 384                                               | 128          | Boot filename  | 0                           | Boot filename. Valid only if bootp not enabled               |

### 5.6.8 xSPI Boot Parameter Table

xSPI Boot Parameter Table shows the boot parameter table for xSPI boot. Must be preceded with the common boot parameters described in [Table 5-43](#).

**Table 5-55. xSPI Boot Parameter Table**

| Byte Offset | Size (bytes) | Name           | Default Value            | Description                                                                                                     |
|-------------|--------------|----------------|--------------------------|-----------------------------------------------------------------------------------------------------------------|
| 256         | 1            | Port           | 0                        | Physical port number                                                                                            |
| 257         | 1            | Mode on        | From Pins                | If non-zero, the mode byte will be sent                                                                         |
| 258         | 1            | Instruct Width | From Pins                | Number of pins used to send instructions (1, 8)                                                                 |
| 259         | 1            | Address Width  | From Pins                | Number of pins used to send address (1, 8)                                                                      |
| 260         | 1            | Data Width     | From Pins                | Number of pins used to received data (1, 8)                                                                     |
| 261         | 1            | Address Size   | 24                       | 24 and 32 bits are the valid address sizes                                                                      |
| 262         | 1            | Mode           | 0                        | QSPI clock polarity and phase mode                                                                              |
| 263         | 1            | CSEL           | From Pins                | Chip select number (0-3)                                                                                        |
| 264         | 1            | Read Cmd       | From Pins                | Command used to read read data                                                                                  |
| 265         | 1            | Mode byte      | 0                        | Value used for the mode byte (when active)                                                                      |
| 266         | 1            | Dummy Cycles   | From pins                | Number of dummy cycles sent after the read command                                                              |
| 267         | 1            | clkRecovery    | From pins                | Clock recovery                                                                                                  |
| 268         | 1            | dqsEnable      | 0                        | Enable DQS                                                                                                      |
| 269         | 1            | ddrEnable      | From pins                | OSPI DDR mode operation                                                                                         |
| 270         | 2            | Module Freq    | 0                        | The QSPI module frequency after PLL enable, in kHz. If 0, ROM code uses the value from the module clock tables. |
| 272         | 4            | Bus Frequency  | From pins                | The QSPI bus frequency, in kHz                                                                                  |
| 276         | 4            | Delay          | 0x08080808 or 0x01010101 | The chip select read delays. Default value is based on the read command                                         |
| 280         | 1            | SFDP           | From Pins                | Enables SFDP parser for 1S-1S-1S to 8D-8D-8D switching                                                          |

**Table 5-55. xSPI Boot Parameter Table (continued)**

| Byte Offset | Size (bytes) | Name         | Default Value | Description                                                                                                                                            |
|-------------|--------------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 282         | 4            | Tap Delay    | 0xFFFFFFFF    | The read tap selection. If 0xFFFFFFFF, the ROM code will scan the taps to find the best delay. The result will then overwrite the value in this table. |
| 286         | 4            | Internal Clk | From pins     | 0 = external (dqs) 1 = internal                                                                                                                        |
| 290         | 4            | inDAC        | From pins     | When 0, XIP mode is used                                                                                                                               |
| 294         | 4            | Read Index   | 0             | Index to the active read address                                                                                                                       |
| 298         | 4            | Read Addr 0  | 0x000000      | The initial flash read address                                                                                                                         |
| 302         | 4            | Read Addr 1  | 0x400000      | Backup read address                                                                                                                                    |

**5.6.9 USB DFU Boot Parameter Table**

[USB DFU Boot Parameter Table](#) shows the boot parameter table for USB DFU boot. Must be preceded with the common boot parameters described in [Table 5-43](#).

**Table 5-56. USB DFU Boot Parameter Table**

| Byte Offset | Size (bytes) | Name                     | Default Value    | Description                                             |
|-------------|--------------|--------------------------|------------------|---------------------------------------------------------|
| 256         | 4            | Port                     | From pins        | Physical port number. Always set to 0.                  |
| 260         | 4            | Base address 0           | From pins (port) | Base address of USB subsystem (CMN)                     |
| 264         | 4            | Base address 1           | From pins (port) | Base address of controller                              |
| 268         | 4            | phyBaseAddress           | From pins (port) | Base address of USB PHY module                          |
| 272         | 4            | modRefClkkHz             | varies           | Module reference clock, in kHz                          |
| 276         | 2            | Vendor ID                | 0x0451           | USB vendor ID. Read from control registers.             |
| 278         | 2            | Product ID               | 0x6165           | USB product ID. Read from control registers.            |
| 280         | 2            | BCD Device               | 0x200            | Binary Coded Decimal device release number              |
| 284         | 4            | String Table addr        | 0x4182A76C       | Pointer to the string table in RAM                      |
| 288         | 2            | Vendor String offset     | 0                | Offset to vendor string in string table                 |
| 290         | 2            | Prod string offset       | 32               | Offset to product string in string table                |
| 292         | 2            | Serial num string offset | 64               | Offset to serial number string in string table          |
| 294         | 2            | Timeout                  | 5000             | USB timeout in milliseconds                             |
| 296         | 2            | Mode                     | 1                | 1 = DFU<br>#1 = MSC Mode 1 = backup DFU, 2 = backup MSC |
| 298         | 1            | Lane reverse             | From pins        | Set to non-zero for lane reverse                        |
| 299         | 1            | CoreVoltage              | From pins        | USB Core Voltage<br>0 = 0.85V, 1 = 0.75V                |
| 300         | 4            | Block Size               | 4096             | DFU Block Size                                          |

**5.6.10 USB MSC Boot Parameter Table**

[USB MSC Boot Parameter Table](#) shows the boot parameter table for USB boot. Must be preceded with the common boot parameters described in [Table 5-43](#).

**Table 5-57. USB MSC Boot Parameter Table**

| Byte Offset | Size (bytes) | Name           | Default Value    | Description                            |
|-------------|--------------|----------------|------------------|----------------------------------------|
| 256         | 4            | Port           | From pins        | Physical port number. Always set to 0. |
| 260         | 4            | Base address 0 | From pins (port) | Base address of USB subsystem (CMN)    |
| 264         | 4            | Base address 1 | From pins (port) | Base address of controller             |
| 268         | 4            | phyBaseAddress | From pins (port) | Base address of USB PHY module         |
| 272         | 4            | modRefClkkHz   | varies           | Module reference clock, in kHz         |

**Table 5-57. USB MSC Boot Parameter Table (continued)**

| Byte Offset | Size (bytes) | Name                     | Default Value | Description                                             |
|-------------|--------------|--------------------------|---------------|---------------------------------------------------------|
| 276         | 2            | Vendor ID                | 0x0451        | USB vendor ID. Read from control registers.             |
| 278         | 2            | Product ID               | 0x6164        | USB product ID. Read from control registers.            |
| 280         | 2            | BCD Device               | 0             | Binary Coded Decimal device release number              |
| 284         | 4            | String Table addr        | 0x4182BCA8    | Pointer to the string table in RAM                      |
| 288         | 2            | Vendor String offset     | 0             | Offset to vendor string in string table                 |
| 290         | 2            | Prod string offset       | 0             | Offset to product string in string table                |
| 292         | 2            | Serial num string offset | 0             | Offset to serial number string in string table          |
| 294         | 2            | Timeout                  | 5000          | USB timeout in milliseconds                             |
| 296         | 2            | Mode                     | 1             | 1 = DFU<br>#1 = MSC Mode 1 = backup DFU, 2 = backup MSC |
| 298         | 1            | Lane reverse             | From pins     | Set to non-zero for lane reverse                        |
| 299         | 1            | CoreVoltage              | From pins     | USB Core Voltage<br>0 = 0.85V, 1 = 0.75V                |
| 300         | 64           | FileName                 | tiboot3.bin   | Boot file name                                          |

### 5.6.11 GPMC NOR Boot Parameter Table

Table 5-58 shows the boot parameter table for GPMC NOR boot. Must be preceded with the common boot parameters described in Table 5-43.

**Table 5-58. GPMC NOR Boot Parameter Table**

| Byte Offset | Size (bytes) | Name          | Default Value | Description                                                                               |
|-------------|--------------|---------------|---------------|-------------------------------------------------------------------------------------------|
| 256         | 4            | refClkkHz     | 0             | The module functional clock frequency, in kHz. 0 = ROM code computes the value.           |
| 260         | 4            | csSizeMb      | 64            | The size of each chip-select, in MB                                                       |
| 264         | 1            | Csel          | From pins     | The chip-select to use (0-3)                                                              |
| 265         | 1            | adMux         | From pins     | The address/data multiplexing used.<br>0 = A/D parallel,<br>1 = A/A/D mux,<br>2 = A/D mux |
| 266         | 1            | Width         | 16            | Data bus width                                                                            |
| 267         | 1            | Reserved      | 0             | Reserved                                                                                  |
| 268         | 4            | Read index    | 0             | The currently active read offset (0-1)                                                    |
| 272         | 4            | Read offset 0 | 0x000000      | Read address offset 0                                                                     |
| 276         | 4            | Read offset 1 | 0x400000      | Backup read address offset 1                                                              |
| 280         | 4            | Reserved      | 0             | Reserved                                                                                  |
| 284         | 4            | Reserved      | 0             | Reserved                                                                                  |

### 5.6.12 GPMC NAND Boot Parameter Table

GPMC NAND Boot Parameter Table shows the boot parameter table for GPMC NAND boot. Must be preceded with the common boot parameters described in Table 5-43.

**Table 5-59. GPMC NAND Boot Parameter Table**

| Byte Offset | Size (bytes) | Name        | Default Value | Description                     |
|-------------|--------------|-------------|---------------|---------------------------------|
| 256         | 4            | Ref Clk kHz | From pins     | Specifies the module ref clock. |
| 260         | 4            | Page Size   | 0             | Page size in bytes 2048 or 4096 |
| 264         | 1            | Chip Select | 0             | Chip Select                     |
| 265         | 1            | Ad Mux      | 0             | Address/data multiplexing       |

**Table 5-59. GPMC NAND Boot Parameter Table (continued)**

| Byte Offset | Size (bytes) | Name                | Default Value | Description                                                |
|-------------|--------------|---------------------|---------------|------------------------------------------------------------|
| 266         | 1            | Data Bus Width      | 8             | Data bus width. Valid values are 8 and 16                  |
| 267         | 1            | AD rows             | 0             | Number of Row address                                      |
| 268         | 1            | AD columns          | 0             | Number of Column address cycles                            |
| 269         | 1            | ECC Nibbles         | 0             | Size of BCH remainder in nibbles. 0 if no ECC, 26 for BCH8 |
| 270         | 2            | Current Valid Block | 0xFFFF        | Block number of last known good block                      |
| 272         | 2            | Pages per Block     | 0             | Number of pages in a block                                 |
| 274         | 2            | Reserved            | 0             | Reserved                                                   |
| 276         | 4            | Current Read Index  | 0             | Active read index                                          |
| 280         | 4            | Read Offset[0]      | 0             | Offsets from base of GPMC NAND memory                      |
| 284         | 4            | Read Offset[1]      | 0x400000      | Offsets from base of GPMC NAND memory                      |

## 5.7 Boot Image Format

### 5.7.1 Overall Structure

The boot image consists of an X.509 Certificate, which is optional for GP devices, followed immediately by a boot image blob.



### 5.7.2 X.509 Certificate

The X.509 certificate is described in [RFC5280](#). Section 4.1 of the specification describes the format.

The X.509 fields relevant to the public boot (taken from RFC5280) are shown below.

```

Certificate ::= SEQUENCE {
    tbsCertificate      TBSCertificate,
    signatureAlgorithm  AlgorithmIdentifier,
    signatureValue      BIT STRING }

TBSCertificate ::= SEQUENCE {
    version            [0] EXPLICIT Version DEFAULT v1,
    serialNumber       CertificateSerialNumber,
    signature          AlgorithmIdentifier,
    issuer             Name,
    validity           Validity,
    subject            Name,
    subjectPublicKeyInfo SubjectPublicKeyInfo,
    issuerUniqueID     [1] IMPLICIT UniqueIdentifier OPTIONAL,
                        -- If present, version MUST be v2 or v3
    subjectUniqueID    [2] IMPLICIT UniqueIdentifier OPTIONAL,
                        -- If present, version MUST be v2 or v3
    extensions         [3] EXPLICIT Extensions OPTIONAL
                        -- If present, version MUST be v3
}
Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension
Extension ::= SEQUENCE {
    extnID            OBJECT IDENTIFIER,
    critical          BOOLEAN DEFAULT FALSE,
    extnValue         OCTET STRING
                        -- contains the DER encoding of an ASN.1 value
                        -- corresponding to the extension type identified
                        -- by extnID
}
  
```

In general, an X.509 certificate contains a public key which has been signed by a private key. The public ROM code does not directly use the keys. In non-secure devices, the public key value is in general a don't care condition. The exception is certificates containing a degenerate RSA public key. GP devices with a degenerate RSA key allow for integrity checking of most (but not all) of the certificate.

The public ROM only needs to extract some of information from the X.509 formatted structure:

- The total size of the X.509 Certificate
- The total size of the boot image

The total size of the X.509 Certificate is determined by reading the length of the sequence containing the certificate. The length of the image is determined by parsing the certificate to find the extension field which holds the image length.

The ROM defines several extensions that are used only by TI for boot. These are placed in the extensions field of the TBS certificate.

### 5.7.3 Organizational Identifier (OID)

OID (organizational identifier) values are represented as a tree structure. TI has the following node registered:

1.3.6.1.4.1.294: *iso(1), identified-organization(3), dod(6), internet(1), private(4), enterprise(1), Texas Instruments(294)*

ROM code adds the following branch after *Texas Instruments: device-boot(1)*. The OID values shown in this section are leaves off the device boot branch.

#### 5.7.4 X.509 Extensions Specific to Boot

These values are not defined in any standard, but created by TI for boot.

##### 5.7.4.1 Boot Info (OID 1.3.6.1.4.1.294.1.1)

This extension must be present on all boot images. It is from this extension that the image length is extracted.

```
bootInfo ::= SEQUENCE {
  cert_type: INTEGER,-- identifies the certificate type
  boot_core:INTEGER,-- identifies the boot core
  core_opts:INTEGER,-- 32 or 64 bit boot core target
  load_addr:OCTET STRING,-- Global address image destination
  image_size:INTEGER,-- Image size in bytes
}
```

**Table 5-60. Certificate Type Values**

| Value       | Description        |
|-------------|--------------------|
| 0x0000_0001 | Primary boot image |
| 0x0000_0002 | Firmware image     |

**Table 5-61. Boot Core Values**

| Value | Description         |
|-------|---------------------|
| 0x00  | Firmware (M4) image |
| 0x08  | M4 certificate      |
| 0x10  | R5 image            |
| 0x20  | Reserved            |

**Table 5-62. Core Options Bit Fields**

|          |  |       |   |      |
|----------|--|-------|---|------|
| 31       |  | 2     | 1 | 0    |
| Reserved |  | Split |   | Mode |

**Table 5-63. Core Options Field Description**

| Bits | Field | Value | Description                                        |
|------|-------|-------|----------------------------------------------------|
| 1    | Split | 0     | Dual MCU set to lockstep (two cores in lockstep)   |
|      |       | 1     | Dual MCU set to split mode (two independent cores) |
| 0    | Mode  | 0     | MCU starts execution in Arm® mode                  |
|      |       | 1     | MCU starts execution in Thumb® mode                |

##### 5.7.4.2 Image Integrity (OID 1.3.6.1.4.1.294.1.2)

```
imageIntegrity ::= SEQUENCE {
  sha_type:OID,-- Identifies the SHA type
  hash:OCTET STRING-- The SHA of the boot image
}
```

#### 5.7.5 Extended Boot Info Extension

The ROM supports a combined boot image boot flow. In this flow, a boot binary blob has both Secondary bootloader (SBL) and System Firmware (SYS-FW) embedded in the boot image with a single X509 certificate. This method helps with the following situations:

- Allows ROM to load and run both the bootloader and SYS-FW in parallel without any dependency.
- Optimizes ROM boot time by minimizing different x509 certificate parsing and authentication.

To support this combined boot format, ROM employs a new X509 extension called: ext\_boot\_info. It supports multiple boot components with a single certificate. It allows up to 5 components as part of this extension:

- Component1: Mandatory and should point to info about SBL binary
- Component2: Optional and if present should point to SYS-FW binary in all device types
- Component3: Optional (Load section to SBL, new certType)
- Component4: Optional (Load section to SYS-FW, new certType)
- Component5:
  - HS-FS and HS-SE non Prime devices. Mandatory and should point to SYS-FW Inner certificate
  - GP and HS-SE Prime devices. Optional (Load Section to SBL or SYS-FW)

This extended boot info extension replaces boot\_seq (boot\_info) and image\_integrity extensions from the previous sections, and these should be exclusive in any given certificate.

ROM supports other extensions, such as sw\_rev and debug\_info, in both formats.

ROM selects the combined image flow based on the presence of ext\_boot\_info extension in the certificate and skips boot\_seq (boot\_info) and image\_integrity extensions boot flow.

Having one component in ext\_boot\_info is same as legacy flow (that is, flow using boot\_seq and image\_integrity); for two or more components, ROM starts both SBL and SYS-SW, the third and fourth components are loaded by ROM to the allowed loading memory range of SBL and SYS-FW if there is no overlap in load address with executable binary info.

Each of the components can independently specify hash value of the binary, and ROM validates the hash on HS and GP if RSA degenerate key is used for signing.

Additionally, ROM rejects the full image if hash of any single component mismatches.

#### 5.7.5.1 Impact on HS Device

For HS devices, ROM supports encryption of images optionally when specified with the Encryption extenstion.

Encryption - Encryption of the components must be specified with a new extension called ext\_boot\_enc. This is an optional extension that must be specified only if any of the components are encrypted with a customer key set. Specify a component number followed by encryption extension details for ROM to decrypt the given components. This extension is used only with combined boot image format (that is, using Extended Boot Info Extension).

Prime vs Non-Prime - The main difference between HS prime and non-prime devices is the presence of the SYS-FW Inner certificate. Extended boot info extension supports both prime and non-prime devices. ROM supports SYS-FW binary as Comp#2 in all device types; for HS-SE non-prime and HS-FS devices, the SYS-FW inner certificate is expected as another optional component in #3, 4, or 5.

#### 5.7.5.2 Extended Boot Info Details

```

1.3.6.1.4.1.294.1.9=ASN1:SEQUENCE:ext_boot_info
[ ext_boot_info ]
extImgSize = INTEGER:470656
numComp = INTEGER:4
sbl=SEQUENCE:comp1
fw=SEQUENCE:comp2
bd1=SEQUENCE:comp3
bd2=SEQUENCE:comp4

[ comp1 ]
compType = INTEGER:1
bootCore = INTEGER:16
compOpts = INTEGER:0
destAddr = FORMAT:HEX,OCT:41c00000
compSize = INTEGER:237376
shaType = OID:2.16.840.1.101.3.4.2.3

```

```

shavalue =
FORMAT:HEX,OCT:6779fdb2b2c27169737c184085b97938bd77bdf698245840f166ca30c7125c29a6675139a25a0a2a3f00a
76d43d082df238c12cb6b293ec0eeb5990bcd603a23

[ comp2 ]
compType = INTEGER:2
bootCore = INTEGER:0
compOpts = INTEGER:0
destAddr = FORMAT:HEX,OCT:00040000
compSize = INTEGER:196608
shaType = OID:2.16.840.1.101.3.4.2.3
shavalue =
FORMAT:HEX,OCT:47f27fb24b81927a928845a4c2b993e6a3d5bdf5ed01c0ec4f96a7ead991c69bf4ed4b9b958fd36a75f3
3aba04d2c28602a85ca737ee75617d6a9a41f4353a3

[ comp3 ]
compType = INTEGER:18
bootCore = INTEGER:0
compOpts = INTEGER:0
destAddr = FORMAT:HEX,OCT:00072000
compSize = INTEGER:16384
shaType = OID:2.16.840.1.101.3.4.2.3
shavalue =
FORMAT:HEX,OCT:2d165ec1d8a38acb977d9298e8a6a27491c62d6daa31f921db9135f9a68779b30b384573c6e4e8203de5f
0a47191c3ff9a35b52a911874e07615f10b4b2f5829

[ comp4 ]
compType = INTEGER:17
bootCore = INTEGER:16
compOpts = INTEGER:0
destAddr = FORMAT:HEX,OCT:41c40000
compSize = INTEGER:20288
shaType = OID:2.16.840.1.101.3.4.2.3
shavalue =
FORMAT:HEX,OCT:12d5be5b2b9774d1b0cad21cbf1dbcdbd7c310657f4334902e3cc6228cf2d8fc844139dae4db6041c38cd
a502d6a900d57039322d360032268a13445021b04a7

```

### 5.7.5.3 Certificate / Component Types

ROM supports only the following component types; all other component types will be rejected.

- CompType 0x1 for SBL binary - compType = INTEGER:1
- CompType 0x2 for SYS\_FW binary - compType = INTEGER:2
- CompType 0x3 for SYS\_FW Inner Certificate - compType = INTEGER:3
- CompType 0x11 for SBL Memory load section - compType = INTEGER:17

Primary Image load section, that can be loaded in to SBL allowed memory range:

- CompType 0x12 for SYS\_FW Memory load section - compType = INTEGER:18

SYS-FW load section, that can be loaded in to SYS-FW allowed memory range

### 5.7.5.4 Extended Boot Encryption Info

Extended Boot Encryption Info specifies the imageEncryption extension per component basis. This extension is not applicable for GP or HS-FS devices, and is optional for HS-SE devices if any components in the image are encrypted. In HS-FS and HS-SE non-prime devices, the SYS-FW binary encryption details are part of SYS-FW Inner certificate. This extension is applicable if either SBL, SYS-FW binary in HS-SE prime, or any binary blobs are encrypted in HS-SE devices.

```

1.3.6.1.4.1.294.1.10=ASN1:SEQUENCE:ext_enc_info

[ ext_enc_info ]
numComp = INTEGER:2
esb1=SEQUENCE:enc1
efw=SEQUENCE:enc2

[ enc1 ]
compNum = INTEGER:1
iv = FORMAT:HEX,OCT:474bfd801866beecc7ab6d4c61490e1a
randString = FORMAT:HEX,OCT:772fc5810fa36f516e595ad8adf19260f47a8461f193892746692fbb932727a1
iterationCnt = INTEGER:0

```

```

salt = FORMAT:HEX,OCT:42ea40851298339c8baa84f29d6b68d0
[ enc2 ]
compNum = INTEGER:2
iv = FORMAT:HEX,OCT:aaaaaaaaaaabecc7ab6d4c61490e1a
randString = FORMAT:HEX,OCT:bbbbbbbbbbbbbbbe595ad8adf19260f47a8461f193892746692fbb932727a1
iterationCnt = INTEGER:2
salt = FORMAT:HEX,OCT:ccccccccccccccaa84f29d6b68d0

```

### 5.7.5.5 Component Ordering

ROM supports fixed Component ordering for SBL- Binary and SYS-FW Cert and Binary.

For GP and HS-SE Prime devices, Comp#1 should be SBL binary, and Comp#2 should be SYS-FW binary.

For HS-FS and HS-SE non-Prime devices, Comp#1 should be SBL binary, Comp#2 should be SYS-FW Inner Certificate, and Comp#3 should be SYS-FW binary.

### 5.7.5.6 Memory Load Sections Overlap with Executable Components

Memory load sections for SBL and SYS-FW (CompType 0x11 and 0x12) the destination address and size should not overlap with the corresponding load and execute sections, and should also fall in the allowed memory range by ROM.

### 5.7.5.7 Device Type and Extended Boot Extension

| X509 Extension | Component | GP Device              | HS-FS                   | HS-SE non-prime               | HS-SE Prime Device            |
|----------------|-----------|------------------------|-------------------------|-------------------------------|-------------------------------|
| ext_boot_info  | Comp#1    | SBL Binary             | SBL Binary              | SBL Binary                    | SBL Binary                    |
|                | Comp#2    | SYS-FW binary          | SYS-FW binary           | SYS-FW binary                 | SYS-FW binary                 |
|                | Comp#3    | SBL mem load section   | SBL mem load section    | SBL mem load section          | SBL mem load section          |
|                | Comp#4    | SysFW mem load section | SysFW mem load section  | SysFW mem load section        | SysFW mem load section        |
|                | Comp#5    | N/A                    | SysFW inner certificate | SysFW inner certificate       | N/A                           |
| ext_enc_info   | Comp#1    | N/A                    | N/A1                    | SBL encryption                | SBL encryption                |
|                | Comp#2    |                        |                         | N/A                           | SYS FW encryption             |
|                | Comp#3    |                        |                         | SBL memory load Encryption    | SBL memory load encryption    |
|                | Comp#4    |                        |                         | Sys-FW memory load encryption | Sys-FW memory load encryption |
|                | Comp#5    |                        |                         | N/A1                          | NA                            |

1. SYS-FW encryption in HS-FS and HS-SE (non Prime) are handled in SYS-FW Inner certificate and they are not part of the extended boot info extensions.

### 5.7.6 Generating X.509 Certificates

X.509 Certificates are generated using OpenSSL and a configuration script to supply values in the extension fields.

#### 5.7.6.1 Key Generation

The SBL must always be signed with a given OpenSSL key - Secure and GP devices. Secure must have encryption and authentication, GP device must only have authentication. The key used for authentication can be random or specific. If a random key is generated and SBL is signed with this, the ROM will copy the SBL image for authentication using memcpy. With this key, ROM code will be directed to use DMA to load the SBL for authentication which saves boot time.

### 5.7.6.1.1 Degenerate RSA Keys

Degenerate RSA keys are valid RSA keys with the private exponent set to 1. This results in the signature field being equal to the digest, since in RSA:

$$\text{Signature} = \text{digestprivExp} \bmod \text{nprivExp} \bmod n^{\text{privExp}} \quad (1)$$

Where  $n$  is the key size. Since the hash used is SHA-512 and the signature is an ASN.1 sequence containing the OID defining which has was used as well as the hash value, the degenerate RSA must have a value of  $n$  greater than the maximum digest size. Typically 1024-bit is chosen.

The following sequence is used to generate degenerate RSA keys:

1. Create a random RSA key:

```
openssl genrsa -out key.pem 1024
```

2. Convert to text:

```
openssl rsa -in key.pem -text -noout > key.txt
```

3. Create an asn1 template for the degenerate key called degenerateKey.txt. Simply copy the values for modulus, prime (listed as  $p$  in key.txt), prime 2 (listed as  $q$ ), and coefficient (listed as  $coeff$ ). Set the public and private key exponents to 1, as well as the values for  $e1$  and  $e2$ . See the example below.

4. Convert the template to DER:

```
openssl asn1parse -genconf degenerateKey.txt -out degenerateKey.der
```

5. Sanity check the key:

```
openssl rsa -in degenerateKey.der -inform der -text -check
```

6. If there are no errors create the degenerate key pem file:

```
openssl rsa -in degenerateKey.der -inform der -outform pem -out degenerateKey.pem
```

An example degenerateKey.txt file is shown.

```
asn1=SEQUENCE:rsa_key
[rsa_key]
version=INTEGER:0
modulus=INTEGER<copied from key.txt>
pubExp=INTEGER:1
privExp=INTEGER:1
p=INTEGER:<copied from key.txt>
q=INTEGER<copied from key.txt>
e1=INTEGER:1
e2=INTEGER:1
coeff=INTEGER<copied from key.txt>
```

Note that when copying the multi-byte fields from key.txt it is necessary to remove the colons, catenate the lines and add a preceding 0x.

### 5.7.6.2 Configuration Script

An example openssl configuration script is shown below. Not all extensions are required, but all possible are shown.

```
[ req ]
distinguished_name = req_distinguished_name
x509_extensions = v3_ca
prompt = no
dirstring_type = nobmp
[ req_distinguished_name ]
C = GB
ST = HI
```

```

L = Boston
O = Texas Instruments., Inc.
OU = DSP
CN = Bob
emailAddress = Bob@hou.ti.com
[ v3_ca ]
basicConstraints = CA:true
1.3.6.1.4.1.294.1.1 = ASN1:SEQUENCE:boot_seq
1.3.6.1.4.1.294.1.2 = ASN1:SEQUENCE:image_integrity
1.3.6.1.4.1.294.1.3 = ASN1:SEQUENCE:swrv
1.3.6.1.4.1.294.1.4 = ASN1:SEQUENCE:encryption
1.3.6.1.4.1.294.1.5 = ASN1:SEQUENCE:key_derivation
1.3.6.1.4.1.294.1.7 = ANSI:SEQUENCE:pllControl
1.3.6.1.4.1.294.1.8 = ANSI:SEQUENCE:debug
[ boot_seq ]
certType = INTEGER:1
bootCore = INTEGER:16
bootArchwidth = INTEGER:32
destAddr = FORMAT:HEX,OCT:bc934b00
imageSize = INTEGER:0x00004860
[ image_integrity ]
shaType = OID:1.3.14.3.2.26
shaValue = FORMAT:HEX,OCT:4cf4d59ef77b5d9ab28d2ceb3c9fe83cb52ae6d2
[ swrv ]
rollback = INTEGER:0x00010001
[ encryption ]
IV =FORMAT:HEX,OCT:00112233445566778899aabccddeff
Rstring = FORMAT:HEX,OCT:00112233445566778899aabccddeff101112131415161718191a1b1c1d1e1f
Icount = INTEGER:1
Salt = FORMAT:HEX,OCT:00112233445566778899aabccddeff
[ pllControl ]
pll0_num = INTEGER:0
pll0_cfg = FORMAT:HEX,OCT:00345678900
pll1_num = INTEGER:1
pll0_cfg = FORMAT:HEX,OCT:00345678900
[ debug ]
uid = FORMAT:HEX,OCT:00345678900
type = INTEGER:1
dbgE = INTEGER:0
secDbgEn = INTEGER:0

```

The certificate is then generated using the following openssl command:

```
openssl req -new -x509 -key <private_key_pem_file> -nodes -out <output_X.509_pem_file> -config <config_file> -sha512
```

If a delegate key is being signed, then add the option -signkey <sign\_key\_pem\_file> to the command above.

#### 5.7.6.3 Image Data

The image data (blob) is considered simply as a byte stream. On devices that are multiple bytes wide the image must be formatted so that all multi-byte fields match the endianness of the device. The R5 will always run in little endian mode.

## 5.8 Boot Memory Maps

### 5.8.1 Global Memory Addresses Used by ROM Code

The ROM code uses several global memory addresses that are useful for debugging. They are shown in [Table 5-64](#).

**Table 5-64. Global Memory Addresses**

| Group              | Address    | Size (bytes) | Content                                  |
|--------------------|------------|--------------|------------------------------------------|
| SMS0_HSM_SRAM0_0   | 0x43c00000 | 0x3e000      | Loadable memory space for SBL            |
| Warning/Error logs | 0x43c3e480 | 0x200        | Warning Entries                          |
| Warning/Error logs | 0x43c3e680 | 0x200        | Severe Entries                           |
| Warning/Error logs | 0x43c3e880 | 0x100        | Critical Entries                         |
| Warning/Error logs | 0x43c3eb80 | 0x14         | Circular message buffer                  |
| Warning/Error logs | 0x43c3eb98 | 0x50         | Boot log context                         |
| Trace              | 0x43c3eb8  | 0x18         | Boot trace context                       |
| Trace              | 0x43c3ec00 | 0x400        | Boot trace entry buffers                 |
| Parameter tables   | 0x43c3f290 | 0x4          | Parameter tables index for R5 bootloader |
| Parameter tables   | 0x43c3f298 | 0x400        | Boot Parameter table for R5 bootloader   |
| Parameter tables   | 0x43c3f1e0 | 0xb0         | Extended boot data for R5 bootloader     |

The ROM code version information is a structure shown in [Table 5-65](#)

**Table 5-65. ROM Code Version**

| Field          | Address     | Size (bytes) | Value for PG1                              |
|----------------|-------------|--------------|--------------------------------------------|
| Version Number | 0x4182_FF80 | 0x4          | 0x00010001 (1.0.1)                         |
| Version Date   | 0x4182_FF84 | 0x8          | "10/26/21"                                 |
| Device Name    | 0x4182_FF8C | 0xC          | "am62x"                                    |
| Commit ID      | 0x4182_FF98 | 0x28         | "5a76b265a1e718df54ea4ce06878f67e9815d589" |

## Chapter 6

# Device Configuration



This chapter describes the device configuration details including information related to Control MMR's, Power, Reset, and Clocking.

|                                                                   |            |
|-------------------------------------------------------------------|------------|
| <b>6.1 Memory Mapped Control Register Modules (CTRL_MMR).....</b> | <b>528</b> |
| <b>6.2 Power.....</b>                                             | <b>533</b> |
| <b>6.4 Clocking.....</b>                                          | <b>614</b> |

## 6.1 Memory Mapped Control Register Modules (CTRL\_MMR)

This chapter covers three categories of device level control register modules:

- General-Purpose Control Register Modules
- Pad Configuration Register Modules
- Security Control Register Modules

Each category of module is described in its own section, along with detailed register descriptions for each module.

### 6.1.1 General Purpose Control Register Modules

The following sections describe the CTRL\_MMR0 and PADCFG\_CTRL0\_CFG0 modules.

#### 6.1.1.1 General Purpose Control Register Modules Overview

There are three General Purpose Control Register Modules on the Device:

- CTRL\_MMR0 for the MAIN domain
- WKUP\_CTRL\_MMR0 for the WKUP domain
- MCU\_CTRL\_MMR0 shared between the WKUP and MCU domains, with Parity Protection.

---

#### Note

Some features may not be available. See *Module Integration* for more information.

---

### 6.1.1.2 General Purpose Control Register Modules Functional Description

#### 6.1.1.2.1 Description for General Purpose Control Register Module Register Types

The following sub-sections provide summary and description for most of the registers which are part of the CTRL\_MMR0, WKUP\_CTRL\_MMR0 and MCU\_CTRL\_MMR0 modules memory spaces. The rest of the registers are described in the corresponding chapters where the functionality associated with particular register is covered in more detail.

##### 6.1.1.2.1.1 Kick Protection Registers

General Purpose Control Register Modules (and also Pad Configuration Register Modules) are organized into different partitions. Partitions can be locked to prevent unintended changes to the register value that might occur due to uncontrolled or malfunctioning software.

Each partition has two registers associated with partition locking - LOCKi\_KICK0 and LOCKi\_KICK1 registers are used for this purpose. A write is required first to the LOCKi\_KICK0[31-1] KEY field and then to the LOCKi\_KICK1[31-0] KEY field with exact data values to unlock the protection mechanism. Once released then all registers within Partition "i" having write permissions can be written to. The read only registers are still read only. An indication for unlocked Partition "i" is when the LOCKi\_KICK0[0] UNLOCKED bit is set to 1h. When the protection mechanism is locked (indicated by LOCKi\_KICK0[0] UNLOCKED = 0h) none of the registers within Partition "i" can be written to. They can only be read..

The key values for all partitions are:

- LOCKi\_KICK0 Key: 68EF 3490h
- LOCKi\_KICK1 Key: D172 BC5Ah

Writing any other data value to either of these registers locks the protection mechanism and blocks any writes to the registers that reside in Partition "i".

##### 6.1.1.2.1.2 I/O Debounce Control Registers

Some device pads have debounce logic. The following MCU\_CTRL\_MMR0 registers are used to configure the debounce period:

- MCU\_CTRL\_MMR\_DBOUNCE\_CFG1
- MCU\_CTRL\_MMR\_DBOUNCE\_CFG2
- MCU\_CTRL\_MMR\_DBOUNCE\_CFG3
- MCU\_CTRL\_MMR\_DBOUNCE\_CFG4
- MCU\_CTRL\_MMR\_DBOUNCE\_CFG5
- MCU\_CTRL\_MMR\_DBOUNCE\_CFG6

The [MCU\\_CTRL\\_MMR\\_DBOUNCE\\_CFG1](#) register contains the debounce period for pads with PADCONFIGx[13-11] DEBOUNCE\_SEL fields set to 1h. The [MCU\\_CTRL\\_MMR\\_DBOUNCE\\_CFG2](#) register contains the debounce period for pads with PADCONFIGx[13-11] DEBOUNCE\_SEL fields set to 2h and so on. The [MCU\\_CTRL\\_MMR\\_DBOUNCE\\_CFG6](#) register contains the debounce period for pads with PADCONFIGx[13-11] DEBOUNCE\_SEL fields set to 6h.

---

##### Note

The debounce logic is not associated with all signals that can be multiplexed on a pad. Only certain signals can use it.

For information about each signal that has associated debounce logic, see the device Datasheet.

---

For information about the PADCONFIGx registers, see [PADCCTRL Registers](#).

[Debounce Period Values](#) shows the debounce period values to load in the MCU\_CTRL\_MMR\_DBOUNCE\_CFGx[5-0] DB\_CFG field.

---

**Note**

The debounce clock selection should happen before the consumer of the debounced signals is enabled as the clock multiplexers for the debounce logic are NOT glitch-free.

---

**Table 6-1. Debounce Period Values**

| MCU_CTRL_MMR_DBOUNCE_CF<br>Gx[5-0] DB_CFG Decimal Value | GPIO Case<br>(32.768kHz<br>(1)) | EQEP Case<br>(20MHz <sup>(1)</sup> ) | MCU_CTRL_MMR_DBOUNCE_CF<br>Gx[5-0] DB_CFG Decimal Value | GPIO Case<br>(20MHz <sup>(1)</sup> ) | EQEP Case<br>(250MHz <sup>(1)</sup> ) |
|---------------------------------------------------------|---------------------------------|--------------------------------------|---------------------------------------------------------|--------------------------------------|---------------------------------------|
|                                                         | Delay[ms]                       | Delay[μs]                            |                                                         | Delay[μs]                            | Delay[ns]                             |
| 0                                                       | bypassed                        | bypassed                             | 32                                                      | 0.05                                 | 4                                     |
| 1                                                       | 1.95                            | 3.20                                 | 33                                                      | 0.10                                 | 8                                     |
| 2                                                       | 2.93                            | 4.80                                 | 34                                                      | 0.15                                 | 12                                    |
| 3                                                       | 3.91                            | 6.40                                 | 35                                                      | 0.20                                 | 16                                    |
| 4                                                       | 4.88                            | 8.00                                 | 36                                                      | 0.25                                 | 20                                    |
| 5                                                       | 5.86                            | 9.60                                 | 37                                                      | 0.30                                 | 24                                    |
| 6                                                       | 6.84                            | 11.20                                | 38                                                      | 0.35                                 | 28                                    |
| 7                                                       | 7.81                            | 12.80                                | 39                                                      | 0.40                                 | 32                                    |
| 8                                                       | 8.79                            | 14.40                                | 40                                                      | 0.45                                 | 36                                    |
| 9                                                       | 9.77                            | 16.00                                | 41                                                      | 0.50                                 | 40                                    |
| 10                                                      | 10.74                           | 17.60                                | 42                                                      | 0.55                                 | 44                                    |
| 11                                                      | 11.72                           | 19.20                                | 43                                                      | 0.60                                 | 48                                    |
| 12                                                      | 12.7                            | 20.80                                | 44                                                      | 0.65                                 | 52                                    |
| 13                                                      | 13.67                           | 22.40                                | 45                                                      | 0.70                                 | 56                                    |
| 14                                                      | 14.65                           | 24.00                                | 46                                                      | 0.75                                 | 60                                    |
| 15                                                      | 15.63                           | 25.60                                | 47                                                      | 0.80                                 | 64                                    |
| 16                                                      | 16.6                            | 27.20                                | 48                                                      | 0.85                                 | 68                                    |
| 17                                                      | 17.58                           | 28.80                                | 49                                                      | 0.90                                 | 72                                    |
| 18                                                      | 18.55                           | 30.40                                | 50                                                      | 0.95                                 | 76                                    |
| 19                                                      | 19.53                           | 32.00                                | 51                                                      | 1.00                                 | 80                                    |
| 20                                                      | 20.51                           | 33.60                                | 52                                                      | 1.05                                 | 84                                    |
| 21                                                      | 21.48                           | 35.20                                | 53                                                      | 1.10                                 | 88                                    |
| Delay[ms]                                               |                                 | Delay[μs]                            | Delay[μs]                                               |                                      | Delay[μs]                             |
| 22                                                      | 15.63                           | 25.60                                | 54                                                      | 25.60                                | 2.048                                 |
| 23                                                      | 31.25                           | 51.20                                | 55                                                      | 51.20                                | 4.096                                 |
| 24                                                      | 46.88                           | 76.80                                | 56                                                      | 76.80                                | 6.144                                 |
| 25                                                      | 62.5                            | 102.40                               | 57                                                      | 102.40                               | 8.192                                 |
| 26                                                      | 78.13                           | 128.00                               | 58                                                      | 128.00                               | 10.24                                 |
| 27                                                      | 93.75                           | 153.60                               | 59                                                      | 153.60                               | 12.288                                |
| 28                                                      | 109.38                          | 179.20                               | 60                                                      | 179.20                               | 14.336                                |
| 29                                                      | 125                             | 204.80                               | 61                                                      | 204.80                               | 16.384                                |
| 30                                                      | 140.63                          | 230.40                               | 62                                                      | 230.40                               | 18.432                                |
| 31                                                      | 156.25                          | 256.00                               | 63                                                      | 256.00                               | 20.48                                 |

(1) These are the debounce logic clock frequencies.

### 6.1.2 Pad Configuration Register Modules

The following sections describe the CTRL\_MMR0 and PADCFG\_CTRL0\_CFG0 modules.

#### 6.1.2.1 Pad Configuration Register Modules Overview

There are three General Purpose Control Register Modules on the Device:

- PADCFG\_CTRL0 for the MAIN domain
- MCU\_PADCFG\_CTRL0 for the MCU and WKUP domains

---

#### Note

Some features may not be available. See *Module Integration* for more information.

---

### 6.1.3 Security Control Register Modules

The following sections describe the CTRL\_MMR0 and PADCFG\_CTRL0\_CFG0 modules.

#### 6.1.3.1 Security Control Register Modules Overview

There are two Security Control Register Modules on the Device:

- MAIN\_SEC\_MMR0 for the MAIN and MCU domains
- WKUP\_SEC\_MMR0 for the WKUP domain

## 6.2 Power

This chapter describes the power-management architecture implemented in the device.

### 6.2.1 Power Management Overview

To provide a versatile architecture that supports multiple power-management techniques, the power management framework is built with three levels of resource management: clock, power, and voltage.

These management levels are enforced by defining the managed entities or building blocks of the power management architecture, called the clock, power, and voltage domains. A domain is a group of modules or subsections of the device that share a common entity (for example, common clock source, common voltage source, or common power switch).

To minimize device power consumption, the clocks can be gated (turned off), or the power to the modules can be switched off, when they are not in use. Independent power and clock control of sections of the device allows for turning on and off specific sections of the device without affecting other sections.

### 6.2.2 Power Control Modules

The Power Control Modules are divided into two sections, dependent on their functionality - Power Sleep Controller section and Device Manager section.

#### 6.2.2.1 Power Sleep Controller

##### 6.2.2.1.1 PSC Architecture

Power Sleep Controller (PSC) is a control component to manage the power domain and module's clock and reset transition. Each PSC module contains multiple power domains, within each power domain, it can contain multiple LPSC. Each LPSC can be used to manage the one or multiple module's reset and clock stop status, see Figure 6-1.

Each power domain has a unique index, starting from number 0. The power domain 0 is a special power domain, which is always on. The status of power domain 0 can't be changed after the device is out of reset.

Each power domain can have one or more Local Power Sleep Control (LPSC). Each LPSC in the same PSC has a unique index value as well. LPSC 0 is special, which user can't change its status. LPSC 0 is always set to be enabled after the device is out of reset.

One LPSC can be used to control the reset and clock status for one or more modules. Some of the LPSC can be used to provide local reset function for the processors, such as A53 and R5 and M4F core. LPSC can also be used to manage the clock stop interface for the interfaces between two interconnect IPs. This is mainly used for providing isolation features required by some special features such as security isolation, functional safety isolation or reset isolation between different parts of the SoC.



**Figure 6-1. PSC Architecture**

**Note**

PSC functions are controlled via Device Manager. For more information how to use Device Manager, see [TISCI API](#) available at [ti.com](#).

#### 6.2.2.1.2 PSC Configurations

Device is partition into two PSC control portions, each portion has its own dedicated PSC module: PSC0 and MCU PSC.

Table 6-2 presents Power Domain features for the processor.

**Table 6-2. Power Domain Features**

| PSC     | PD name         | PD index | GP / PD           | Default Power Domain State | PD State Software Controlled |
|---------|-----------------|----------|-------------------|----------------------------|------------------------------|
| MCU PSC | GP_Core_CTL MCU | 0        | GP <sup>(1)</sup> | AO <sup>(3)</sup>          | NO                           |
|         | PD_MCU_M4F      | 1        | PD <sup>(2)</sup> | ON                         | YES                          |

**Table 6-2. Power Domain Features (continued)**

| PSC  | PD name          | PD index | GP / PD           | Default Power Domain State | PD State Software Controlled |
|------|------------------|----------|-------------------|----------------------------|------------------------------|
| PSC0 | GP_Core_CTL      | 0        | GP <sup>(1)</sup> | AO <sup>(3)</sup>          | NO                           |
|      | PD_ICSSM         | 1        | PD <sup>(2)</sup> | OFF                        | YES                          |
|      | PD_CPSW          | 2        | PD <sup>(2)</sup> | ON                         | YES                          |
|      | PD_A53_cluster_0 | 3        | PD <sup>(2)</sup> | OFF                        | YES                          |
|      | PD_A53_0         | 4        | PD <sup>(2)</sup> | OFF                        | YES                          |
|      | PD_A53_1         | 5        | PD <sup>(2)</sup> | OFF                        | YES                          |
|      | PD_A53_2         | 6        | PD <sup>(2)</sup> | OFF                        | YES                          |
|      | PD_A53_3         | 7        | PD <sup>(2)</sup> | OFF                        | YES                          |
|      | PD_GPU           | 8        | PD <sup>(2)</sup> | OFF                        | YES                          |
|      | PD_DSS           | 9        | PD <sup>(2)</sup> | OFF                        | YES                          |

(1) Group with common power - means that there are no power switches. The group is considered always-on.

(2) Power switched domain - means this is a full power switched domain.

(3) AO = Always On

[Table 6-3](#) and [Table 6-4](#) show the summary how each module is controlled by LPSC.

Table 6-3. LPSC Features

| PSC   | Power Domain Name | LPSC Name                             | LPSC Index | Default LPSC State | LPSC State Software Controlled | Modules (Aliased)                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------------------|---------------------------------------|------------|--------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSC_0 | GP_Core_CTL       | LPSC_main_alwayson <sup>(1)</sup>     | 0          | ON                 | No                             | CMP_EVENT_INROUTER0<br>CTRL_MMR0<br>MAIN_GPIOMUX_INROUTER0<br>PLL0<br>TIMESYNC_EVENT_ROUTER0<br>WKUP_CTRL_MMR0<br>WKUP_WKUP_SEC_MMR0<br>PADCFIG_CTRL0<br>DCC0<br>DCC1<br>DCC2<br>DCC3<br>DCC4<br>DCC5<br>DCC6<br>WKUP_TIMER0<br>WKUP_TIMER1<br>ESMO<br>GPIO0<br>GPIO1<br>WKUP_GTC0<br>DDPA0<br>WKUP_VTM0<br>WKUP_I2C0<br>PSRAMECC0<br>WKUP_ROM0<br>WKUP_rtcss0<br>EFUSE0<br>WKUP_UART0 |
|       |                   | LPSC_main_dm                          | 1          | OFF                | Yes                            | R5FSS0_CORE0<br>WKUP_RTIO                                                                                                                                                                                                                                                                                                                                                              |
|       |                   | LPSC_DM_PBIST                         | 2          | ON                 | Yes                            | WKUP_PBIST0                                                                                                                                                                                                                                                                                                                                                                            |
|       |                   | LPSC_main2DM_ISO <sup>(2)</sup>       | 3          | ON                 | Yes                            |                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                   | LPSC_DM2main_ISO <sup>(2)</sup>       | 4          | ON                 | Yes                            |                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                   | LPSC_DM2main_infra_ISO <sup>(2)</sup> | 5          | ON                 | Yes                            |                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                   | LPSC_DM2central_iso <sup>(2)</sup>    | 6          | ON                 | Yes                            |                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                   | LPSC_central2DM_ISO <sup>(2)</sup>    | 7          | ON                 | Yes                            |                                                                                                                                                                                                                                                                                                                                                                                        |

**Table 6-3. LPSC Features (continued)**

| PSC   | Power Domain Name | LPSC Name                         | LPSC Index | Default LPSC State | LPSC State Software Controlled | Modules (Aliased)  |
|-------|-------------------|-----------------------------------|------------|--------------------|--------------------------------|--------------------|
| PSC_0 | GP_Core_CTL       | LPSC_GP_spare0                    | 8          | OFF                | Yes                            |                    |
|       |                   | LPSC_EMIF_local                   | 9          | OFF                | Yes                            | DDR16SS0           |
|       |                   | LPSC_EMIF_CFG_ISO <sup>(2)</sup>  | 10         | OFF                | Yes                            |                    |
|       |                   | LPSC_EMIF_data_ISO <sup>(2)</sup> | 11         | OFF                | Yes                            |                    |
|       |                   | LPSC_main_USB0_ISO <sup>(2)</sup> | 12         | OFF                | Yes                            |                    |
|       |                   | LPSC_main_USB1_ISO <sup>(2)</sup> | 13         | OFF                | Yes                            |                    |
|       |                   | LPSC_main_test                    | 14         | ON                 | Yes                            | DFTSS0             |
|       |                   | LPSC_GPMC                         | 15         | OFF                | Yes                            | ELM0               |
|       |                   |                                   |            |                    |                                | GPMC0              |
|       |                   | LPSC_GP_spare1                    | 16         | OFF                | Yes                            |                    |
|       |                   | LPSC_main_mcasp_0                 | 17         | OFF                | Yes                            | MCASP0             |
|       |                   | LPSC_main_mcasp_1                 | 18         | OFF                | Yes                            | MCASP1             |
|       |                   | LPSC_main_mcasp_2                 | 19         | OFF                | Yes                            | MCASP2             |
|       |                   | LPSC_emmc_8b                      | 20         | OFF                | Yes                            | MMCSDO             |
|       |                   | LPSC_emmc_4b_0                    | 21         | OFF                | Yes                            | MMCSD1             |
|       |                   | LPSC_emmc_4b_1                    | 22         | OFF                | Yes                            | MMCSD2             |
|       |                   | LPSC_USB_0                        | 23         | OFF                | Yes                            | USB0               |
|       |                   | LPSC_USB_1                        | 24         | OFF                | Yes                            | USB1               |
|       |                   | LPSC_CSI_RX_0                     | 25         | OFF                | Yes                            | csi_rx_if0         |
|       |                   | LPSC_DPHY_0                       | 26         | OFF                | Yes                            | DPHY_RX0           |
|       |                   | LPSC_SMS_common                   | 27         | ON                 | Yes                            | MAIN_SEC_MMR0      |
|       |                   |                                   |            |                    |                                | CPT2_AGGR1         |
|       |                   |                                   |            |                    |                                | MAILBOX0_CLUSTER_0 |
|       |                   |                                   |            |                    |                                | PSRAMECC_16K0      |
|       |                   |                                   |            |                    |                                | SPINLOCK0          |
|       |                   | LPSC_fss_ospi                     | 28         | ON                 | Yes                            | FSS0_FSAS_0        |
|       |                   |                                   |            |                    |                                | FSS0_OSPI_0        |
|       |                   | LPSC_TIFS                         | 29         | ON                 | Yes                            | SMS0               |
|       |                   | LPSC_HSM                          | 30         | OFF                | Yes                            |                    |
|       |                   | LPSC_sa3ul                        | 31         | ON                 | Yes                            | SA3_SS0            |
|       |                   | LPSC_HSM_ISO <sup>(2)</sup>       | 32         | TRUE               | Yes                            |                    |
|       |                   | LPSC_debugss                      | 33         | ON                 | Yes                            | DBGUSPENDROUTER0   |
|       |                   |                                   |            |                    |                                | STM0               |
|       |                   |                                   |            |                    |                                | DEBUGSS_WRAP0      |
|       |                   |                                   |            |                    |                                | DEBUGSS0           |

Table 6-3. LPSC Features (continued)

| PSC   | Power Domain Name | LPSC Name          | LPSC Index | Default LPSC State | LPSC State Software Controlled | Modules (Aliased)                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-------------------|--------------------|------------|--------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSC_0 | GP_Core_CTL       | LPSC_main_IP       | 34         | ON                 | Yes                            | CPT2_AGGR0<br>DMASS0<br>TIMER0<br>TIMER1<br>TIMER2<br>TIMER3<br>TIMER4<br>TIMER5<br>TIMER6<br>TIMER7<br>ECAP0<br>ECAP1<br>ECAP2<br>EQEP0<br>EQEP1<br>EQEP2<br>EPWM0<br>EPWM1<br>EPWM2<br>MCRC64_0<br>I2C0<br>I2C1<br>I2C2<br>I2C3<br>PDMA2<br>PDMA0<br>PDMA1<br>MCSP10<br>MCSP11<br>MCSP12<br>UART0<br>UART1<br>UART2<br>UART3<br>UART4<br>UART5<br>UART6<br>MCAN0<br>GICSS0<br>PBIST0<br>UART0<br>UART1<br>UART2<br>UART3<br>UART4<br>UART5<br>UART6 |
|       |                   | LPSC_main_mcanss_0 | 35         | OFF                | Yes                            | MCAN0                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |                   | LPSC_GIC           | 36         | ON                 | Yes                            | GICSS0                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                   | LPSC_main_PBIST    | 37         | ON                 | Yes                            | PBIST0                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                   | LPSC_main_spare0   | 38         | OFF                | Yes                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |                   | LPSC_main_spare1   | 39         | OFF                | Yes                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**Table 6-3. LPSC Features (continued)**

| PSC   | Power Domain Name | LPSC Name                  | LPSC Index | Default LPSC State | LPSC State Software Controlled | Modules (Aliased)        |
|-------|-------------------|----------------------------|------------|--------------------|--------------------------------|--------------------------|
| PSC_0 | PD_ICSSM          | LPSC_ICSSM                 | 40         | OFF                | Yes                            | ICSSM0                   |
|       | PD_CPSW           | LPSC_CPSW3G                | 41         | OFF                | Yes                            | CPSW0                    |
|       | PD_A53_cluster_0  | LPSC_A53_cluster_0         | 42         | OFF                | Yes                            | A53SS0                   |
|       |                   | LPSC_A53_cluster_0_PBIST_0 | 43         | OFF                | Yes                            | COMPUTE_CLUSTER0_PBIST_0 |
|       |                   | LPSC_A53_cluster_0_PBIST_1 | 44         | FALSE              | Yes                            |                          |
|       | PD_A53_0          | LPSC_A53_0                 | 45         | OFF                | Yes                            | RTI0                     |
|       | PD_A53_1          | LPSC_A53_1                 | 46         | OFF                | Yes                            | RTI1                     |
|       | PD_A53_2          | LPSC_A53_2                 | 47         | OFF                | Yes                            | RTI2                     |
|       | PD_A53_3          | LPSC_A53_3                 | 48         | OFF                | Yes                            | RTI3                     |
|       | PD_GPU            | LPSC_GPU                   | 49         | OFF                | Yes                            | GPU0                     |
|       |                   | LPSC_GPU_PBIST             | 50         | OFF                | Yes                            | RTI15                    |
|       | PD_DSS            | LPSC_DSS                   | 51         | OFF                | Yes                            | PBIST1                   |

- (1) This LPSC's state can't be modified by user.  
 (2) This LPSC is used for isolation purpose, not control any reset for any modules.

Table 6-4. MCU LPSC Features

| PSC      | Power Domain Name | LPSC Name                        | LPSC Index | Default LPSC State | LPSC State Software Controlled | Modules (Aliased)                                                                                                         |
|----------|-------------------|----------------------------------|------------|--------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| MCU_PSC0 | GP_core_CTL_MCU   | LPSC_mcu_alwayson <sup>(1)</sup> | 0          | ON                 | No                             | MCU_CTRL_MMR0<br>WKUP_MCU_GPIOMUX_INTRO_UTER0<br>WKUP_PLL0<br>WKUP_PADC_CFG_CTRL0<br>MCU_DCC0<br>WKUP_ESM0<br>MCU_GPIO0   |
|          |                   | LPSC_main2mcu_ISO <sup>(2)</sup> | 1          | ON                 | Yes                            |                                                                                                                           |
|          |                   | LPSC_mcu2main_ISO <sup>(2)</sup> | 2          | ON                 | Yes                            |                                                                                                                           |
|          |                   | LPSC_DM2safe_ISO <sup>(2)</sup>  | 3          | ON                 | Yes                            |                                                                                                                           |
|          |                   | LPSC_mcu2DM_ISO <sup>(2)</sup>   | 4          | ON                 | Yes                            |                                                                                                                           |
|          |                   | LPSC_mcu_test                    | 5          | ON                 | Yes                            |                                                                                                                           |
|          | PD_M4F            | LPSC_mcu_m4f                     | 6          | OFF                | Yes                            | MCU_M4FSS0<br>MCU_RT10                                                                                                    |
|          |                   | LPSC MCU_mcanss_0                | 7          | OFF                | Yes                            | MCU_MCAN0                                                                                                                 |
|          |                   | LPSC MCU_mcanss_1                | 8          | OFF                | Yes                            | MCU_MCAN1                                                                                                                 |
|          |                   | LPSC MCU_common                  | 9          | ON                 | Yes                            | MCU_TIMER0<br>MCU_TIMER1<br>MCU_TIMER2<br>MCU_TIMER3<br>MCU_MCRC64_0<br>MCU_I2C0<br>MCU_MCSPI0<br>MCU_MCSPI1<br>MCU_UART0 |

(1) This LPSC's state can't be modified by user.

(2) This LPSC is used for isolation purpose, not control any reset for any modules.

### 6.2.2.1.2.1 Software Sequence to enable an IP through PSC

In order to enable a module, user needs to program the PSC to put LPSC into enable state. There is dependence between power domain and LPSC and among different LPSC controls.

First of all, in order to enable any LPSC, the power domain which that LPSC belongs needs to be enabled first. The LPSC can't put into any state other than disable if the power domain is not enabled.

Among different LPSC, there is also a special sequence needs to be followed to make sure the device is not getting into undefined state.

Similarly, a special sequence shall be followed to disable the LPSC to prevent device getting into undefined states. Before a power domain can be turned off, all the LPSCs within that power domain shall be disabled first. Normally, user can turn off the power domain to save power. However, it is not necessary to turn off the power domain when all the LPSCs inside that power domain are disabled.

[Figure 6-2](#) shows how to understand the dependent relationship between two LPSCs. In order to enable LPSC\_2, LPSC\_1 shall be enabled first. If user wants to disable LPSC\_1, LPSC\_2 shall be disabled first.



**Figure 6-2. LPSC Dependence**

[Figure 6-3](#) shows the dependent relationship among all the LPSCs in the device.



Figure 6-3. LPSC Dependence Tree

### 6.2.2.2 Device Manager

The device has one Device Manager located in WKUP domain. Device Manager is responsible for entry/exit to low power modes. Also, Device Manager hosts RM/PM (Resource manager/power manager) SYSFW code for providing RM/PM services to HLOS. As part of boot, public ROM is executed over Device Manager.

#### Device Manager Features

- Single Core Cortex-R5 subsystem
  - ARMv7-R architecture with following extensions
    - Advanced SIMD extension for integer and floating-point vector operations
    - Vector Floating Point Version 3 (VFPv3)
  - L1 memory architecture
    - 32KB I-cache with 64-bit ECC error checking
    - 32KB D-cache with 64-bit ECC error checking
  - 64Kbyte TCM(L2) with 32-bit ECC error checking
  - 32-bit AXI3 initiator interface for accessing local peripherals
- 1x RTI/WWDT
- 2x Timer
- 1x UART
- 1x I2C
- Wake-up logic
- Public ROM
- RTC digital
- VTM
- LFOSC

---

#### Note

PSC functions are controlled via Device Manager. For more information how to use Device Manager, see [TISCI API](#) available at [ti.com](#).

---

### 6.2.3 Power Management Techniques

The following section describes the power management techniques supported by the device

#### 6.2.3.1 Dynamic Frequency Scaling (DFS)

DFS is a power management technique where the operating frequency is dynamically scaled across device Operating Performance Points (OPP). An OPP is a voltage/frequency pair that defines a specific power state. For each OPP, software controls clock frequency in order to adjust the performance and power to the optimum point. The Device supports DFS for Cortex-A53 only.

#### 6.2.3.2 OPP Low

The device supports lower bus frequency operation as OPP Low. The OPP Low must be configured at boot time. In OPP Low, the main CBASS clock frequency is reduced in half in order to lower active power consumption with reduced performance. The performance of some peripheral modules is limited or not available in this operating condition.

Refer to the device datasheet to determine the supported features and the clock frequency of cores, modules, and peripheral I/Os in OPP Low.

#### 6.2.4 Power Modes

The following sections describe a high-level description of the different power modes of the device. They are listed in order from highest power consumption, lowest wakeup latency (Standby), to lowest power consumption, highest wakeup latency (Partial IO). If your application requires some sort of power management, you must determine which power mode level described below satisfies your requirements. Each level must be evaluated based on power consumed and latency (the time it takes to wakeup to Active mode). Specific values are detailed

in the device-specific data sheet. Note that not all modes are supported by software packages supplied by Texas Instruments.

**Table 6-5. Low Power Modes**

| Low Power Modes | Wakeup Sources                                                     | Application State and Use Case                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Partial I/O     | CANUART I/O Bank pins                                              | The entire SoC is OFF except I/O pins in CANUART I/O Bank to maintain I/O wakeup capability from CANUART I/O Bank I/O pins.                                                                                                                                                                                                                                                                             |
| DeepSleep       | GP Timers, RTC Timer, UART, I2C, WKUP GPIO, I/O Daisy Chain        | Core domain register information will be lost. On-chip peripheral register (context) information of core domain needs to be saved by application to DDR before entering this mode. DDR is in self-refresh. Boot ROM executes and branches to peripheral context restore for wakeup, followed by system resume. This mode is primarily used for Suspend to RAM for battery lifetime or backup operation. |
| MCU Only        | DeepSleep wakeup events, Interrupt events supported in MCU channel | The MCU subsystem runs at the MCU PLL clock. The rest of the SoC status is the same as DeepSleep. DDR is in self-refresh. MCU can run applications with MCU domain peripherals while in this low power mode.                                                                                                                                                                                            |
| Standby         | Any SoC interrupt event                                            | On-chip contents are fully preserved. Any SoC interrupt event can cause a wakeup event from this low power mode. A53 and MCU M4F are in WFI or Power Down. DDR memory is in self-refresh. The device can run low-level processing with non-Wakeup/MCU domain peripherals and support wakeup from those peripherals.                                                                                     |

**Table 6-6. Voltage, Power and Clock Domain Status**

| Low Power Modes | Voltage Domain       |          |                  |                     | Power Domain |          |         |                  |          |        |        |                 | Clocks     |          | DDR             |              |
|-----------------|----------------------|----------|------------------|---------------------|--------------|----------|---------|------------------|----------|--------|--------|-----------------|------------|----------|-----------------|--------------|
|                 | VDD_CORE / VDDR_CORE | VDDS_DDR | 1.8 Analog Rails | 1.8V/3.3V I/O Rails | GP_Core_CTL  | PD_ICSSM | PD_CPSW | PD_A53_cluster_0 | PD_A53_X | PD_GPU | PD_DSS | GP_Core_CTL_MCU | PD MCU_M4F | Main OSC | DPLLS           |              |
| Partial I/O     | OFF                  | OFF      | OFF              | Partial On          | OFF          | OFF      | OFF     | OFF              | OFF      | OFF    | OFF    | OFF             | OFF        | OFF      | OFF             | OFF          |
| DeepSleep       | ON                   | ON       | ON               | ON                  | ON           | OFF      | OFF     | OFF              | OFF      | OFF    | OFF    | OFF             | OFF        | OFF      | OFF             | Self-Refresh |
| MCU Only        | ON                   | ON       | ON               | ON                  | ON           | OFF      | OFF     | OFF              | OFF      | OFF    | OFF    | ON              | ON         | ON       | MCU DPLL locked | Self-Refresh |
| Standby         | ON                   | ON       | ON               | ON                  | ON           | ON       | ON      | ON               | ON       | ON     | ON     | ON              | ON         | ON       | Bypass          | Self-Refresh |

#### 6.2.4.1 Active

In Active mode, the supply to all voltage rails must be maintained. All power domains come up in ON state and the device is fully functional.

#### 6.2.4.2 Standby

The device can be placed in Standby mode to reduce power consumption during low activity levels. This first level of power management allows you to maintain the device context for fast resume times. The main characteristics of this mode that distinguish it from Active mode are:

- All modules are clock gated except GPIOs
- PLLs may be placed in bypass mode if downstream clocking does not require full performance
- The VDD\_CORE voltage level is maintained.
- Power domain may be turned off if it's not used for the contexts can be saved and restored.
- DDR memory is in low power self-refresh mode.

The above conditions result in lower power consumption than Active mode but require the user to save the switched-off power domain context to On-Chip Memory or DDR and restore the contexts to resume properly upon wakeup.

Wakeup in Standby mode is achieved using any GPIO. GPIO wakeup is possible by switching the pad to GPIO mode and configuring the corresponding GPIO bank for generating an interrupt to the Device Manager. Note that pads that do not have a GPIO muxmode (for example, USB) cannot cause these wakeups. If additional or other wakeup sources are required, the associated peripheral module clock and interconnect clock domain should remain enabled (this may require the associated PLL to remain locked) and the module must be configured appropriately for wakeup by configuring it to generate an interrupt to the Device Manager.

#### 6.2.4.3 MCU-Only

MCU-Only can be used for low power use cases that require low-level processing during a low power mode. The status of the SoC is the same as DeepSleep, except the MCU channel is fully active to run applications with MCU channel resources and peripherals. Any interrupt event in the MCU channel can initiate a wakeup from MCU-Only and the wakeup events supported in DeepSleep can also trigger wakeup from MCU-Only.

The main characteristics of the mode which distinguish it from other low power modes are:

- Main domain status is the same as DeepSleep
- VDD\_CORE power (except VDDA analog) to PLLs is turned OFF except MCU PLL
- The main oscillator is active to keep MCU channel running.
- MCU Channel is fully active to run applications with the peripherals in the channel.
- DDR memory is in low power self-refresh mode.

#### 6.2.4.4 DeepSleep

DeepSleep mode enables lower power consumption than Standby or MCU-Only. The main characteristics of the mode which distinguish it from other higher power modes are:

- All on-chip power domains are shut off (except GP\_Core\_CTL and GP\_Core\_CTL\_MPU remain ON) to reduce power leakage
- VDD\_CORE power (except VDDA analog) to PLLs is turned OFF
- The main and RTC oscillators may be turned off if they're not used to keeping timers on as a wakeup source.

DeepSleep mode is typically used during inactivity when the user requires very low power while waiting for an event that requires processing or higher performance. DeepSleep is the lowest power mode which still includes DDR in self-refresh, so wakeup events do not require a full cold boot, significantly reducing wakeup latencies.

The lowest power in this mode can be achieved by disabling both oscillators when the RTC or other timer function is not required.

The main On-Chip SRAM (OCM) contents are lost because the power domain is turned OFF.

Before entering DeepSleep mode, peripheral and MPU context must be saved in the DDR. Upon wakeup, the boot ROM executes and checks to see if it has resumed from a DeepSleep state. If so, it redirects to the DDR to continue the resume process. Because the power to Always-On power domains (GP\_Core\_CTL and GP\_Core\_CTL\_MU) are ON throughout DeepSleep, power to key modules such as GPIO0 and others is maintained to allow wakeup events to exit out of this mode. In addition, the Wakeup On-Chip SRAM (OCM) power is maintained to preserve information internally during DeepSleep.

Activity on wakeup peripherals via wakeup events enables the high frequency oscillator by using the oscillator control circuit. The wakeup events also interrupt the Device Manager, which controls proper enabling of power

domains and clocks in the PSC. See 1.4.7, Wakeup Sources/Events, for details on wakeup sources during DeepSleep and other low power modes mentioned.

#### 6.2.4.5 Partial I/O

In Partial I/O, I/O pins and small logics in the CANUART I/O Bank are active, and the rest of the SoC is turned off. The user can use the I/O pins to aggregate multiple I/O wakeup events and toggle PMIC\_LPM\_EN pin to enable PMIC or discrete power solution when an I/O wakeup event is triggered. The information on the I/O wakeup event is logged in the MMR in the CANUART I/O bank and helps the software to distinguish between cold boot and wakeup to respond to the wakeup event faster.

#### 6.2.4.6 Power States and Transitions

The Low power mode transition always starts from the active state. If the device needs to transition from one low power mode to another low power mode, it must go through the active state first. Typically, the software initiates a transition from active mode to a low power mode and a wakeup event triggers a transition from a low power mode to active.

Figure 6-4 shows the power state transition supported by the device.



**Figure 6-4. Power State Transition Diagram**

#### 6.2.4.7 Wakeup Sources/Events

Table 6-7 shows the wake sources supported in each low power mode. High-frequency or Low -frequency oscillator remains ON when a timer wakeup event is selected in DeepSleep. DeepSleep wakeup events are part of the Wakeup Power domain and remain always ON.

**Table 6-7. Low Power Mode Wakeup Events**

| Low Power Modes | Wakeup Events                                               |
|-----------------|-------------------------------------------------------------|
| Partial I/O     | CANUART I/O Bank pins                                       |
| DeepSleep       | GP Timers, RTC Timer, UART, I2C, WKUP GPIO, I/O Daisy Chain |
| MCU Only        | DeepSleep wakeup events, Any MCU channel interrupt event    |
| Standby         | Any SoC interrupt event                                     |

#### 6.2.4.8 USB Wakeup Scenarios

**Table 6-8** summarizes different USB wakeup use cases which are supported in each system sleep state (DeepSleep, MCU-only or Standby). Three use case scenarios exist:

- **USB Connect:** Wakeup is cause by physically inserting the USB cable.
- **USB Disconnect:** Wakeup is caused by physically removing the USB cable.
- **USB Resume/Remote Wakeup:** Wakeup is caused by a USB resume or remote wakeup. For example, a USB mouse click can cause a USB remote wakeup.

Within each wakeup use case, each row describes whether or not that type of wakeup is supported in each system sleep mode. USB mode (host or device) is also considered.

There are three possible Wakeup events that are generated:

- **PHY Signal WKUP:** this is an internal wakeup signal to the wakeup processor that is generated by the USB PHY based off of USB signaling.
- **PHY VBUS WKUP:** this is an internal wakeup signal to the wakeup processor that is generated by the USB PHY based off of a level change on VBUS voltage. Ensure you level shift the voltage to conform to the I/O requirements. When VBUS transitions from 0V to 5V (or vice versa), the transition will trigger a wakeup.
- **ID Status WKUP:** this is a wakeup signal generated by a status change on the USB ID pin.

**Table 6-8. USB Wakeup Use Cases Supported in System Sleep States**

| No. | USB Wakeup Use Case           | System Sleep State      | USB Controller State                         | USB Mode     | Supported | USB Wakeup Event                   |
|-----|-------------------------------|-------------------------|----------------------------------------------|--------------|-----------|------------------------------------|
| 1   | USB Connect                   | DS/MCU-only/<br>Standby | Clock Gated<br>Register Contexts<br>Retained | Host         | Yes       | PHY Signal WKUP                    |
| 2   |                               | DS/MCU-only/<br>Standby | Clock Gated<br>Register Contexts<br>Retained | Device       | Yes       | PHY VBUS WKUP                      |
| 3   |                               | DS/MCU-only/<br>Standby | Clock Gated<br>Register Contexts<br>Retained | Undetermined | Yes       | ID Status WKUP                     |
| 4   | USB Resume /<br>Remote Wakeup | DS/MCU-only/<br>Standby | Clock Gated<br>Register Contexts<br>Retained | Host         | Yes       | PHY Signal WKUP                    |
| 5   |                               | DS/MCU-only/<br>Standby | Clock Gated<br>Register Contexts<br>Retained | Device       | Yes       | PHY Signal WKUP                    |
| 6   | USB Disconnect                | DS/MCU-only/<br>Standby | Clock Gated<br>Register Contexts<br>Retained | Host         | Yes       | PHY Signal WKUP,<br>ID Status WKUP |
| 7   |                               | DS/MCU-only/<br>Standby | Clock Gated<br>Register Contexts<br>Retained | Device       | Yes       | PHY VBUS WKUP                      |

#### 6.2.4.9 Main Oscillator Control During DeepSleep

The DeepSleep oscillator circuit is used to control the main oscillator by disabling it during deep sleep and enabling during active/wakeup. By default, during reset, the oscillator is enabled and the oscillator control circuit comes up disabled (in-active). In order to activate the oscillator control circuit for DeepSleep, a register must be programmed. Once this is set and whenever the Device Manager enters DeepSleep, the oscillator control will disable the oscillator causing the clock to be shut OFF. Any event from the wakeup sources will cause the oscillator control to re-enable the oscillator after a programmed period in a register.

The Device Manager will always be powered up. But when the main oscillator is in power down / OFF state, the Device Manager will not receive any clock.

#### 6.2.4.10 Low Power Mode Sequencing with Device Manager

The device contains a Device Manager (DM) to handle all of the low-level power management control of the device including the Low Power Mode transitions. It is part of the DM Always ON (AON) power domain as shown in [Figure 6-5](#). A firmware is provided by Texas Instruments that includes all of the necessary functions to achieve low power modes. Inter-Processor Communication (IPC) registers are available to communicate with the Device Manager so the user can provide certain configuration parameters based on the level of low power that is required.



**Figure 6-5. Key SoC Components for Low Power Modes**

The followings are prerequisites to start a low power mode sequence.

- All IO Pad config MMRs configured appropriately for a target low power mode
- Save device configuration / context information to external DDR
- Power initiator, likely A53 running RTOS or Linux or MCU M4 running RTOS, is responsible for putting other application cores in proper state (OFF) and restarts after resume.
- Power initiator core will signal for DM sleep sequence to begin.
- Application software is responsible for DS padconf configuration for all states needed in low power mode.
- Secure Stub must be signed and encrypted as a bootable image and loaded to SPS region by HLOS or bootloader
- DM Stub must be loaded to NSPS region by HLOS or bootloader
- TISCI\_MSG\_PREPARE\_SLEEP comes from PM initiator (Secure or Non-secure)
  - Contains Desired State to Enter (DeepSleep, MCU-Only, Standby)
  - Flags that can be used to set HALT points for debug
  - Memory address to be used for TIFS context encrypt and save. If bad address is given on resume, decrypt will fail.
- TISCI\_MSG\_ENTER\_SLEEP message must contain resume address of cores to be restarted by firmware
- WKUP\_CTRL.PMCTRL\_SYS.lpm\_en should be configured to let DeepSleep Logic control PMIC\_LPM\_EN output before sequence.

#### Sleep Sequencing

1. During Active power mode, the MPU sends TISCI\_MSG\_PREPARE\_SLEEP with DeepSleep selected to the DM and TISCI\_MSG\_ENTER\_SLEEP with resume address to the TIFS core.
2. TIFS Core prepares for DeepSleep and messages HSM core to tell it to enter WFI
3. HSM Core prepares for DeepSleep and enters WFI
4. TIFS Core sends TISCI to DM for suspend finish and enters WFI.
5. DM waits for all cores to enter WFI, timeout and abort if they do not.
6. DM executes DM Stub sequence, place DDR into Self Refresh, configures selected wakeup sources and HFOSC clock and PD.
7. DM enters in WFI
8. DS HW Logic gates off HFOSC0 and Powers-off
9. DS state is captured in MMR.
10. Device in DS state

### **Wakeup Sequencing**

1. Event of IO daisy chain or internal Timer/RTC events generates async wake-up event
2. This async wake-up event turns on high frequency oscillator (HFOSC)
3. DM exists WFI as soon as HFOSC clock is available.
4. DM detects that it is resuming from Deep sleep mode
5. DM goes through wake-up sequence: enabling MCU PLL etc
6. DM Powers-on MCU, SMS, DEBUGSS
7. DM configures DS\_MAIN\_POR\_PDOFF register to deassert MCU PORz and Main PD Domains (SMS, DEBUGSS, MAINIP)
8. Wait for RESETSTATZ indication to determine Main is out of Reset
9. TIFS Boots-up -it detects that it is resuming from DeepSleep state
10. DM and TIFS handshake to start the device restore
11. Decrypts Secure Stub from DM Secure RAM and Messages DM on completion
12. DM configures Main Domain PLLs
13. DM programs Main PSC to enable clocks to Main components (DDR, USB, Peripherals)
14. DM checks PSC to ensure DDR and USB are enabled and resets are de-asserted.
15. DM configures DDR to restore to the state it was prior to entering sleep mode
16. DM enables A53 –enables PLLs, programs Reset Vector, etc...
17. A53 reads context data from external DDR and restores MAIN/WKUP/MCU configuration including IO pads etc
18. Device enters normal mode of operation

---

#### **Note**

Low Power Mode sequencing is controlled via Device Manager. For more information how to use Device Manager, see [TISCI API](#) available at [ti.com](http://ti.com).

---

#### **6.2.4.11 I/O Power Management and Daisy Chaining**

I/O power management is useful when the main oscillator is clock gated and the power domains for the peripherals connected to LVCMOS I/Os are OFF (power-gated state) in DeepSleep or MCU-Only. Since the I/Os are controlled by modules in power-gated state, I/O power management is required to have flexibility when interfacing with external devices. During DeepSleep or MCU-Only, the wakeup feature is active, described in **Wakeup** below. Isolation is required to be activated and deactivated during sleep and wakeup sequencing, respectively (see following description of **Isolation**).

Three aspects comprise I/O cell power management:

- **Isolation** - Isolation from power state transitions.
  - When ISOLATED, the I/Os will hold their previous state (0,1, tristate) until the ISOLATION is released. The controls for the ISOLATION travel through the chain. Isolation is controlled during sleep and wakeup sequencing.

---

**Note**

The Device Manager must have the optional feature to remove isolation from DDR I/Os while allowing rest of the I/O isolation to be removed later. This allows for software to restore any critical peripherals from DDR and ensure the peripheral is in a required or valid state (like GPIO) before the remaining I/Os are removed from Isolation.

---

- **Wakeup** - I/O PAD can be individually enabled for wakeup using PADCONFx.wkup\_en register bit.
  - The wakeup controls and events (as well as enable and disable controls) travel through asynchronously through the chain during DeepSleep or MCU-Only. The global wakeup chain is enabled/controlled by the Device Manager. This is global control is achieved by qualifying each of the I/O PAD wakeup enables with global wakeup daisy chain control coming from Device Manager.
- **PADCONFIG** - Individual control on what will be the IO state during Isolation using PADCONFIGx control register bits.
  - The PADCONFIG registers must be used only if the default state of the I/O during the low power state does not meet system requirements.

The following terminal signal names are unique and are excluded from the isolation and wakeup daisy chains. Control of these signals can remain with GPIO even when I/O isolation is enabled. Refer to the device datasheet to determine which pins map to each signal name. Each pin has a corresponding GPIO that can be mapped to one of the GPIOs in the GPIO module.

- System signals: MCU\_RESETSTATz, WKUP\_CLKOUT0, EXT\_REFCLK1
- OLDDIO interface: All OLDDIO\_x signals

The following terminal signal names are excluded from the isolation and wakeup daisy chains and not muxed with GPIO signals. Hence, these signals cannot be used as a wakeup event.

- System signals: MCU\_RESETz, MCU\_PORz, MCU\_ERRORn, WKUP\_CLKOUT0, EXT\_REFCLK1, RESET\_REQz, RESETSTATz, PORz\_OUT
- JTAG interface: TMS, TDI, TDO, TCK, TRSTn, EMU0, EMU1
- Oscillator signals: MCU\_OSC0\_XO, MCU\_OSC0\_XI, WKUP\_LFOSC0\_XO, WKUP\_LFOSC0\_XI
- CSI0 interface: All CSI0\_x signals
- USB signals: USB0\_DP, USB0\_DM, USB0\_RCALIB, USB0\_VBUS, USB1\_DP, USB1\_DM, USB1\_RCALIB, USB1\_VBUS
- DDR interface: All DDR0\_x signals

## 6.2.5 Power Supply Modules

### 6.2.5.1 Power OK (POK) Modules

---

**Note**

All POK modules are in MCU domain regardless of the domain of the voltage they monitor.

---



---

**Note**

In this family of devices, the Power-on-reset module is used only for voltage monitoring, as three additional POK modules. For more information about POK functionality in POR module - voltage being monitored and type (under voltage or over voltage), see [Section 6.2.5.2](#).

---

POK modules are responsible for accurately detecting the voltage levels. Each module is trimmed to account for process and temperature variations. The trim values are provided by eFuse chains enabled by a POR/Reset Generator (PRG) module.

Two types of POK modules are implemented in this family of devices - POK and POK\_SA. See [Table 6-9](#) about the type of a POK and the voltage it is monitoring. More information about the two types of POKs is given further in this section.

**Table 6-9. POK Module Overview**

| POK Module Instance Name  | PRG Index<br><sup>(3)</sup> | POK Index<br><sup>(1)</sup> | Voltage Monitored | Module Type | OV/<br>UV <sup>(2)</sup> | Description                                  |
|---------------------------|-----------------------------|-----------------------------|-------------------|-------------|--------------------------|----------------------------------------------|
| IPOK_VDD_CORE_OV          | PRG0                        | 4                           | VDD_CORE          | POK_CORE    | OV                       | Voltage Monitor for VDD_CORE                 |
| IPOK_VDDA_PMIC_IN_UV      | PRG0                        | 3                           | VMON_VSYS         | POK_SA      | UV                       | Voltage Monitor for PMIC_IN                  |
| IPOK_VDDDS_DDRIO          | PRG1                        | 4                           | VDDDS_DDR         | POK_CORE    | UV/OV                    | Voltage Monitors for DDRIO                   |
| IPOK_VDDR_CORE            | PRG1                        | 3                           | VDDR_CORE         | POK_CORE    | UV/OV                    | Voltage Monitors for VDDR_CORE               |
| IPOK_VMON_CAP MCU_GENERAL | PRG1                        | 2                           | CAP_VDDDS MCU     | POK_CORE    | UV/OV                    | Voltage Monitors for MCU mid-rail            |
| IPOK_VDDSHV_MAIN_1P8      | PRG1                        | 1                           | VMON_1P8_SOC      | POK_1P8     | UV/OV                    | Voltage Monitors for 1.8-V I/O supply in MCU |
| IPOK_VDDSHV_MAIN_3P3      | PRG1                        | 0                           | VMON_3P3_SOC      | POK_3P3     | UV/OV                    | Voltage Monitors for 3.3-V I/O supply in MCU |

- (1) The POK Index also represents the mapping index for relevant under and overvoltage status and interrupts where applicable.
- (2) UV: POK is set for undervoltage detection. OV: POK is set for overvoltage detection. UV/OV: POK monitors both OV and UV through a Ping-Pong mechanism.
- (3) Ping-pong mechanism is only applicable to PRG1.

[Figure 6-6](#) and [Figure 6-7](#) represent the block diagrams of the two POK types.



**Figure 6-6. POK Block Diagram**



pok-002

Figure 6-7. POK\_SA Block Diagram

Vref for both POK and POK\_SA types in [Figure 6-6](#) and [Figure 6-7](#) is supplied from POK module, see [Section 6.2.5.2](#)

#### 6.2.5.1.1 Configuration Registers

Configuration registers needed for POK (Supervisor Module) are given in *POK Configuration Registers*. For each POK there is one comparator that is controlled through the registers. These registers decide the functionality of the POK Comparator. It decides if it is UD/OD mode and also the threshold voltages. In the current implementation only SET\_THRESHOLD[8:1] bits are used.

Comparator threshold levels and corresponding configuration register settings are given in the following tables:

- POK\_CORE: [Table 6-11](#)
- POK\_1P8: [Table 6-12](#)
- POK\_3P3: [Table 6-13](#)

Table 6-10. POK Configuration Registers

| Register Name                                       | POK Type |
|-----------------------------------------------------|----------|
| MCU_CTRL_MMR0_POK_VDD_CORE_OV_CTRL[7:0]             | POK_CORE |
| MCU_CTRL_MMR0_POK_VDDR_CORE_UV_CTRL[7:0]            | POK_CORE |
| MCU_CTRL_MMR0_POK_VDDR_CORE_OV_CTRL[7:0]            | POK_CORE |
| MCU_CTRL_MMR0_POK_VMON_CAP_MCU_GENERAL_UV_CTRL[7:0] | POK_1P8  |
| MCU_CTRL_MMR0_POK_VMON_CAP_MCU_GENERAL_OV_CTRL[7:0] | POK_1P8  |
| MCU_CTRL_MMR0_POK_VDDSHV_MAIN_1P8_UV_CTRL[7:0]      | POK_1P8  |
| MCU_CTRL_MMR0_POK_VDDSHV_MAIN_1P8_OV_CTRL[7:0]      | POK_1P8  |
| MCU_CTRL_MMR0_POK_VDDSHV_MAIN_3P3_UV_CTRL[7:0]      | POK_3P3  |
| MCU_CTRL_MMR0_POK_VDDSHV_MAIN_3P3_OV_CTRL[7:0]      | POK_3P3  |
| MCU_CTRL_MMR0_POK_VDDS_DDRIO_UV_CTRL[7:0]           | POK_CORE |
| MCU_CTRL_MMR0_POK_VDDS_DDRIO_OV_CTRL[7:0]           | POK_CORE |

**Table 6-11. Bit Settings of POK\_CORE with VMON Threshold Values**

| POK Programmability                                           | POK Configuration Register bits |          | THRESHOLD (V)  |
|---------------------------------------------------------------|---------------------------------|----------|----------------|
|                                                               | [7]                             | [6:0]    |                |
| Under Voltage Detection                                       | 0                               | XXX XXXX | 474mV - 1.35V  |
| Over Voltage Detection                                        | 1                               | XXX XXXX | 726mV - 1.645V |
| POK_CORE VMON Selection (Under Voltage Detection)<br>hys_en=0 | 0                               | 000 0000 | 0.4743         |
|                                                               | 0                               | 000 0001 | 0.4875         |
|                                                               | 0                               | 000 0010 | 0.5000         |
|                                                               | 0                               | 000 0011 | 0.5125         |
|                                                               | 0                               | 000 0100 | 0.5250         |
|                                                               | 0                               | 000 0101 | 0.5375         |
|                                                               | 0                               | 000 0110 | 0.5513         |
|                                                               | 0                               | 000 0111 | 0.5631         |
|                                                               | 0                               | 000 1000 | 0.5754         |
|                                                               | 0                               | 000 1001 | 0.5883         |
|                                                               | 0                               | 000 1010 | 0.6017         |
|                                                               | 0                               | 000 1011 | 0.6122         |
|                                                               | 0                               | 000 1100 | 0.6268         |
|                                                               | 0                               | 000 1101 | 0.6382         |
|                                                               | 0                               | 000 1110 | 0.6500         |
|                                                               | 0                               | 000 1111 | 0.6623         |
|                                                               | 0                               | 001 0000 | 0.6750         |
|                                                               | 0                               | 001 0001 | 0.6882         |
|                                                               | 0                               | 001 0010 | 0.7020         |
|                                                               | 0                               | 001 0011 | 0.7115         |
|                                                               | 0                               | 001 0100 | 0.7262         |
|                                                               | 0                               | 001 0101 | 0.7363         |
|                                                               | 0                               | 001 0110 | 0.7521         |
|                                                               | 0                               | 001 0111 | 0.7630         |
|                                                               | 0                               | 001 1000 | 0.7742         |
|                                                               | 0                               | 001 1001 | 0.7858         |
|                                                               | 0                               | 001 1010 | 0.7977         |
|                                                               | 0                               | 001 1011 | 0.8100         |
|                                                               | 0                               | 001 1100 | 0.8226         |
|                                                               | 0                               | 001 1101 | 0.8356         |
|                                                               | 0                               | 001 1110 | 0.8491         |
|                                                               | 0                               | 001 1111 | 0.8630         |
|                                                               | 0                               | 010 0000 | 0.8774         |
|                                                               | 0                               | 010 0001 | 0.8848         |
|                                                               | 0                               | 010 0010 | 0.8999         |
|                                                               | 0                               | 010 0011 | 0.9155         |
|                                                               | 0                               | 010 0100 | 0.9235         |
|                                                               | 0                               | 010 0101 | 0.9400         |
|                                                               | 0                               | 010 0110 | 0.9485         |
|                                                               | 0                               | 010 0111 | 0.9659         |
|                                                               | 0                               | 010 1000 | 0.9748         |
|                                                               | 0                               | 010 1001 | 0.9839         |
|                                                               | 0                               | 010 1010 | 1.0030         |

Table 6-11. Bit Settings of POK\_CORE with VMON Threshold Values (continued)

| POK Programmability                                           | POK Configuration Register bits |          | THRESHOLD (V)  |
|---------------------------------------------------------------|---------------------------------|----------|----------------|
|                                                               | [7]                             | [6:0]    |                |
| Under Voltage Detection                                       | 0                               | XXX XXXX | 474mV - 1.35V  |
| Over Voltage Detection                                        | 1                               | XXX XXXX | 726mV - 1.645V |
| POK_CORE VMON Selection (Under Voltage Detection)<br>hys_en=0 | 0                               | 010 1011 | 1.0120         |
|                                                               | 0                               | 010 1100 | 1.0220         |
|                                                               | 0                               | 010 1101 | 1.0320         |
|                                                               | 0                               | 010 1110 | 1.0530         |
|                                                               | 0                               | 010 1111 | 1.0630         |
|                                                               | 0                               | 011 0000 | 1.0740         |
|                                                               | 0                               | 011 0001 | 1.0850         |
|                                                               | 0                               | 011 0010 | 1.0970         |
|                                                               | 0                               | 011 0011 | 1.1140         |
|                                                               | 0                               | 011 0100 | 1.1260         |
|                                                               | 0                               | 011 0101 | 1.1380         |
|                                                               | 0                               | 011 0110 | 1.1510         |
|                                                               | 0                               | 011 0111 | 1.1630         |
|                                                               | 0                               | 011 1000 | 1.1760         |
|                                                               | 0                               | 011 1001 | 1.1900         |
|                                                               | 0                               | 011 1010 | 1.1960         |
|                                                               | 0                               | 011 1011 | 1.2100         |
|                                                               | 0                               | 011 1100 | 1.2240         |
|                                                               | 0                               | 011 1101 | 1.2380         |
|                                                               | 0                               | 011 1110 | 1.2530         |
|                                                               | 0                               | 011 1111 | 1.2610         |
|                                                               | 0                               | 100 0000 | 1.2760         |
|                                                               | 0                               | 100 0001 | 1.2920         |
|                                                               | 0                               | 100 0010 | 1.3000         |
|                                                               | 0                               | 100 0011 | 1.3160         |
|                                                               | 0                               | 100 0100 | 1.3240         |
|                                                               | 0                               | 100 0101 | 1.3410         |
|                                                               | 0                               | 100 0110 | 1.3500         |

**Table 6-11. Bit Settings of POK\_CORE with VMON Threshold Values (continued)**

| POK Programmability                                          | POK Configuration Register bits |          | THRESHOLD (V)  |
|--------------------------------------------------------------|---------------------------------|----------|----------------|
|                                                              | [7]                             | [6:0]    |                |
| Under Voltage Detection                                      | 0                               | XXX XXXX | 474mV - 1.35V  |
| Over Voltage Detection                                       | 1                               | XXX XXXX | 726mV - 1.645V |
| POK_CORE VMON Selection (Over Voltage Detection)<br>hys_en=0 | 1                               | 000 0000 | 0.7262         |
|                                                              | 1                               | 000 0001 | 0.7363         |
|                                                              | 1                               | 000 0010 | 0.7521         |
|                                                              | 1                               | 000 0011 | 0.7630         |
|                                                              | 1                               | 000 0100 | 0.7743         |
|                                                              | 1                               | 000 0101 | 0.7858         |
|                                                              | 1                               | 000 0110 | 0.7977         |
|                                                              | 1                               | 000 0111 | 0.8100         |
|                                                              | 1                               | 000 1000 | 0.8226         |
|                                                              | 1                               | 000 1001 | 0.8357         |
|                                                              | 1                               | 000 1010 | 0.8491         |
|                                                              | 1                               | 000 1011 | 0.8630         |
|                                                              | 1                               | 000 1100 | 0.8774         |
|                                                              | 1                               | 000 1101 | 0.8848         |
|                                                              | 1                               | 000 1110 | 0.8999         |
|                                                              | 1                               | 000 1111 | 0.9155         |
|                                                              | 1                               | 001 0000 | 0.9236         |
|                                                              | 1                               | 001 0001 | 0.9400         |
|                                                              | 1                               | 001 0010 | 0.9485         |
|                                                              | 1                               | 001 0011 | 0.9659         |
|                                                              | 1                               | 001 0100 | 0.9748         |
|                                                              | 1                               | 001 0101 | 0.9839         |
|                                                              | 1                               | 001 0110 | 1.0030         |
|                                                              | 1                               | 001 0111 | 1.0120         |
|                                                              | 1                               | 001 1000 | 1.0220         |
|                                                              | 1                               | 001 1001 | 1.0320         |
|                                                              | 1                               | 001 1010 | 1.0530         |
|                                                              | 1                               | 001 1011 | 1.0630         |
|                                                              | 1                               | 001 1100 | 1.0740         |
|                                                              | 1                               | 001 1101 | 1.0850         |
|                                                              | 1                               | 001 1110 | 1.0970         |
|                                                              | 1                               | 001 1111 | 1.1140         |
|                                                              | 1                               | 010 0000 | 1.1260         |
|                                                              | 1                               | 010 0001 | 1.1380         |
|                                                              | 1                               | 010 0010 | 1.1510         |
|                                                              | 1                               | 010 0011 | 1.1630         |
|                                                              | 1                               | 010 0100 | 1.1760         |
|                                                              | 1                               | 010 0101 | 1.1900         |
|                                                              | 1                               | 010 0110 | 1.1960         |
|                                                              | 1                               | 010 0111 | 1.2100         |
|                                                              | 1                               | 010 1000 | 1.2240         |
|                                                              | 1                               | 010 1001 | 1.2380         |
|                                                              | 1                               | 010 1010 | 1.2530         |

**Table 6-11. Bit Settings of POK\_CORE with VMON Threshold Values (continued)**

| POK Programmability                                          | POK Configuration Register bits |          | THRESHOLD (V)  |
|--------------------------------------------------------------|---------------------------------|----------|----------------|
|                                                              | [7]                             | [6:0]    |                |
| Under Voltage Detection                                      | 0                               | XXX XXXX | 474mV - 1.35V  |
| Over Voltage Detection                                       | 1                               | XXX XXXX | 726mV - 1.645V |
| POK_CORE VMON Selection (Over Voltage Detection)<br>hys_en=0 | 1                               | 010 1011 | 1.2610         |
|                                                              | 1                               | 010 1100 | 1.2760         |
|                                                              | 1                               | 010 1101 | 1.2920         |
|                                                              | 1                               | 010 1110 | 1.3000         |
|                                                              | 1                               | 010 1111 | 1.3160         |
|                                                              | 1                               | 011 0000 | 1.3240         |
|                                                              | 1                               | 011 0001 | 1.3410         |
|                                                              | 1                               | 011 0010 | 1.3500         |
|                                                              | 1                               | 011 0011 | 1.3670         |
|                                                              | 1                               | 011 0100 | 1.3760         |
|                                                              | 1                               | 011 0101 | 1.3850         |
|                                                              | 1                               | 011 0110 | 1.4040         |
|                                                              | 1                               | 011 0111 | 1.4130         |
|                                                              | 1                               | 011 1000 | 1.4230         |
|                                                              | 1                               | 011 1001 | 1.4420         |
|                                                              | 1                               | 011 1010 | 1.4520         |
|                                                              | 1                               | 011 1011 | 1.4620         |
|                                                              | 1                               | 011 1100 | 1.4720         |
|                                                              | 1                               | 011 1101 | 1.4830         |
|                                                              | 1                               | 011 1110 | 1.5040         |
|                                                              | 1                               | 011 1111 | 1.5150         |
|                                                              | 1                               | 100 0000 | 1.5260         |
|                                                              | 1                               | 100 0001 | 1.5370         |
|                                                              | 1                               | 100 0010 | 1.5480         |
|                                                              | 1                               | 100 0011 | 1.5600         |
|                                                              | 1                               | 100 0100 | 1.5710         |
|                                                              | 1                               | 100 0101 | 1.5830         |
|                                                              | 1                               | 100 0110 | 1.5950         |
|                                                              | 1                               | 100 0111 | 1.6070         |
|                                                              | 1                               | 100 1000 | 1.6200         |
|                                                              | 1                               | 100 1001 | 1.6320         |
|                                                              | 1                               | 100 1010 | 1.6450         |

**Table 6-12. Bit Settings of POK\_1P8 with VMON Threshold Values**

| POK Programmability                        | POK Configuration Register bits |          | THRESHOLD (V)  |
|--------------------------------------------|---------------------------------|----------|----------------|
|                                            | [7]                             | [6:0]    |                |
| Under Voltage Detection                    | 0                               | XXX XXXX | 1.44V - 2.173V |
| Over Voltage Detection                     | 1                               | XXX XXXX | 1.44V - 2.173V |
| POK_1P8 (Under Voltage Detection) hys_en=0 | 0                               | 010 0000 | 1.44           |
|                                            | 0                               | 010 0001 | 1.452          |
|                                            | 0                               | 010 0010 | 1.477          |
|                                            | 0                               | 010 0011 | 1.502          |
|                                            | 0                               | 010 0100 | 1.515          |
|                                            | 0                               | 010 0101 | 1.543          |
|                                            | 0                               | 010 0110 | 1.556          |
|                                            | 0                               | 010 0111 | 1.585          |
|                                            | 0                               | 010 1000 | 1.6            |
|                                            | 0                               | 010 1001 | 1.615          |
|                                            | 0                               | 010 1010 | 1.645          |
|                                            | 0                               | 010 1011 | 1.661          |
|                                            | 0                               | 010 1100 | 1.677          |
|                                            | 0                               | 010 1101 | 1.694          |
|                                            | 0                               | 010 1110 | 1.728          |
|                                            | 0                               | 010 1111 | 1.745          |
|                                            | 0                               | 011 0000 | 1.763          |
|                                            | 0                               | 011 0001 | 1.781          |
|                                            | 0                               | 011 0010 | 1.799          |
|                                            | 0                               | 011 0011 | 1.828          |
|                                            | 0                               | 011 0100 | 1.848          |
|                                            | 0                               | 011 0101 | 1.868          |
|                                            | 0                               | 011 0110 | 1.888          |
|                                            | 0                               | 011 0111 | 1.909          |
|                                            | 0                               | 011 1000 | 1.93           |
|                                            | 0                               | 011 1001 | 1.952          |
|                                            | 0                               | 011 1010 | 1.963          |
|                                            | 0                               | 011 1011 | 1.986          |
|                                            | 0                               | 011 1100 | 2.009          |
|                                            | 0                               | 011 1101 | 2.032          |
|                                            | 0                               | 011 1110 | 2.056          |
|                                            | 0                               | 011 1111 | 2.069          |
|                                            | 0                               | 100 0000 | 2.094          |
|                                            | 0                               | 100 0001 | 2.12           |
|                                            | 0                               | 100 0010 | 2.133          |
|                                            | 0                               | 100 0011 | 2.159          |
|                                            | 0                               | 100 0100 | 2.173          |

**Table 6-12. Bit Settings of POK\_1P8 with VMON Threshold Values (continued)**

| POK Programmability                        | POK Configuration Register bits |          | THRESHOLD (V)  |
|--------------------------------------------|---------------------------------|----------|----------------|
|                                            | [7]                             | [6:0]    |                |
| Under Voltage Detection                    | 0                               | XXX XXXX | 1.44V - 2.173V |
| Over Voltage Detection                     | 1                               | XXX XXXX | 1.44V - 2.173V |
| POK_1P8 (Under Voltage Detection) hys_en=0 | 1                               | 000 1100 | 1.44           |
|                                            | 1                               | 000 1101 | 1.452          |
|                                            | 1                               | 000 1110 | 1.477          |
|                                            | 1                               | 000 1111 | 1.502          |
|                                            | 1                               | 001 0000 | 1.515          |
|                                            | 1                               | 001 0001 | 1.543          |
|                                            | 1                               | 001 0010 | 1.556          |
|                                            | 1                               | 001 0011 | 1.585          |
|                                            | 1                               | 001 0100 | 1.6            |
|                                            | 1                               | 001 0101 | 1.615          |
|                                            | 1                               | 001 0110 | 1.645          |
|                                            | 1                               | 001 0111 | 1.661          |
|                                            | 1                               | 001 1000 | 1.677          |
|                                            | 1                               | 001 1001 | 1.694          |
|                                            | 1                               | 001 1010 | 1.728          |
|                                            | 1                               | 001 1011 | 1.745          |
|                                            | 1                               | 001 1100 | 1.763          |
|                                            | 1                               | 001 1101 | 1.781          |
|                                            | 1                               | 001 1110 | 1.799          |
|                                            | 1                               | 001 1111 | 1.828          |
|                                            | 1                               | 010 0000 | 1.848          |
|                                            | 1                               | 010 0001 | 1.868          |
|                                            | 1                               | 010 0010 | 1.888          |
|                                            | 1                               | 010 0011 | 1.909          |
|                                            | 1                               | 010 0100 | 1.93           |
|                                            | 1                               | 010 0101 | 1.952          |
|                                            | 1                               | 010 0110 | 1.963          |
|                                            | 1                               | 010 0111 | 1.986          |
|                                            | 1                               | 010 1000 | 2.009          |
|                                            | 1                               | 010 1001 | 2.032          |
|                                            | 1                               | 010 1010 | 2.056          |
|                                            | 1                               | 010 1011 | 2.069          |
|                                            | 1                               | 010 1100 | 2.094          |
|                                            | 1                               | 010 1101 | 2.12           |
|                                            | 1                               | 010 1110 | 2.133          |
|                                            | 1                               | 010 1111 | 2.159          |
|                                            | 1                               | 011 0000 | 2.173          |

**Table 6-13. Bit Settings of POK\_3P3 with VMON Threshold Values**

| POK Programmability                        | POK Configuration Register bits |          | THRESHOLD (V)   |
|--------------------------------------------|---------------------------------|----------|-----------------|
|                                            | [7]                             | [6:0]    |                 |
| Under Voltage Detection                    | 0                               | XXX XXXX | 1.427V - 3.982V |
| Over Voltage Detection                     | 1                               | XXX XXXX | 2.184V - 3.958V |
| POK_3P3 (Under Voltage Detection) hys_en=0 | 0                               | 000 0000 | 1.427           |
|                                            | 0                               | 000 0001 | 1.466           |
|                                            | 0                               | 000 0010 | 1.501           |
|                                            | 0                               | 000 0011 | 1.545           |
|                                            | 0                               | 000 0100 | 1.576           |
|                                            | 0                               | 000 0101 | 1.616           |
|                                            | 0                               | 000 0110 | 1.658           |
|                                            | 0                               | 000 0111 | 1.694           |
|                                            | 0                               | 000 1000 | 1.731           |
|                                            | 0                               | 000 1001 | 1.769           |
|                                            | 0                               | 000 1010 | 1.81            |
|                                            | 0                               | 000 1011 | 1.841           |
|                                            | 0                               | 000 1100 | 1.885           |
|                                            | 0                               | 000 1101 | 1.919           |
|                                            | 0                               | 000 1110 | 1.955           |
|                                            | 0                               | 000 1111 | 1.992           |
|                                            | 0                               | 001 0000 | 2.03            |
|                                            | 0                               | 001 0001 | 2.07            |
|                                            | 0                               | 001 0010 | 2.111           |
|                                            | 0                               | 001 0011 | 2.14            |
|                                            | 0                               | 001 0100 | 2.184           |
|                                            | 0                               | 001 0101 | 2.215           |
|                                            | 0                               | 001 0110 | 2.262           |
|                                            | 0                               | 001 0111 | 2.295           |
|                                            | 0                               | 001 1000 | 2.329           |
|                                            | 0                               | 001 1001 | 2.363           |
|                                            | 0                               | 001 1010 | 2.399           |
|                                            | 0                               | 001 1011 | 2.436           |
|                                            | 0                               | 001 1100 | 2.474           |
|                                            | 0                               | 001 1101 | 2.513           |
|                                            | 0                               | 001 1110 | 2.554           |
|                                            | 0                               | 001 1111 | 2.596           |
|                                            | 0                               | 010 0000 | 2.639           |
|                                            | 0                               | 010 0001 | 2.661           |
|                                            | 0                               | 010 0010 | 2.706           |
|                                            | 0                               | 010 0011 | 2.753           |
|                                            | 0                               | 010 0100 | 2.778           |
|                                            | 0                               | 010 0101 | 2.827           |
|                                            | 0                               | 010 0110 | 2.853           |
|                                            | 0                               | 010 0111 | 2.905           |
|                                            | 0                               | 010 1000 | 2.932           |
|                                            | 0                               | 010 1001 | 2.959           |
|                                            | 0                               | 010 1010 | 3.015           |
|                                            | 0                               | 010 1011 | 3.044           |

**Table 6-13. Bit Settings of POK\_3P3 with VMON Threshold Values (continued)**

| POK Programmability                        | POK Configuration Register bits |          | THRESHOLD (V)   |
|--------------------------------------------|---------------------------------|----------|-----------------|
|                                            | [7]                             | [6:0]    |                 |
| Under Voltage Detection                    | 0                               | XXX XXXX | 1.427V - 3.982V |
| Over Voltage Detection                     | 1                               | XXX XXXX | 2.184V - 3.958V |
| POK_3P3 (Under Voltage Detection) hys_en=0 | 0                               | 010 1100 | 3.074           |
|                                            | 0                               | 010 1101 | 3.104           |
|                                            | 0                               | 010 1110 | 3.166           |
|                                            | 0                               | 010 1111 | 3.198           |
|                                            | 0                               | 011 0000 | 3.231           |
|                                            | 0                               | 011 0001 | 3.264           |
|                                            | 0                               | 011 0010 | 3.298           |
|                                            | 0                               | 011 0011 | 3.35            |
|                                            | 0                               | 011 0100 | 3.386           |
|                                            | 0                               | 011 0101 | 3.423           |
|                                            | 0                               | 011 0110 | 3.46            |
|                                            | 0                               | 011 0111 | 3.498           |
|                                            | 0                               | 011 1000 | 3.538           |
|                                            | 0                               | 011 1001 | 3.577           |
|                                            | 0                               | 011 1010 | 3.598           |
|                                            | 0                               | 011 1011 | 3.639           |
|                                            | 0                               | 011 1100 | 3.681           |
|                                            | 0                               | 011 1101 | 3.724           |
|                                            | 0                               | 011 1110 | 3.769           |
|                                            | 0                               | 011 1111 | 3.791           |
|                                            | 0                               | 100 0000 | 3.837           |
|                                            | 0                               | 100 0001 | 3.884           |
|                                            | 0                               | 100 0010 | 3.908           |
|                                            | 0                               | 100 0011 | 3.957           |
|                                            | 0                               | 100 0100 | 3.982           |

**Table 6-13. Bit Settings of POK\_3P3 with VMON Threshold Values (continued)**

| POK Programmability                       | POK Configuration Register bits |          | THRESHOLD (V)   |
|-------------------------------------------|---------------------------------|----------|-----------------|
|                                           | [7]                             | [6:0]    |                 |
| Under Voltage Detection                   | 0                               | XXX XXXX | 1.427V - 3.982V |
| Over Voltage Detection                    | 1                               | XXX XXXX | 2.184V - 3.958V |
| POK_3P3 (Over Voltage Detection) hys_en=0 | 1                               | 000 0000 | 2.184           |
|                                           | 1                               | 000 0001 | 2.215           |
|                                           | 1                               | 000 0010 | 2.262           |
|                                           | 1                               | 000 0011 | 2.295           |
|                                           | 1                               | 000 0100 | 2.329           |
|                                           | 1                               | 000 0101 | 2.363           |
|                                           | 1                               | 000 0110 | 2.399           |
|                                           | 1                               | 000 0111 | 2.436           |
|                                           | 1                               | 000 1000 | 2.474           |
|                                           | 1                               | 000 1001 | 2.513           |
|                                           | 1                               | 000 1010 | 2.554           |
|                                           | 1                               | 000 1011 | 2.596           |
|                                           | 1                               | 000 1100 | 2.639           |
|                                           | 1                               | 000 1101 | 2.661           |
|                                           | 1                               | 000 1110 | 2.707           |
|                                           | 1                               | 000 1111 | 2.754           |
|                                           | 1                               | 001 0000 | 2.778           |
|                                           | 1                               | 001 0001 | 2.827           |
|                                           | 1                               | 001 0010 | 2.853           |
|                                           | 1                               | 001 0011 | 2.905           |
|                                           | 1                               | 001 0100 | 2.932           |
|                                           | 1                               | 001 0101 | 2.959           |
|                                           | 1                               | 001 0110 | 3.016           |
|                                           | 1                               | 001 0111 | 3.045           |
|                                           | 1                               | 001 1000 | 3.074           |
|                                           | 1                               | 001 1001 | 3.104           |
|                                           | 1                               | 001 1010 | 3.166           |
|                                           | 1                               | 001 1011 | 3.198           |
|                                           | 1                               | 001 1100 | 3.231           |
|                                           | 1                               | 001 1101 | 3.264           |
|                                           | 1                               | 001 1110 | 3.298           |
|                                           | 1                               | 001 1111 | 3.35            |
|                                           | 1                               | 010 0000 | 3.386           |
|                                           | 1                               | 010 0001 | 3.423           |
|                                           | 1                               | 010 0010 | 3.46            |
|                                           | 1                               | 010 0011 | 3.499           |
|                                           | 1                               | 010 0100 | 3.538           |
|                                           | 1                               | 010 0101 | 3.578           |
|                                           | 1                               | 010 0110 | 3.598           |
|                                           | 1                               | 010 0111 | 3.639           |
|                                           | 1                               | 010 1000 | 3.682           |
|                                           | 1                               | 010 1001 | 3.725           |
|                                           | 1                               | 010 1010 | 3.769           |
|                                           | 1                               | 010 1011 | 3.792           |

**Table 6-13. Bit Settings of POK\_3P3 with VMON Threshold Values (continued)**

| POK Programmability                       | POK Configuration Register bits |          | THRESHOLD (V)   |
|-------------------------------------------|---------------------------------|----------|-----------------|
|                                           | [7]                             | [6:0]    |                 |
| Under Voltage Detection                   | 0                               | XXX XXXX | 1.427V - 3.982V |
| Over Voltage Detection                    | 1                               | XXX XXXX | 2.184V - 3.958V |
| POK_3P3 (Over Voltage Detection) hys_en=0 | 1                               | 010 1100 | 3.838           |
|                                           | 1                               | 010 1101 | 3.885           |
|                                           | 1                               | 010 1110 | 3.909           |
|                                           | 1                               | 010 1111 | 3.958           |

### 6.2.5.2 Power on Reset (POR) Module

This section describes the Power on Reset (POR) module.

#### 6.2.5.2.1 POR Overview

POR module in this family of devices is responsible for detecting proper operating voltage levels on VDDA\_MCU (under voltage), and both under and over voltages for analog supply in MCU domain.

Table 6-14 shows POR modules allocation within device domains.

**Table 6-14. POR Modules Allocation within Device Domains**

| Module Instance | Domain |      |
|-----------------|--------|------|
|                 | MCU    | MAIN |
| POR0            | ✓      | -    |

#### 6.2.5.2.2 POR Integration

The device supports one instance of a Power on Reset (POR) module - MCU\_POR0. MCU\_POR0 is located in MCU domain. Figure 6-8 shows the integration of MCU\_POR0.

**Figure 6-8. POR Integration**

**Table 6-15. POR Modules**

| POR Module Instance Name | PRG Index | POK Index | Voltage Monitored | Module Type | OVI/UV <sup>(1)</sup> | Description                                                                |
|--------------------------|-----------|-----------|-------------------|-------------|-----------------------|----------------------------------------------------------------------------|
| POKHV                    | PRG0      | 2         | VDDA_MCU 1.8 V    | POR         | UV                    | Internal POR generation and power monitoring for 1.8-V supply and VDD_CORE |
| POKLVA                   | PRG0      | 1         | VDDA_MCU 1.8 V    | POR         | OV                    | Internal POR generation and power monitoring for 1.8-V supply and VDD_CORE |
| POKLVB                   | PRG0      | 0         | VDD_CORE          | POR         | UV                    | Internal POR generation and power monitoring for 1.8-V supply and VDD_CORE |

- (1) UV: POK is set for under voltage detection. OV: POK is set for over voltage detection. UV/OV: POK monitors both OV and UV via Ping-Pong mechanism.

### 6.2.5.3 PoR/Reset Generator (PRG) Modules

This device has two PoR/Reset Generator (PRG) modules – PRG\_PP\_0 and PRG\_PP\_1. Both of these modules are located in the MCU domain.

#### 6.2.5.3.1 PRG Overview

A PRG module is responsible for implementing enable/disable controls and event/interrupt masking logic on all POK outputs.

Figure 6-9 shows the PRG module overview.



Figure 6-9. PRG0 Overview

Figure 6-10 shows the PRG module overview.



**Figure 6-10. PRG1 Overview**

#### 6.2.5.4 Power Glitch Detect (PGD) Modules

A Power Glitch Detect (PGD) circuit is used to detect short duration “glitches” on the core and MPU power supplies. The PGD provides a low output when no glitch is detected and a high output when a glitch is detected.

Table 6-16 shows PGD modules allocation within device domains.

**Table 6-16. PGD Allocation within Device Domains**

| Module Instance | Domain |     |      |
|-----------------|--------|-----|------|
|                 | WKUP   | MCU | MAIN |
| IPGD_VDD_CORE   | -      | ✓   | -    |

Figure 6-11 shows the PGD block diagram.



Figure 6-11. PGD Block Diagram

Table 6-17 Summarizes the PGD integration.

Table 6-17. PGD Integration Summary

| Module Instance | Monitored Voltage | PGD Control/Status Registers <sup>(1)</sup> |
|-----------------|-------------------|---------------------------------------------|
| IPGD_VDD_CORE   | VDD_CORE          |                                             |

(1) For more information about control registers, see , *Control Module (CTRL\_MMR)*.

#### Note

A flag status bit in corresponding STAT register is cleared by clearing the [30] RSTB bit in the corresponding CTRL register, see for STAT and CTRL registers for a certain PGD module.

#### Note

For more information on the interconnects, see , *System Interconnect*.

For more information on the power, reset and clock management, see the corresponding sections within , *Device Configuration*.

For more information on the device interrupt controllers, see , *Interrupt Controllers*.

### 6.2.5.5 Voltage and Thermal Manager (VTM)

#### 6.2.5.5.1 VTM Overview

This section describes the Voltage and Thermal Manager (VTM) module in the device.

The VTM module supports voltage and thermal management of the device by providing control of on-chip temperature sensors.

The device supports a single VTM module, VTM0, which is located in the WKUP domain. VTM0 has two associated temperature monitors, Temp\_Sensor\_Main\_0, and Temp\_Sensor\_Main\_1, each of which are located near hotspots in the device die.

Figure 6-12 shows VTM module allocation within device domains.



**Figure 6-12. VTM Overview**

#### 6.2.5.5.1.1 VTM Features

VTM module supports the following features:

- Programming of temperature-crossing thresholds
- Signals when programmed thresholds are exceeded - up to 3 alerts:
  - Three full reference 10-bit temperature threshold points, THPT1, THPT2 and THPT0.
  - Two relative 4-bit delta values vs THPT1 (one an increment and another a decrement), each able to set additional threshold point, THPT2 and THPT0.
- Supports up to 8 temperature monitors
- Allows resolution of 0.5°C for temperature reading and threshold point temperature alert/interrupt generation.
- Supports PMIC/LDO set-up with Class-0 VDD-VID settings
- Support of tentative customization of OPP voltage per device (in support of multiple OPPs)

- AVS-voltage or thermal management for up to 8 voltage domains
- Maximum temperature alert
- Supports one shot sampling mode and continuous monitoring mode for the sensors
- Contains registers with reset defaults from e-fuse values needed to supports SR-Class0 via e-fuse/ manufacturing calibration and firmware and/or software using those values to program the PMIC/LDO with the Class-0 VDD-VID setting.
- Contains registers with reset defaults from e-fuse values per SOC for a tentative customization of OPP voltage per device (in support of multiple OPPs/DVFS).
- Supports a group of registers for up to 8 core voltage domains that require AVS-voltage management or thermal management in a contiguous memory region to support access privilege control by Firewall within its address space.
- Core voltage domains that don't require any SR-Class0 or thermal management shall not be controlled or map to any of the MCU\_VTM0 voltage domain group.
- Contains registers with reset defaults from e-fuse values or TIE-OFFs to provide control for temperature monitors and interrupt generation needed to support thermal management customized if necessary in a per voltage domain basis.
- Provides register control, status and interrupt generation, and alerts for up to 8 temperature monitors.
- Stores in the registers the defaults for temperature detection threshold points and other temperature monitor control values for Firmware usage.
- Samples, captures, and allows for register read of the on-die temperature monitor present reading.
- Provides interrupt and status for out of range temperature reading.
- Provides one full reference 10-bit temperature threshold point, THPT1.
- Provides 2 relative 3-bit delta values versus THPT1, one an increment and another a decrement, which yields 2 additional threshold points, THPT2 and THPT0, in close proximity to THPT1.
- Provides 3 temperature threshold point alert signals (level), GT\_TH1\_ALERT, GT\_TH2\_ALERT and LT\_TH0\_ALERT, for each one of the up to 8 temperature monitors.
- Provides 3 temperature threshold point interrupt flags, GT\_TH1\_INT, GT\_TH2\_INT and LT\_TH0\_INT, for each one of the up to 8 voltage domains.
- Provides 3 temperature threshold point interrupts (level-only) for the entire MCU\_VTM0, GT\_TH1\_INT, GT\_TH2\_INT and LT\_TH0\_INT, which are driven out of MCU\_VTM0 and are shared by the 8 voltage domains. The output port interrupts correspond to the OR function of the contributions of the 8 voltage domains.
- Software must read the corresponding flags in each of the 8 voltage domains to identify which voltage domain is active.
- Allows for temperature reading and threshold point temperature alert and interrupt generation with 0.5°C of resolution.

---

#### Note

The VTM in this family of devices implements two temperature monitors.

---

#### 6.2.5.5.1.2 VTM Not Supported Features

- No support for AVS-Class0 with temperature compensation (AVS0 + TC)
- No support internal to MCU\_VTM0 for any AVS Class technology other than Class0
- No support for K1 or K2 4/6-bit VCNTL/VID parallel or 2-step interfaces.
- No integrated I2C inside VTM
- No direct hardware triggering of I2C transactions by VTM. Only interrupt and event generation is supported.
- No support for voltage and thermal management of I/O voltage domains. Only core domain voltage/thermal management is supported.
- VTM0 does not contain or support register groups or control hooks for I/O voltage domains.
- Core voltage domains that do not require any voltage or thermal management are not controlled or mapped to any of the VTM0 voltage domain groups.
- Everything else not explicitly listed in [Section 6.2.5.5.1.1](#) is not supported.
- No oversampling of the temperature reading
- No support for eFuse defaults of all register values

### 6.2.5.5.2 VTM Functional Description

#### 6.2.5.5.2.1 VTM Temperature Status and Thermal Management

VTM module provides temperature reading and interrupt/alert information for thermal management.

---

#### Note

VTM functions are controlled through the DMSC. For more information how to use DMSC, see the [TISCI API](#).

VTM controls the temperature monitors in the die. A single VTM can control up to 8 monitors via its registers. The VTM enables the sensors periodically to keep the reported data continually updated because the device sensors are not periodical. The temperature value coming back from the monitor is captured and reported by the VTM registers. The VTM keeps the sensors in reset state when not enabled to save power and reduce sensor usage to maximize the sensor life.

---

#### Note

A temperature diode sensor is used to measure silicon junction temperature, for more information about temperature diode, see the device-specific Datasheet.

#### 6.2.5.5.2.1.1 10-bit Temperature Values Versus Temperature

Table 6-18 shows a table lookup method for translating code to temperature from temperature monitors which correspond to the temperature measured read from the VTM0\_VTM\_TMPSENS\_STAT\_J [9-0] DATA\_OUT bitfields. Table 6-18 also provides the values for the temperatures coded in VTM0\_VTM\_MISC\_CTRL2 [25-16] MAXT\_OUTRG\_ALERT\_THR0 and VTM0\_VTM\_MISC\_CTRL2 [9-0] MAXT\_OUTRG\_ALERT\_THR thresholds.

**Table 6-18. Temperature Translation Table**

| Parameter Type               | Value  |        |      |       |       |       |        |        |        |
|------------------------------|--------|--------|------|-------|-------|-------|--------|--------|--------|
|                              | -40    | -25    | 0    | 25    | 50    | 75    | 100    | 125    | 150    |
| Temperature [°C] (rounded)   | -40    | -25    | 0    | 25    | 50    | 75    | 100    | 125    | 150    |
| Temperature [°C] (unrounded) | -40.03 | -24.95 | 0.01 | 25.02 | 49.94 | 75.03 | 100.02 | 124.97 | 150.00 |
| DATA_OUT Code                | 28     | 77     | 164  | 260   | 366   | 485   | 620    | 773    | 949    |

Table 6-19 shows a table that gives coefficients of polynomial to calculate code or temperature. The equation to calculate code or temperature is:

$$y = a4 \times x^4 + a3 \times x^3 + a2 \times x^2 + a1 \times x + a0$$

**Table 6-19. Equation Method to Calculate Code or Temperature**

| Function              | Unit                  | Coefficient |            |             |            |             |
|-----------------------|-----------------------|-------------|------------|-------------|------------|-------------|
|                       |                       | a4          | a3         | a2          | a1         | a0          |
| Code = f(Temperature) | Decimal value of code | 4.9847E-08  | 1.6972E-05 | 6.8759E-03  | 3.6509E+00 | 1.6407E+02  |
| Temperature = f(Code) | °C                    | -9.2627E-12 | 6.0373E-08 | -1.7058E-04 | 3.2512E-01 | -4.9002E+01 |

## 6.3 Reset

This chapter describes the device reset signals and contains details on reset management.

|                           |     |
|---------------------------|-----|
| 6.3.1 Overview.....       | 571 |
| 6.3.2 Reset Sources.....  | 583 |
| 6.3.3 Reset Status.....   | 584 |
| 6.3.4 Reset Controls..... | 587 |

|                          |     |
|--------------------------|-----|
| 6.3.5 Reset Details..... | 590 |
|--------------------------|-----|

### 6.3.1 Overview

#### Reset Introduction

A reset is designed to bring a device or subsystem into a known state. Resets occur after power up events, as well as through software and hardware reset requests. This section introduces the device reset capabilities and functionality.

#### Device Resets

The Device Power-on-Reset (POR) is controlled by the external pin MCU\_PORz. This pin is driven by an external (off-chip) "Power-Good" Circuit or Power Management IC (PMIC). The MCU\_PORz pin should be held active LOW (0) during the entire power-up phase. The device should be held in reset until all power supplies are stable with an additional delay for the High Frequency Oscillator (HFOSC0) clock to stabilize.

The SoC is divided into two separate functional Reset Domains: MCU Reset Domain and MAIN Reset Domain (each containing specific processing cores and peripherals).

- MCU Reset Domain: Managed by the MCU Domain, PLLCTRL and PSC, this includes ARM® Cortex®- M4F MCU Processor (M4FSS).
- MAIN Reset Domain: Managed by the MAIN Domain, PLLCTRL and PSC, this includes the high performance application Arm Cortex-A53 cores (A53SS), Device Management and Low Power Management (DM R5F), Security Controller (SMS0 - Dual core M4F) and Programmable Real-Time Unit Subsystem (PRUSS0).
- A subset of MAIN and MCU domains is logically grouped ad WKUP domain. This domain is always on and is responsible for device low power management. DM R5F is located in this domain. See [Figure 6-15](#).
- Security controller SMS has 2 submodules:
  - TIFS (TI Foundational Security) has a dedicated M4F responsible for device security
  - HSM (Hardware Security Mode) has a dedicated M4F responsible for customer/application centric security (such as AutoSAR)

[Figure 6-13](#) illustrates the high-level reset domain partition.



Figure 6-13. High Level Reset Control

### 6.3.1.1 MCU Domain Supported Resets

- Power-On-Resets
  - MCU\_PORx device pin: This power-on-reset will reset the entire device including MCU and MAIN domains.
- Warm Resets
  - MCU\_RESETz device pin
  - MCU domain software warm reset
  - MCU domain ESM error reset
  - SMS cold reset

The warm resets listed above will reset the entire device including MCU and MAIN domains.

- Local Module Resets
  - MCU domain LPSC module local reset: This reset is generated by the MCU PSC to locally reset the M4F CPU core

### 6.3.1.2 MAIN Domain Supported Resets

- Power-On-Resets
  - MAIN domain software POR reset
  - MAIN domain hardware POR reset generated by MCU\_PORz
- Warm Resets
  - RESETz\_REQ device pin
  - MAIN domain ESM error reset
  - MAIN domain software warm reset
  - SMS cold reset
  - MCU domain warm reset will also generate a MAIN domain warm reset
- Local Module Resets
  - MAIN domain LPSC module local reset: This reset is generated by the MAIN PSC to locally reset the Processor cores (A53, SMS M4F, DM R5F, PRUSS)

The device can be configured via software such that a Main domain resets can be isolated from MCU domain. When the MCU domain is configured for reset isolation, MAIN domain resets will only reset the MAIN domain and the MCU domain will remain unaffected by all MAIN domain resets. All MCU domain resets will cause a reset to the entire device (including MAIN and MCU domains).

### 6.3.1.3 High-Level Reset Flow

**High Level Reset Flow** explains the high-level device power-up and reset use cases.



**Figure 6-14. High Level Reset Flow**

#### 6.3.1.4 Reset Terminology

|                        |                                                                       |
|------------------------|-----------------------------------------------------------------------|
| <b>DM</b>              | Device Management (including Low Power Management)                    |
| <b>POR</b>             | Power-On-Reset                                                        |
| <b>ESM</b>             | Error Signaling Module                                                |
| <b>Reset Isolation</b> | The module or domain is exempt from specific resets                   |
| <b>PSC</b>             | Power Sleep Controller                                                |
| <b>LPSC</b>            | Local Power Sleep Controller                                          |
| <b>PD</b>              | Power Domain                                                          |
| <b>VD</b>              | Voltage Domain                                                        |
| <b>PRG</b>             | Power Reset Generator                                                 |
| <b>POK</b>             | Power OK                                                              |
| <b>PGD</b>             | Power Glitch Detector                                                 |
| <b>PLLCTRL</b>         | PLL and Reset Controller                                              |
| <b>HHV</b>             | High Heating Value mode (IO Pin Fail-safe Control (Tri-State Output)) |
| <b>VTM</b>             | Voltage and Temperature Monitor                                       |
| <b>HFOSC</b>           | Internal Device High-Frequency Oscillator                             |
| <b>SMS</b>             | Security Management Subsystem                                         |
| <b>TIFS</b>            | Texas Instruments Foundational Security                               |
| <b>HSM</b>             | Hardware Security Module                                              |

### 6.3.1.5 Reset Architecture

### **6.3.1.5.1 Reset Architecture Block Diagram**

[Reset Architecture Block Diagram](#) shows the device reset architecture block diagram. It describes the device reset sub-modules and critical internal signal interconnections.



**Figure 6-15. Reset Architecture Block Diagram**

**6.3.1.5.2 SoC Reset Hardware Logic Diagram**

**SoC Reset Hardware Logic Diagram** shows the reset hardware logic diagram. It describes the MAIN and MCU reset domains and processors connections as well as the available reset sources including reset pins and CTRLMMRs.



**Figure 6-16. SoC Reset Hardware Logic Diagram**

**6.3.1.5.3 MCU Domain Reset Hardware Logic Diagram**

**MCU Domain Reset Hardware Logic Diagram** shows the external and internal signals associated with the MCU domain resets.



**Figure 6-17. MCU Domain Reset Hardware Logic Diagram**

#### 6.3.1.5.4 MAIN Domain Reset and PORz Hardware Logic Diagrams



Figure 6-18. MAIN Domain Reset Hardware Logic Diagram



Figure 6-19. MAIN Domain PORz Hardware Logic Diagram

### 6.3.2 Reset Sources

Device Reset Sources summarizes the available reset sources that are supported by the device.

**Table 6-20. Device Reset Sources**

| Reset Name         | Device Domain | Reset Type                                 | Sync/<br>Async | Pin/<br>Register/<br>Internal | Details                                         |
|--------------------|---------------|--------------------------------------------|----------------|-------------------------------|-------------------------------------------------|
| MCU_PORz           | MCU MAIN      | Hardware POR                               | Async          | MCU_PORz HW Pin               | <a href="#">MCU_PORz Details</a>                |
| SW_MAIN_PORz       | MAIN          | Software POR                               | Sync           | MMR                           | <a href="#">SW_MAIN_PORz Details</a>            |
| MCU_RESETz         | MCU MAIN      | Hardware warm reset                        | Async          | MCU_RESETz HW Pin             | <a href="#">MCU_RESETz Details</a>              |
| SW MCU_WARMRSTz    | MCU MAIN      | Software warm reset                        | Sync           | MMR                           | <a href="#">SW MCU_WARMRSTz Details</a>         |
| MAIN_RESETz_REQ    | MAIN          | Hardware warm reset                        | Sync           | RESETz_REQ HW Pin             | <a href="#">MAIN_RESETz_REQ Details</a>         |
| SW_MAIN_WARMRSTz   | MAIN          | Software warm reset                        | Sync           | MMR                           | <a href="#">SW_MAIN_WARMRSTz Details</a>        |
| VTM Thermal Reset  | MCU MAIN      | Thermal error warm reset                   | Async          | Internal Signal               | <a href="#">VTM Thermal Alert Reset Details</a> |
| ESM_ERRORz         | MCU MAIN      | ESM error warm reset                       | Async          | Internal Signal               | <a href="#">ESM_ERRORz Reset Details</a>        |
| SMS_COLD_OUT_RST_n | MCU MAIN      | SMS0 cold reset                            | Async          | Internal Signal               | <a href="#">SMS Reset Details</a>               |
| SMS_WARM_OUT_RST_n | MAIN          | SMS0 warm reset                            | Async          | Internal Signal               | <a href="#">SMS Reset Details</a>               |
| DM_WDT_RST_n       | MCU MAIN      | DM Watchdog Timeout Reset during Deepsleep | Async          | Internal Signal               | <a href="#">MCU_RESETz Details</a>              |

### 6.3.3 Reset Status

**Reset Status** shows the Reset Status functionality. An output pin or software bit is used to represent the status of a specific individual reset.

**Table 6-21. Reset Status**

| Reset Status Name            | Reset Status Source | Reset Status Info                                          | Signal Active Level                                                   | Reset Signal Details          |
|------------------------------|---------------------|------------------------------------------------------------|-----------------------------------------------------------------------|-------------------------------|
| MCU CTRLMMRStatus Register   | Register            | 4 bits in CTRLMMR on MCU warm reset status and assertion.  | Status bits read active HIGH (1) when a particular reset is asserted. |                               |
| WKUP CTRLMMR Status Register | Register            | 4 bits in CTRLMMR on WKUP warm reset status and assertion. | Status bits read active HIGH (1) when a particular reset is asserted. |                               |
| PORz_OUTz                    | Output Pin          | On/Off pin status of MAIN PORz reset                       | Active LOW (0)                                                        | MAIN_PORz_OUT Status Pin      |
| RESETSTATz                   | Output Pin          | On/Off pin status of MAIN warm reset                       | Active LOW (0)                                                        | MAIN_RESETSTATz Status Pin    |
| MCU_RESETSTATz               | Output Pin          | On/Off pin status of MCU PORz reset                        | Active LOW (0)                                                        | MCU_RESETSTATz Status Pin     |
| MCU_ERRORn                   | Output Pin          | On/Off pin status of MCU ESM_ERROR reset                   | Active LOW (0)                                                        | MCU_SAFETY_ERR ORn Status Pin |

### 6.3.3.1 Reset Source Status Registers

All warm reset sources which trigger a device/domain warm reset are captured in the MCU domain CTRLMMR reset status register **CTRLMMR\_MCU\_RST\_SRC**. This register is only reset on MCU\_PORz.

The MCU domain CTRLMMR **CTRLMMR\_MCU\_RST\_SRC** register is shadowed in MAIN domain CTRLMMR **CTRLMMR\_RST\_SRC** so that MAIN domain processors can read it without directly accessing the MCU domain CTRLMMR.

After recovery from warm reset, software can read the CTRLMMR reset source register **CTRLMMR\_RST\_SRC** to identify the source of previous reset. After reading this reset source register, software must clear the register.

Reset status bits read active HIGH (1) when a particular reset is triggered.

The following reset sources, which cause MCU and MAIN domain resets, are captured in the MCU domain CTRLMMR reset source register:

- MCU\_RESETz (Reset by Hardware Pin)
- SW\_MCU\_WARMRSTz (Reset by MCU domain CTRLMMR<sup>1</sup>)
- SW\_MAIN\_PORz\_MCUMMR (Reset by MCU domain CTRLMMR<sup>1</sup>)
- SW\_MAIN\_PORz\_MAINMMR (Reset by MAIN domain CTRLMMR<sup>1</sup>)
- MAIN\_RESET\_REQz (Reset by Hardware Pin)
- SW\_MAIN\_WARMRSTz\_MCUMMR (Reset by MCU domain CTRLMMR<sup>1</sup>)
- SW\_MAIN\_WARMRSTz\_MAINMMR (Reset by MAIN domain CTRLMMR<sup>1</sup>)
- SMS\_COLD\_OUT\_RST\_n (Reset by SMS)
- SMS\_WARM\_OUT\_RST\_n (Reset by SMS)
- THERM\_MAXTEMP\_OUTRANGE\_ALERT (Reset by VTM Max Temperature Alert)
- SYSR\_ASSERTRESET\_n (Reset by DEBUGSS)
- ESM\_ERROR\_RST\_n (Reset by ESM Error)
- DM\_WDT\_RST\_n (Reset by WKUP WDT Timeout during Deepsleep mode)
- DM\_MAIN\_PORz (Reset by DS\_MAIN\_POR\_PDOFF a WKUP domain CTRLMMR<sup>1</sup> during deepsleep)
  - MCU ESM Error will reset entire device
  - MAIN ESM Error will only reset MAIN domain when MCU domain is isolated. When MCU domain is not isolated, it will warm reset both MCU and MAIN domains.

---

#### Note

1. MAIN domain software WARMRSTz and PORz control registers are defined in both WKUP domain CTRLMMR and MCU domain CTRLMMR.

When the MCU domain is isolated from MAIN domain, MCU M4FSS processor can reset the MAINdomain, by programming the reset control registers defined in the MCU domain CTRLMMR. This way MCU M4FSS does not need to access MAIN domain CTRLMMR for MAIN domain reset action.

When a MAIN domain processor (A53, SMS, R5F) needs to issue resets to MAIN domain on error detection they will use the WARMRESETz and PORz MMR bits defined in the WKUP domain CTRLMMR.

---

### 6.3.3.2 MCU\_RESETSTATz Status Pin

The MCU\_RESETSTATz pin indicates the internal reset status of the device (active LOW). When LOW, it indicates that the MCU and MAIN domains are in warm reset state. When HIGH, it indicates that the MCU is out of warm reset state. Refer to [Section 6.3.3.4](#) for MAIN domain reset status.

### 6.3.3.3 MCU\_ERRORn Status Pin

The MCU\_ERRORn pin indicates the MCU domain ESM status. This Output is used to signal an external agent that it needs to (or may need to) intervene because of an error. The Error Pin Output is active Low or PWM,

based on the ESM Error Pin Control register pwm\_en field (Refer ESM IP) . This pwm\_en field should only be modified when the ESM is disabled, based on the Global Enable register. Refer ESM chapter for details.

While in Power-On-Reset, the Error Pin is active (asserted low). SoC drives a Low via a weak internal pull-down. After Power-On-Reset condition is removed, ESM will drive the Error Pin. During a Warm Reset the state of the Error Pin is unchanged (i.e. the Error Pin logic is only reset by asserting MCU\_PORz low).

When MCU\_ERRORn output pin is configured to operate in level mode, a LOW indicates the MCU ESM module has registered an error. A HIGH indicates that there are no MCU ESM errors.

When MCU\_ERRORn output pin is configured to operate in PWM mode, no error is indicated by continuous toggle according to programmable MMR widths for high and low periods. When an error occurs, the error pin stops toggling and remains constant until the error is cleared. An external device (such as a PMIC) that is detecting the PWM toggles can identify the error if the pin stops toggling. The periods should be programmed such that they fit within the expectation of the external device.

---

**Note**

This signal can be used by external safety devices to determine the device status and assert MCU\_PORz if necessary.

---

#### 6.3.3.4 RESETSTATz Status Pin

This pin indicates warm reset status (active LOW) of the MAIN domain.

When LOW, it indicates that the MAIN domain is in a warm reset state.

When HIGH, it indicates that the MAIN domain is out of reset.

The status of this signal will be captured in MCU CTRLMMR registers.

#### 6.3.3.5 PORz\_OUT Status Pin

This pin indicates the POR status of the MAIN domain (active LOW).

When LOW, it indicates the MAIN domain is in the POR state.

When HIGH, it indicates the MAIN domain is out of the POR state.

---

**Note**

PORz\_OUT may be used to enable and/or disable output buffers of attached devices that share pins associated with BOOTMODE inputs, such that appropriate boot configuration values are allowed to propagate into the device without contention.

---

### 6.3.4 Reset Controls

The reset control registers enable, disable, and adjust specific reset operations. This section explains how to control certain device resets.

#### 6.3.4.1 Reset Control Registers

[MCU Domain Reset Control Registers](#) shows the CTRLMMR registers that are able to enable and disable reset abilities and options.

**Table 6-22. MCU Domain Reset Control Registers**

| Control Name          | Control Action                      | Control Register     |
|-----------------------|-------------------------------------|----------------------|
| MCU_ESM_ERROR_RST_ENz | Enable MCU ESM_ERRORz reset         | CTRLMMR_MCU_RST_CTRL |
| SMS_COLD_RESET_ENz    | Enable SMS cold reset of MCU domain | CTRLMMR_MCU_RST_CTRL |

**Table 6-23. MAIN Domain Reset Control Registers**

| Control Name           | Control Action                       | Control Register |
|------------------------|--------------------------------------|------------------|
| MAIN_ESM_ERROR_RST_ENz | Enable MAIN ESM_ERRORz Reset         | CTRLMMR_RST_CTRL |
| SMS_COLD_RESET_ENz     | Enable SMS Cold Reset of MAIN Domain | CTRLMMR_RST_CTRL |

---

#### Note

For more information, see *Control Module (CTRLMMR)*.

---

### 6.3.4.2 Reset Isolation

#### Reset Isolation Introduction

It is possible to isolate certain SoC modules and subsystems and prevent them from undergoing an arbitrarily generated warm reset. This is known as Reset Isolation. This section describes the device reset isolation capabilities.

[Simple Reset Isolation Sequence Diagram](#) shows a simple description of the device reset isolation sequence.



**Figure 6-20. Simple Reset Isolation Sequence Diagram**

#### MCU Reset Isolation Details

[Detailed Reset Isolation Sequence Diagram](#) shows a detailed description of the MCU reset isolation sequences.



**Figure 6-21. Detailed Reset Isolation Sequence Diagram**

### **6.3.5 Reset Details**

#### **Reset Details Introduction**

The Reset Details section will break down the available device resets and explain operating details such as sequencing and reset logic diagrams. It also includes any additional information related to the device resets.

### 6.3.5.1 POR Resets

#### 6.3.5.1.1 SW\_MAIN\_PORz Reset

##### Reset Overview

This reset is a software controlled MAIN domain POR reset defined in **CTRLMMR\_RST\_CTRL** and **CTRLMMR MCU\_RST\_CTRL**.

This software reset will generate a MAIN domain PORz.

M4FSS processor in MCU domain can trigger PORz to the MAIN domain by writing to the **CTRLMMR MCU\_RST\_CTRL** register.

MAIN domain processors can reset the MAIN domain by writing to the **CTRLMMR\_RST\_CTRL** register.

When the MCU domain is configured as a safety domain it must be isolated from SW\_MAIN\_PORz.

A reset isolation sequence for the MCU domain must be complete prior to reset propagation.

**CTRLMMR\_RST\_CTRL** and **CTRLMMR MCU\_RST\_CTRL** define a 4-bit field, SW\_MAIN\_POR[7:4], for generating a software-controlled POR for the MAIN domain (SW\_MAIN\_PORz).

When SW\_MAIN\_POR [7:4] field is set to "0110", the MAIN domain is in POR reset state (SW\_MAIN\_PORz = LOW).

When SW\_MAIN\_POR [7:4] is set to any other value, the MAIN domain is out of POR reset state (SW\_MAIN\_PORz = HIGH).

This bit field is reset to "1111" (Inactive State) by default.

##### MCU Domain Effect

When MCU domain is configured as an independent domain, then the entire MCU domain is reset isolated. When MCU domain is not configured as independent domain then this SW\_MAIN\_PORz must not be used. Instead MCU\_PORz pin functions should be used.

MCU IOs are not affected.

##### MAIN Domain Effect

All modules in MAIN domain are reset (including reset isolated modules).

IOs will enter safe state (as defined in the BALL STATE DURING RESET column of the Datasheet Pin Attributes table while this reset is active).

MAIN domain CTRLMMR boot configuration register is reset.

Device BOOTMODE pins will be re-latched after this reset is de-asserted.

Device will re-boot. During boot-up, R5FSS (secondary boot loader) will poll the CTRLMMR reset status and MCU ACTIVE MAGIC WORD registers and configure MCU domain/M4FSS processor accordingly.

##### Additional Details

###### PORz\_OUT:

This pin indicates POR status output of the MAIN domain (active LOW).

When LOW, it indicates the MAIN domain is in POR state.

When HIGH, it indicates that the MAIN domain is out of POR state.

---

**Note**

PORz\_OUT may be used to enable and/or disable output buffers of attached devices that share IOs associated with BOOTMODE inputs, such that appropriate boot configuration values are allowed to propagate into the device without contention

---

---

**Note**

The boot mode pins are latched internally on the rising edge of PORz\_OUT and are reset isolated from all other device resets.

---

#### 6.3.5.1.2 MCU\_PORz Reset

##### Reset Overview

This is the POR reset signal (active LOW) for the entire device, controlled by the MCU\_PORz HW Pin.

When LOW, it performs a POR reset on the entire device (MCU and MAIN domains) and puts IOs in a safe state (as defined in the BALL STATE DURING RESET column of the datasheet Pin Attributes table).

##### MCU Domain Effect

All modules in MCU domain are reset.

MCU IOs are in HHV state (Reset State).

When MCU\_PORz is de-asserted, MCU IOs will enter the default state defined in the device Datasheet. MCU domain will be reconfigured by the device boot processor (secondary boot loader).

##### MAIN Domain Effect

All modules in the MAIN domain are reset.

MAIN domain IOs are in HHV state (as defined in the BALL STATE DURING RESET column of the datasheet Pin Attributes table).

When MCU\_PORz is de-asserted, the MAIN domain IOs will enter default state as defined in the BALL STATE AFTER RESET column of the datasheet Pin Attributes table.

The device boot processor (secondary boot loader) will setup M4FSS as Safety or General-Purpose Processor.

### 6.3.5.2 Warm Resets

#### 6.3.5.2.1 MAIN Domain Warm Reset Sequence Flow

[MAIN Domain Warm Reset Sequence Flowchart](#) explains the process for a typical MAIN domain warm reset.



**Figure 6-22. MAIN Domain Warm Reset Sequence Flowchart**

### 6.3.5.2.2 *MAIN\_RESETz\_REQ* Reset

#### Reset Overview

This reset signal is the MAIN domain warm reset request (active LOW) controlled by the *RESET\_REQz* HW pin.

When LOW is detected, reset hardware generates an interrupt to processors (A53SS/R5FSS/M4FSS) so they can complete the reset isolation sequence before reset is propagated.

#### MCU Domain Effect

When MCU domain is configured to operate independently, MCU domain reset isolation sequence is completed before propagating the *RESETz* to MAIN domain.

MCU IOs are not affected.

When MCU domain is not configured as independent, then this reset will also warm reset MCU domain.

#### MAIN Domain Effect

This is a MAIN domain warm reset request. First, the reset isolation sequence is applied and then the reset is propagated.

All modules in MAIN domain are reset except for warm reset isolated modules and MAIN domain *CTRLMMR* register bits which are reset only on *MAIN\_PORz*.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

Reason for this reset is captured in the *CTRLMMR* reset source register ***CTRLMMR\_RST\_SRC***. After reset is de-asserted, device will boot-up. During device boot-up, DM R5F secondary boot loader will read the reset status and MCU ACTIVE MAGIC WORD registers and reconfigure the MCU M4F processor accordingly.

#### Reset Sequence

The *RESET\_REQz* reset sequence is described below.

***RESET\_REQz* Sequence** shows the timing between the *RESET\_REQz* reset signal and the internal *RESETz* (MAIN domain warm reset) signal. Refer to the datasheet for timing and pulse width requirements.

### MAIN WARM RESET (RESET\_REQz Pin)



**Figure 6-23. RESET\_REQz Sequence**

#### Additional Reset Details

##### RESETSTATz:

The RESETSTATz pin indicates the MAIN domain internal reset status (active LOW). This is a reflection of the reset status after the RESET\_REQz reset signal (RESET\_REQz HW Pin) is asserted.

When LOW, it indicates that the MAIN domain is in internal reset state.

When HIGH, it indicates that the MAIN domain is out of internal reset state.

[RESETSTATz Timing](#) shows the timing between the RESET\_REQz reset signal and the RESETSTATz output. Refer to the datasheet for timing and pulse width requirements.



**Figure 6-24. RESETSTATz Timing**

**Note**

For more details see [MAIN\\_RESETSTATz Status Pin](#).

### 6.3.5.2.3 SW\_MAIN\_WARMRSTz Reset

#### Reset Overview

This reset is software controlled MAIN domain warm reset defined in **CTRLMMR\_RST\_CTRL** and **CTRLMMR MCU\_RST\_CTRL**.

The M4FSS can issue a warm reset to the MAIN domain, by writing to the MCU domain CTRLMMR register.

The MAIN domain processors can issue a warm reset the WKUP domain, by writing to the MAIN domain CTRLMMR register.

---

#### Note

When M4FSS is configured as safety processor it must be reset isolated from this MAIN domain warm reset.

A reset isolation sequence for MCU domain has to be complete prior to this reset propagation.

---

WKUP domain CTRLMMR and MCU domain CTRLMMR registers define a 4-bit field, **SW\_MAIN\_WARMRST[3:0]** for generating a software controlled warm reset for the MAIN domain (**SW\_MAIN\_WARMRSTz**).

When **SW\_MAIN\_WARMRST[3:0]** field is set to “0110”, a MAIN domain warm reset is active (**SW\_MAIN\_WARMRSTz** = LOW).

When **SW\_MAIN\_WARMRST[3:0]** is set to any other value, the MAIN domain warm reset is inactive (**SW\_MAIN\_WARMRSTz** = HIGH).

This bit field is reset to “1111” (Inactive State) by default.

---

#### Note

This software reset is equivalent to **RESET\_REQz** reset signal (**RESET\_REQz** HW Pin) functionality.

---

#### MCU Domain Effect

When MCU domain is configured to operate independently, MCU domain reset isolation sequence is completed before propagating the **RESETz** to main domain.

MCU IOs are not affected.

When MCU domain is not configured as independent then, this reset will also warm reset MCU domain.

#### MAIN Domain Effect

This is a MAIN domain reset request. First, the reset isolation sequence is applied and then the reset is propagated.

All modules in MAIN domain are reset except for reset isolated modules and MAIN domain CTRLMMR register bits which are reset only on **MAIN\_PORz**.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

Reason for this reset is captured in MAIN domain CTRLMMR reset status register **CTRLMMR\_RST\_STAT**. After reset is de-asserted, device will boot-up. During device boot-up, R5FSS (secondary boot loader) will read the reset status and MCU ACTIVE MAGIC WORD registers and reconfigure the MCU domain/M4FSS processor accordingly.

### 6.3.5.2.4 MCU\_RESETz Reset

#### Reset Overview

The MCU\_RESETz signal is the warm reset input (active low) to the entire device, controlled by the MCU\_RESETz HW Pin.

When active, it resets all modules in the MCU and MAIN domains.

MCU\_RESETz will not reset selected **CTRLMMR\_RST\_CTRL** and **CTRLMMR\_MCU\_RST\_CTRL** register bits. These bits are only reset by PORz.

#### MCU Domain Effect

All modules in MCU domain are reset except for **CTRLMMR\_MCU\_RST\_CTRL** bits which are reset only on MCU\_PORz.

IOs are not affected.

M4FSS is reset.

When MCU\_RESETz is de-asserted, the MCU domain needs to be reconfigured by R5FSS (secondary boot loader) in the MAIN domain.

#### MAIN Domain Effect

All modules in the MAIN domain are reset except for CTRLMMR bits which are reset only by PORz.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

When MCU\_RESETz is de-asserted, the device goes through full boot. The reason for this reset is captured in the CTRLMMR reset source register **CTRLMMR\_RST\_SRC**.

During device boot-up, the R5FSS (secondary boot loader) will read the CTRLMMR reset status and MCU ACTIVE MAGIC WORD registers and reconfigure the MCU domain/M4FSS processor accordingly.

#### Additional Details

MCU\_RESETSTATz:

This pin indicates internal MCU\_RESETz reset status (active LOW).

When LOW, it indicates that the device, both MCU and MAIN domains, are in internal reset state.

When HIGH, it indicates that the device MAIN domains, are is out of internal reset state.

---

#### Note

In order for the MAIN domain to come out of reset, RESETz\_REQ (RESET\_REQz HW Pin) must also be de-asserted.

---

---

#### Note

For more details see [MCU\\_RESETSTATz Status Pin](#).

---

### 6.3.5.2.5 **SW\_MCU\_WARMRSTz** Reset

#### Reset Overview

This is a software MCU domain warm reset defined in MCU domain CTRLMMR.

MCU CTRLMMR defines a 4-bit field, SW\_MCU\_WARMRST[11:8] for generating a software warm reset in the MCU domain (SW\_MCU\_WARMRSTz).

When SW\_MCU\_WARMRST[11:8] field is set to “0110”, MCU warm reset is active (SW\_MCU\_WARMRSTz = LOW).

When SW\_MCU\_WARMRST[11:8] is set to any other value, MCU warm reset is inactive (SW\_MCU\_WARMRSTz = HIGH).

This bit field is reset to “1111” (Inactive State) by default.

---

#### Note

This software reset is equivalent to MCU\_RESETz warm reset signal (MCU\_RESETz HW Pin) functionality.

---

#### MCU Domain Effect

All modules in the MCU domain are reset except for MCU domain CTRLMMR bits which are reset only on MCU\_PORz.

IOs are not affected.

M4FSS processor is reset.

When MCU\_RESETz is de-asserted, the MCU domain needs to be reconfigured by the R5FSS (secondary boot loader) in the MAIN domain.

#### MAIN Domain Effect

All modules in the MAIN domain are reset except for CTRLMMR bits which are reset only on PORz.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

When MCU\_RESETz is de-asserted, the device goes through full boot. The reason for this reset is captured in CTRLMMR reset source register **CTRLMMR\_RST\_SRC**.

During device boot-up, the R5FSS (secondary boot loader) will read the CTRLMMR reset status and MCU ACTIVE MAGIC WORD and reconfigure the MCU domain/M4FSS processor accordingly.

### 6.3.5.3 SMS Resets

#### 6.3.5.3.1 SMS\_WARM\_OUT\_RST\_n Reset (MAIN Domain)

##### Reset Overview

The SMS will issue this reset upon a security error.

When this reset is enabled in MAIN domain, it causes a MAIN domain warm reset.

This is a synchronous reset type (needs to complete reset isolation sequence).

---

##### Note

This reset behavior is same as the RESETz\_REQ reset signal (RESET\_REQz HW Pin).

---

##### MCU Domain Effect

When MCU domain is configured to operate independently, MCU domain reset isolation sequence is completed before propagating the RESETz to main domain.

MCU IOs are not affected.

When MCU domain is not configured as independent then, this reset will also warm reset MCU domain.

##### MAIN Domain Effect

This is a MAIN domain warm reset request. First, the reset isolation sequence is applied and then the reset is propagated.

All modules in MAIN domain are reset except for CTRLMMR register bits which are reset only on PORz.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

Reason for this reset is captured in CTRLMMR reset source status register **CTRLMMR\_RST\_SRC**. After reset is de-asserted, device will boot-up. During device boot-up, R5FSS (secondary boot loader) will read the reset status and MCU ACTIVE MAGIC WORD registers and reconfigure the MCU domain/M4FSS processor accordingly.

#### 6.3.5.3.2 SMS\_COLD\_OUT\_RST\_n Reset (MAIN Domain)

##### Reset Overview

This reset is a MAIN domain warm reset that is executed from the SMS. This is an asynchronous reset type (takes effect immediately). This SMS reset of the Main domain is enabled only when the SMS\_COLD\_RESET\_EN\_z bit in WKUP domain CTRLMMR is '0'.

---

##### Note

This reset behavior is same as the RESETz\_REQ reset signal (RESET\_REQz HW Pin) with the exception that it takes effect immediately without need for any reset isolation sequence.

---

##### MCU Domain Effect

When MCU domain is configured to operate independently, MCU domain reset isolation sequence is completed before propagating the RESETz to main domain.

MCU IOs are not affected.

When MCU domain is not configured as independent then, this reset will also warm reset MCU domain.

## MAIN Domain Effect

This is a MAIN domain asynchronous warm reset. Propagates immediately without any reset isolation sequence.

All modules in MAIN domain are reset except CTRLMMR register bits which are reset only on PORz.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

Reason for this reset is captured in CTRLMMR reset status register. After reset is de-asserted, device will boot-up. During device boot-up, R5FSS (secondary boot loader) will read the reset status and MCU ACTIVE MAGIC WORD registers and reconfigure the MCU domain/M4FSS processor accordingly.

### 6.3.5.3.3 SMS\_COLD\_OUT\_RST\_n Reset (MCU Domain)

#### Reset Overview

The device SMS will issue this reset upon a security error.

When this reset is enabled in MCU domain, it causes a whole device warm reset.

This SMS reset of the MCU domain is enabled only when the SMS\_COLD\_RESET\_ENz bit in MCU domain CTRLMMR is '0'.

When the M4FSS is configured as a safety processor, it can block this reset from resetting the MCU domain.

This is an asynchronous reset type (takes effect immediately)

---

#### Note

This reset behavior is same as MCU\_RESETz reset signal (MCU\_RESETz HW Pin).

---

#### MCU Domain Effect

All modules in MCU domain are reset except for CTRLMMR bits which are reset only on MCU\_PORz.

IOs are not affected.

M4FSS is reset.

When MCU\_RESETz is de-asserted, the MCU domain will be reconfigured by R5FSS (secondary boot loader) in the MAIN domain.

#### MAIN Domain Effect

All modules in the MAIN domain are reset except for CTRLMMR bits which are reset only on PORz.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

When MCU\_RESETz is de-asserted, the device goes through full boot. The reason for this reset is captured in the CTRLMMR reset source register **CTRLMMR\_RST\_SRC**.

During device boot-up, the R5FSS (secondary boot loader) will read the CTRLMMR reset status and MCU ACTIVE MAGIC WORD and reconfigure the MCU domain/M4FSS processor accordingly.

### 6.3.5.4 VTM Thermal Alert Reset

#### Reset Overview

The VTM module outputs an alert signal (THERM\_MAXTEMP\_OUTRANGE\_ALERT), when the device temperature goes beyond a maximum threshold.

This reset signal creates a MCU domain warm reset.

VTM alert will be active as long as the error condition (Device Temperature > Maximum Temperature Threshold) is still TRUE.

When the error goes away, VTM alert will be de-asserted and device will come out of warm reset.

---

#### Note

This signal, when asserted HIGH, will cause a device warm reset similar to MCU\_RESETz.

---

#### MCU Domain Effect

All modules in MCU domain are reset except for MCU domain CTRLMMR bits which are reset only on MCU\_PORz.

IOs are not affected.

This reset is active as long as the VTM alert is active.

When THERM\_MAXTEMP\_OUTRANGE\_ALERT is de-asserted, the MCU domain needs to be reconfigured by R5FSS (secondary boot loader) in the MAIN domain.

#### MAIN Domain Effect

All modules in the MAIN domain are reset except for CTRLMMR bits which are reset only on MAIN\_PORz.

IOs are not affected.

All processor cores are reset (A53SS and R5FSS).

When THERM\_MAXTEMP\_OUTRANGE\_ALERT is de-asserted, the device goes through full initialization procedure. The reason for this reset is captured in the CTRLMMR reset source register **CTRLMMR\_RST\_SRC**.

#### Additional Reset Details

VTM alert use-case example:

VTM sends out a warning signal before generating the Max Temp Alert.

There are 2 different threshold settings for max temperature limits.

The first one has a lower threshold which will generate an interrupt to the processor for taking action to reduce frequency, turn-off power domains, etc. This should eventually lower the temperature and avoid the Max Temp Alert.

If the interrupt does not fix the rising temperature, then VTM will issue a Max Temp Alert. This will cause a device warm reset. The VTM Max Temp Alert will be active as long as die temperature is above the programmed threshold.

Device warm reset will default certain power domains to off mode (default at power-up). This should eventually lower the die temperature further.

Software can read the reset status register to poll on the cause of the warm reset. If it is from VTM, then it can wait for additional time before turning on the power domains.

### 6.3.5.5 MAIN ESM\_ERRORz Reset

#### Reset Overview

This reset is issued when a MAIN domain processor (A53SS, SMS, or R5FSS) detects a catastrophic software error or a MAIN domain WDT timeout event occurs.

Errors in the MAIN domain cause the MAIN ESM module to trigger ESM\_ERRORz.

This is routed as internal MAIN domain warm reset when enabled by the WKUP domain CTRLMMR reset control bit (MAIN\_ESM\_ERROR\_RST\_ENz).

This is an asynchronous reset type (takes effect immediately).

#### Reset MCU Domain Effect

When MCU domain is configured to operate independently, MCU domain reset isolation sequence is completed before propagating the RESETz to main domain.

MCU IOs are not affected.

When MCU domain is not configured as independent then, this reset will also warm reset MCU domain.

#### Reset MAIN Domain Effect

All modules in MAIN domain are reset except for MAIN domain CTRLMMR bits which are reset only on PORz.

IOs are not affected.

The device will re-boot. During boot-up, the R5FSS (secondary boot loader) will poll the CTRLMMR reset registers and reconfigure the MCU domain/M4FSS processor accordingly.

---

#### Note

If the device boot fails, and the MCU\_ERRORn level is still LOW, then an external safety device should issue the MCU\_PORz Reset to allow the device to recover from this error.

---

### 6.3.5.6 MCU ESM\_ERRORz Reset

#### Reset Overview

This reset is issued when the M4FSS detects a catastrophic safety error or a MCU WDT timeout occurs.

Errors in the MCU domain cause the MCU ESM module to trigger error output.

This is routed as a device warm reset when enabled by the MCU domain CTRLMMR bit (MCU\_ESM\_ERROR\_RST\_ENz).

This is an asynchronous reset type (takes effect immediately).

#### MCU Domain Effect

All modules in MCU domain are reset except for MCU domain CTRLMMR bits which are reset only on PORz.

IOs are not affected.

Error is reported on MCU\_ERRORn pin.

When SAFETY\_ERROR\_RST\_n is de-asserted, the MCU domain needs to be reconfigured by the R5FSS (secondary boot loader) in the MAIN domain.

External hardware (PMIC or secondary MCU safety channel) must issue MCU\_PORz to recover from this error.

#### MAIN Domain Effect

All modules in MAIN domain are reset except for reset isolated modules and MAIN domain CTRLMMR bits which are reset only on PORz.

IOs are not affected.

Device will re-boot. During boot-up, the R5FSS (secondary boot loader) will poll the CTRLMMR reset source register and configure the MCU domain/M4FSS processor accordingly.

If the device boot fails, and MCU\_ERRORn level is still LOW, then an external safety device should issue the MCU\_PORz reset to allow the device to recover from the error.

### 6.3.5.7 DM\_WDT\_RST\_n Reset

#### Reset Overview

During Deepsleep resume sequence if the Device Manager is unable to respond due to a software bug, the WKUP domain WDT timer will issue this reset signal.

When this reset is enabled in MCU domain, it causes a whole device warm reset.

This WKUP WDT reset is enabled only when the DM\_WDT\_RST\_EN\_z bit in MCU domain CTRLMMR is '0'.

When the M4FSS is configured as a safety processor, it can block this reset from resetting the MCU domain. This is an asynchronous reset type (takes effect immediately)

---

#### Note

This reset behavior is same as MCU\_RESETz reset signal (MCU\_RESETz HW Pin).

---

#### MCU Domain Effect

All modules in MCU domain are reset except for MCU domain CTRLMMR bits which are reset only on MCU\_PORz.

IOs are not affected. M4FSS is reset.

When this reset is de-asserted, the MCU domain will be reconfigured by R5FSS (secondary boot loader) in the MAIN domain.

### MAIN Domain Effect

All modules in the MAIN domain are reset except for CTRLMMR bits which are reset only on PORz.

IOs are not affected.

All processor cores are reset (A53SS, SMS, and R5FSS).

When this reset is de-asserted, the device goes through full boot. The reason for this reset is captured in the CTRLMMR reset source register.

During device boot-up, the R5FSS (secondary boot loader) will read the CTRLMMR reset status and MCU ACTIVE MAGIC WORD and reconfigure the MCU domain/M4FSS processor accordingly.

### 6.3.5.8 HHV

IOs support HHV mode during power up. HHV is active when PORz signal is driven LOW.

HHV allows IO cells to be tri-stated and is an IO feature. All IO cells have HHV which is asserted (driven) by HHV generated during PORz assertion. There are default pull values during this HHV/PORz assertion specified in the device Datasheet for each pin. All HHV logic controlling the buffer output enable and associated default internal pull for each IO will be applied.

[HHV Timing Diagram](#) demonstrates the timing sequence for the device HHV signals.



**Figure 6-25. HHV Timing Diagram**

### 6.3.5.9 BOOTMODE Pin Latching

This device requires several Boot Mode controls to enable device boot. The BOOTMODE inputs are not implemented on dedicated pins. They are multiplexed with other signal functions, where pins associated with the BOOTMODE inputs are defined in the Pin Attributes table. The logic state of the BOOTMODE inputs are latched on the rising edge of PORz\_OUT. Valid logic states must be maintained as long as PORz\_OUT is held low. The latched values are reflected in WKUP CTRL MMRs for read/write access.



**Figure 6-26. BOOTMODE Pin Latching**

#### 6.3.5.10 Power-on-Reset Sequence

Figure 6-27 and Figure 6-28 give a high-level overview of the device power-up sequence.



**Figure 6-27. Power-up/Boot Flow Chart**



**Figure 6-28. Power-up/Boot Timing Chart**

### 6.3.5.11 Low Power Mode Reset Handling

This device supports Low Power & Deepsleep modes where parts of the device are switched-off through internal Power-Domain switches. To support these low power modes the device is partitioned so that only a small region is kept active (Wake-up) and the rest can be powered off through power-down switches. During deepsleep mode, several power-domains in Main domain are powered off and its PORz will be asserted.

Figure 6-29 shows the high-level overview of Power domain partitions.



**Figure 6-29. Power Domain Partitions**

### WKUP MMR DEEP SLEEP CONTROLS

These bits are multi-bit encoded fields (ideally 4 bits) to prevent single bit flip/error from causing a reset. When this 4bit MMR filed is programmed with a value of 4'b0110, the decode logic must make that signal active ('1'). For all other values, the decode logic makes reset inactive. The default value must be 4'b1111, which is reset inactive. These MMRs are key-lock protected and firewall protected. Reset control for these MMRs is MCU PLLCTRL CHIP\_1\_RST\_n



When DS\_MAIN\_POR\_PDOFF is programmed high (towards the end of Deepsleep sequence), this signal is used to assert main\_porz (=Low) and also force ds\_pd\_sms\_off, ds\_pd\_debugss\_off, ds\_pd\_mainip\_off to off state (= '0'). This MMR is programmed only during Deepsleep mode.

Rising edge of DS\_MAIN\_POR\_PDOFF is captured into WKUP MMR SLEEP STATUS MMR as Main Domain DeepSleep State. When Main domain resumes from Deepsleep, TIFS can read this MMR to detect that it is resuming from deepsleep state. TIFS can clear this bit or can request DM to clear this bit.

Since DS\_MAIN\_POR\_PDOFF is also causing a Main Domain Porz during deepsleep mode, inverted version of DS\_MAIN\_POR\_PDOFF should be captured as ds\_main\_porz in Reset Status MMR in MCU CTRL MMR.

#### High Level Sequence



**Figure 6-30. High-level Power Domain Partitions**

Figure 6-31 depicts a high-level deep-sleep sequence. For more details please refer to Low Power Management Chapter.

**SMS-DM/WAKE-UP Handshaking during Deep-sleep Resume Sequence**

**Figure 6-31. Deepsleep Reset Handling**

## 6.4 Clocking

This chapter describes the clock architecture of the device.

### 6.4.1 Overview

To satisfy the various subsystems requirements, the device features multiple clock sources and clock generators:

- External Crystal Driver
  - Internal Oscillator
  - Phase-Locked Loop circuits (PLLs)
  - Dividers

Figure 6-32 shows the device top-level clock diagram. The clocking is divided into two clocking domains - MCU and MAIN.

## AM62x HIGH LEVEL CLOCK PARTITION



**Figure 6-32. Top-Level Clock Diagram**

## 6.4.2 Clock Inputs

### 6.4.2.1 Overview

Various external clock inputs are needed to drive the device. Summary of these input clock signals is as follows:

- High frequency oscillators
  - MCU\_OSC0\_XO/MCU\_OSC0\_XI — external main crystal interface pins of the internal oscillator which sources a reference clock. Provides reference clock to PLLs within MCU and MAIN domain.
- Low frequency oscillators
  - LSOSC0\_IN/LFOSC0\_OUT - external 32.768KHz crystal interface pins of the internal oscillator which sources a reference clock. Provides reference clock to RTC and Timers within MCU and MAIN domain.
- General purpose clock inputs
  - MCU\_EXT\_REFCLK0 — optional external system clock input (MCU domain).
  - EXT\_REFCLK1— optional external system clock input (MAIN domain).
- External CPTS reference clock inputs
  - CP\_GEMAC\_CPTS0\_RFT\_CLK — CPTS reference clock input for CPSW and Timers in MAIN.
- External audio reference clock inputs/outputs
  - AUDIO\_EXT\_REFCLK[1:0] — optional McASP high-frequency input clocks when configured to operate as an input.

---

#### Note

Other clock inputs that are routed directly to the subsystems are described in the respective subsystem chapters.

---

### 6.4.3 Clock Outputs

The device provides several system clock outputs. Summary of these output clock signals is as follows:

- MCU\_SYSCLKOUT0
- MCU\_OBSCLK0
- SYSCLKOUT0
- OBSCLK0
- WKUP\_CLKOUT0
- CLKOUT0
- AUDIO\_EXT\_REFCLK[1:0]

Other clock outputs, that are routed directly from subsystems to device pins, are described in the respective module chapter.

Observation clock pins - MCU\_OBSCLK0 and OBSCLK0 serve the following purposes:

- During testing, PLLs on the device are configured to output all operating frequencies desired by each module to characterize PLL performance.
- System debug: during debug, clocks from various PLLs can be inspected for possible clues. Example clock glitches, lock loss etc.

#### Note

Maximum frequency supported on both MCU\_OBSCLK0 and OBSCLK0 pins is 200 MHz. Hence the divider at the output of each OBSCLK mux must be programmed to meet this limitation.

Unlike the OBSCLK pins which can select several different clocks for output, system clock pins (MCU\_SYSCLKOUT0 and SYSCLKOUT0) are hardwired to dedicated clock resources (see [Section 6.4.3.2](#))

#### 6.4.3.1 Observation Clock Pins

##### 6.4.3.1.1 MCU\_OBSCLK0 Pin

MCU\_OBSCLK0 output is controlled by MCU\_CTRL\_MMR\_CFG0\_MCU\_OBSCLK\_CTRL register in the MCU\_CTRL\_MMR0 module; for more information about control registers, refer to *Control Module (CTRL\_MMR)*. Two muxes are connected in series - MCU\_OBSCLK0\_MUX0 and MCU\_OBSCLK0\_MUX1, see [Figure 6-33](#).



**Figure 6-33. MCU\_OBSCLK Muxes Diagram**

How to select the output of MCU\_OBSCLK0\_MUX1 is described in [Table 6-24](#).

**Table 6-24. MCU\_OBSCLK0\_MUX1 Output Clock Selection**

| MCU_CTRL_MMR_CFG0_MCU_OBSCLK_CTRL <sup>(2)</sup> [3:0]<br>CLK_SEL | MCU_OBSCLK0_MUX1 Output Clock Selection <sup>(1)</sup> |
|-------------------------------------------------------------------|--------------------------------------------------------|
| 0x0                                                               | CLK_12M_RC                                             |
| 0x1                                                               | 0 (GND) <sup>(3)</sup>                                 |
| 0x2                                                               | MCU_PLL0_HSDIV0_CLKOUT                                 |

**Table 6-24. MCU\_OBSCLK0\_MUX1 Output Clock Selection (continued)**

| MCU_CTRL_MMR_CFG0_MCU_OBSCLK_CTRL <sup>(2)</sup> [3-0]<br>CLK_SEL | MCU_OBSCLK0_MUX1 Output Clock Selection <sup>(1)</sup> |
|-------------------------------------------------------------------|--------------------------------------------------------|
| 0x3                                                               | MCU_PLL0_HSDIV4_CLKOUT                                 |
| 0x4                                                               | MCU_PLLCTRL0_PLL_CTRL_OBSCLK_CLK                       |
| 0x5                                                               | CLK_32K_RC                                             |
| 0x6                                                               | HFOSC0_CLKOUT                                          |
| 0x7                                                               | HFOSC0_CLKOUT_32K                                      |
| 0x8                                                               | MCU_SYSCLK0                                            |
| 0x9                                                               | DEVICE_CLKOUT_32K                                      |
| 0xA-0xF                                                           | RESERVED <sup>(3)</sup>                                |

(1) Software-controlled 4-bit divider is used to obtain the divided versions of the clocks passed to MCU\_OBSCLK1 mux

(2) For more information about control registers, refer to *Control Module (CTRL\_MMR)*.

(3) GND - ground

The value of the software-controlled 4-bit divider is determined by the MCU\_CTRL\_MMR\_CFG0\_MCU\_OBSCLK\_CTRL[11-8] CLK\_DIV field; for more information about control registers, see *Control Module (CTRL\_MMR)*.

#### Note

MCU\_OBSCLK1\_MUX0 is provided as a low jitter output for HFOSC0\_CLK. In this configuration, MCU\_CTRL\_MMR\_CFG0\_MCU\_OBSCLK\_CTRL[3-0] should be configured as 0x1 (1, selecting a logical low signal) and MCU\_CTRL\_MMR\_CFG0\_MCU\_OBSCLK\_CTRL[24] should be configured as 0x1.

#### 6.4.3.1.2 OBSCLK0 Pin

The OBSCLK0 output pin is controlled by MAIN\_CTRL\_MMR\_CFG0\_OBSCLK0\_CTRL register in the CTRL\_MMR0 module; for more information about control registers, refer to *Control Module (CTRL\_MMR)*. Figure 6-34 shows a block diagram of internal OBSCLK0 mux connections.


**Figure 6-34. OBSCLK0 Muxes Diagram**
**Table 6-25. OBSCLK0 Clock Selection**

| MAIN_CTRL_MMR_CFG0_OBSCLK0_CTRL <sup>(2)</sup> [4-0] CLK_SEL | OBSCLK0 Selection <sup>(1)</sup> |
|--------------------------------------------------------------|----------------------------------|
| 0x0                                                          | MAIN_PLL0_HSDIV0_CLKOUT          |
| 0x1                                                          | MAIN_PLL1_HSDIV0_CLKOUT          |
| 0x2                                                          | MAIN_PLL2_HSDIV0_CLKOUT          |
| 0x3                                                          | MAIN_PLL8_HSDIV0_CLKOUT          |
| 0x4                                                          | MAIN_PLL12_HSDIV0_CLKOUT         |
| 0x5                                                          | CLK_12M_RC                       |
| 0x6                                                          | HFOSC0_CLKOUT_32K                |
| 0x7                                                          | PLLCTRL0_PLL_CTRL_OBSCLK_CLK     |
| 0x8                                                          | HFOSC0_CLKOUT                    |
| 0x9                                                          | CLK_32K_RC                       |
| 0xA                                                          | CPSW0_CPTS_GENF0                 |
| 0xB                                                          | CPSW0_CPTS_GENF1                 |
| 0xC                                                          | MCU_PLL0_HSDIV0_CLKOUT           |

**Table 6-25. OBSCLK0 Clock Selection (continued)**

| MAIN_CTRL_MMR_CFG0_OBSCLK0_CTRL <sup>(2)</sup> [4-0] CLK_SEL | OBSCLK0 Selection <sup>(1)</sup> |
|--------------------------------------------------------------|----------------------------------|
| 0xD                                                          | MAIN_PLL15_HSDIV0_CLKOUT         |
| 0xE                                                          | MAIN_PLL16_HSDIV0_CLKOUT         |
| 0xF                                                          | MAIN_PLL17_HSDIV0_CLKOUT         |
| 0x10                                                         | MAIN_SYSCLK0                     |
| 0x11                                                         | DEVICE_CLKOUT_32K                |
| 0x12-0xFF 0x16-0x1F                                          | RESERVED <sup>(3)</sup>          |

(1) Software-controlled 8-bit divider is used to obtain the divided versions of the clocks passed to output pins

(2) For more information about control registers, refer to *Control Module (CTRL\_MMR)*.

(3) GND - ground

The value of the software-controlled 8-bit divider is determined by register MAIN\_CTRL\_MMR\_CFG0\_OBSCLK0\_CTRL[15-8] CLK\_DIV; for more information about control registers, refer to *Control Module (CTRL\_MMR)*.

#### 6.4.3.1.3 AUDIO\_EXT\_REFCLK

AUDIO\_EXT\_REFCLK gives an option of sourcing one of six McASP high-frequency audio reference clocks, MAIN\_PLL1\_HSDIV6\_CLKOUT, or MAIN\_PLL2\_HSDIV8\_CLKOUT when configured to operate as an output.

#### 6.4.3.2 System Clock Pins

##### 6.4.3.2.1 MCU\_SYSCLKOUT0

MCU\_SYSCLK0 is divided by 4 and then send out of the device as a LVCMOS clock signal (MCU\_SYSCLKOUT0). This signal can be used to test if the specific device clock is functioning or not.

##### Note

MCU\_SYSCLKOUT0 cannot be used as a clock source for external devices on the board.

##### 6.4.3.2.2 SYSCLKOUT0

SYSCLK0 is divided by 4 and then send out of the device as a LVCMOS clock signal (SYSCLKOUT0). This signal can be used to test if the specific device clock is functioning or not.

##### Note

SYSCLKOUT0 cannot be used as a clock source for external devices on the board.

##### 6.4.3.2.3 WKUP\_CLKOUT0

The WKUP\_CLKOUT0 output pin is controlled by the WKUP\_CTRL\_MMR\_CFG0\_CLKOUT\_CTRL register in the WKUP\_CTRL\_MMR0 module; for more information about control registers, refer Control Module (CTRL\_MMR). Figure 6-35 shows a block diagram of internal WKUP\_CLKOUT0 mux connections.

**Figure 6-35. WKUP\_CLKOUT0 Mux Diagram****Table 6-26. WKUP\_CLKOUT0\_MUX Output Clock Selection**

| WKUP_CTRL_MMR_CFG0_CLKOUT_CTRL <sup>(1)</sup> [2-0]<br>WKUP_CLKOUT_SEL | WKUP_CLKOUT0_MUX Output Clock Selection |
|------------------------------------------------------------------------|-----------------------------------------|
| 0x0                                                                    | HFOSC0_CLK                              |
| 0x1                                                                    | LFOSC0_CLKOUT                           |
| 0x2                                                                    | MAIN_PLL0_HSDIV2_CLKOUT                 |

**Table 6-26. WKUP\_CLKOUT0\_MUX Output Clock Selection (continued)**

| WKUP_CTRL_MMR_CFG0_CLKOUT_CTRL <sup>(1)</sup> [2-0]<br>WKUP_CLKOUT_SEL | WKUP_CLKOUT0_MUX Output Clock Selection |
|------------------------------------------------------------------------|-----------------------------------------|
| 0x3                                                                    | MAIN_PLL1_HSDIV2_CLKOUT                 |
| 0x4                                                                    | MAIN_PLL2_HSDIV9_CLKOUT                 |
| 0x5                                                                    | DEVICE_CLKOUT_32K                       |
| 0x6                                                                    | CLK_12M_RC                              |
| 0x7                                                                    | HFOSC0_CLKOUT                           |

(1) For more information about control registers, refer Control Module (CTRL\_MMR).

#### 6.4.4 Device Oscillators

The device has the possibility to source clocks of an external high-frequency oscillator - HFOSC0 and external 32.768KHz oscillator - LFOSC0. The device has also one internal RC oscillator - CLK\_12M\_RC.

##### 6.4.4.1 Device Oscillators Integration

###### 6.4.4.1.1 High-Frequency Oscillator with External Crystal

By default, HFOSC0 is enabled after PORz. It supports a bypass mode. In this mode, an external clock can be driven on the XI Pin.


**Figure 6-36. HFOSC0 Integration Diagram**

###### 6.4.4.1.2 Low-Frequency Oscillator with External Crystal

By default, LFOSC0 is disabled after PORz. It supports a bypass mode. In this mode, an external clock can be driven on the XI Pin.


**Figure 6-37. LFOSC0 Integration Diagram**

#### 6.4.4.1.3 Internal RC Oscillator

CLK\_12M\_RC in always oscillate mode.

The 12.5-MHz RC clock output (CLK\_12M\_RC) is used by the on-chip Reset Glue logic, Power Reset Generator (PRG) circuits, HFOSC0 Loss Circuits, Dual Clock Comparator (DCC) and Timer Modules.

#### Note

An output clock of CLK\_12M\_RC is further divided down to generate a 32-kHz clock (CLK\_32K\_RC). This clock is used by SMS and Timer Modules.

The actual value of the derived CLK\_32K\_RC will vary with PVT variations.

#### 6.4.4.2 Oscillator Clock Loss Detection

The device supports HFOSC0 clock loss circuitry to detect when HFOSC0\_CLK stops toggling. Dedicated hardware logic monitors HFOSC0 clock using CLK\_12M\_RC clock. When HFOSC0\_CLK stops toggling for 9 CLK\_12M\_RC clock periods, a HFOSC0 clock stop loss condition is detected. If CTRLMMR MCU\_PLL\_CLKSEL[8] CLKLOSS\_SWTCH\_EN is set, the reference clock is switched from HFOSC0\_CLKOUT to CLK\_12M\_RC to allow the device to operate with a slower clock. The HFOSC0\_CLK clock loss condition is reported as an error to MCU\_ESM0 regardless of the value of CTRLMMR MCU\_PLL\_CLKSEL[8] CLKLOSS\_SWTCH\_EN. Integration diagram of HFOSC0 clock loss detection is presented in [Figure 6-38](#).



**Figure 6-38. HFOSC0 Clock Loss Detection Integration Diagram**

MCU\_ESM0 can optionally generate an interrupt to MCU\_M4FSS0 and DM\_R5FSS0 so they can save some critical contents such as error logging to scratch pad memory or external flash. ESM must also be configured to report this error on the MCU\_ERRORn pin.

HFOSC0 clock loss is a catastrophic failure since this clock is the most critical system clock. During the clock loss condition an external system intervention is required.

The clock loss mux is not a glitch free mux. The mux control is synchronized to the CLK\_12M\_RC clock. Since HFOSC0\_CLK has stopped switching the mux should transition to RC Clock without producing glitches.

During clock-loss condition, the device reports the error to the external device through MCU\_ERRORn pin - the pin is driven Low. The recovery mechanism is up to the external system (such as a PMIC to take action). For example, it can try a full system power cycle to see if the system recovers. If the system does not recover then, it has to take some other action such as to check system clocks, external crystal or supply rails.

Device PLLs will lose lock when clock loss is detected. During this time 12.5-MHz RC clock is output through the bypass muxes. The PLL will relock to a new frequency based on 12.5 MHz RC clock.

In an event of clock glitch which may potentially hang the device, then the SMS watchdog timer will expire and will generate an internal reset for the whole device.

## 6.4.5 PLLs

Phase-Locked Loop circuits (PLLs) in the device are clock generator PLLs, which multiply the lower-frequency reference clock up to the operating frequency of the respective subsystem(s).

### 6.4.5.1 MCU Domain PLL Overview

MCU\_PLL0 (MCU PLL) with MCU\_PLLCTRL0 are present in the device in MCU domain. An overview is shown on [Figure 6-39](#). For more specific information about PLLs see [Section 6.4.5.5, PLLs Device-Specific Information](#).



Figure 6-39. MCU Domain PLLs Integration

#### 6.4.5.2 MAIN Domain PLLs Overview

The following are the PLLs in the device in MAIN domain:

- PLL0 (MAIN PLL) with PLLCTRL0
- PLL1 (PER0 PLL)
- PLL2 (PER1 PLL)
- PLL8 (ARM0 PLL)
- PLL12 (DDR PLL)
- PLL15 (SMS PLL)
- PLL16 (DSS0 PLL)
- PLL17 (DSS1 PLL)

Overview of the device PLLs with their reference clock options in MAIN domain is shown on Figure 6-40. For more specific information about PLLs see [Section 6.4.5.5, PLLs Device-Specific Information](#).

---

**Note**

The external muxes of choosing the reference clocks are glitch-free muxes.

---


**Figure 6-40. MAIN Domain PLLs Integration**

#### 6.4.5.3 PLL Reference Clocks

##### 6.4.5.3.1 PLLs in MCU Domain

The reference clock `MCU_PLL0_REF_CLK` for the PLL in MCU domain is chosen between the internal high-frequency (HF) oscillator with external crystal (`HFOSC0`) and 12.5-MHz free-running RC oscillator. The selection is made through `CTRLMMR MCU_PLL_CLKSEL[8]` `CLKLOSS_SWTCH_EN`, see [Table 6-27](#).

**Table 6-27. PLL MCU Domain Reference Clock Selection - HFOSC0\_CLKOUT Selection**

| <code>CTRLMMR MCU_PLL_CLKSEL<sup>(1)</sup>[8]</code><br><code>CLKLOSS_SWTCH_EN</code> | <code>MCU_PLL0_REF_CLK</code>                                                                                    |
|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| 0 (default)                                                                           | <code>HFOSC0_CLK</code>                                                                                          |
| 1                                                                                     | <code>CLK_12M_RC</code> if clock loss is detected<br>or<br><code>HFOSC0_CLK</code> if clock loss is not detected |

(1) For more information about control registers, see *Control Module (CTRL\_MMR)*.

##### 6.4.5.3.2 PLLs in MAIN Domain

Each PLL in MAIN domain has a dedicated register (`CTRLMMR_MAIN_PLLn_CLKSEL` `CTRLMMR_MAIN_PLLn_CLKSEL`,  $n = 0$  to  $2, 8, 12, 15, 16, 17$ ) in `CTRL_MMR0` that contains associated control bits.

#### 6.4.5.4 Generic PLL Overview

To generate high-frequency clocks, the device supports multiple on-chip PLLs controlled directly by the Top-level Clocking. Their type is Fractional PLL with Calibration (PLLTS16FFCLAFRACF2).

#### Note

This chapter discusses only the PLLs that are directly controlled by the Top-level Clocking. The other PLLs embedded in and managed by other subsystems are described in their respective subsystems.

##### 6.4.5.4.1 PLLs Output Clocks Parameters

[Figure 6-41](#) shows the functional architecture of a generic PLL for PLLTS16FFCLAFRACF2 type.



**Figure 6-41. Generic PLL Functional Diagram for PLLTS16FFCLAFRACF2 Type**

#### 6.4.5.4.1.1 PLLs Input Clocks

As shown in Figure 6-41 the reference clock (FREF) input is used to generate the synthesized clock, but can also be used as the bypass clock for some outputs of the PLL whenever the PLL enters bypass mode. It is mandatory for the PLL clock synthesis.

#### 6.4.5.4.1.2 PLL Output Clocks

##### 6.4.5.4.1.2.1 PLLTS16FFCLAFRACF2 Type Output Clocks

Table 6-28 describes the output clocks of PLLTS16FFCLAFRACF2.

**Table 6-28. PLLTS16FFCLAFRACF2 Output Clocks**

| Output      | Description                                 | Frequency                                       |
|-------------|---------------------------------------------|-------------------------------------------------|
| FOUTP       | Positive phase VCO output (no post divider) | $(FREF / REF\_DIV) * (FB\_DIV + FB\_DIV\_FRAC)$ |
| FOUTN       | Negative phase VCO output (no post divider) | $(FREF / REF\_DIV) * (FB\_DIV + FB\_DIV\_FRAC)$ |
| FOUTPOSTDIV | VCO-divided clock output.                   | $FOUTP / (POST\_DIV1 * POST\_DIV2)$             |
| CLKSSCG     | Clock to SSMOD                              | $(FREF / REF\_DIV)$                             |

Where:

- REF\_DIV is the software-configured division ratio binary value.
- FB\_DIV is the software-configured division ratio binary value.
- FB\_DIV\_FRAC is the software-configured fractional division.
- POST\_DIV1 is the software-configured division ratio binary value.
- POST\_DIV2 is the software-configured division ratio binary value.

---

**Note**

POST\_DIV1 and POST\_DIV2 valid values are from 1 to 7. To ensure correct operation, POST\_DIV1 must always be programmed to a value equal to or greater than POST\_DIV2.

---

**Note**

For device-specific information about clock output parameters and synthesized clocks, see [Table 6-33](#) and [Table 6-34](#).

---

#### 6.4.5.4.1.2.2 PLL Lock

PLL module outputs a lock status signal to indicate that the PLL has achieved frequency lock. When the PLL detects no cycle slips between the feedback clock (FFB) and reference clock FREF/ REF\_DIV[5:0] for 128 consecutive cycles, it asserts the lock signal high. When the PLL detects any cycle slip, lock signal will go low and stays low until it detects no cycle slip for 128 consecutive cycles. This lock signal is captured in <PLL\_name>\_STAT[0] LOCK bit. Software can read this bit to determine if the PLL has achieved frequency lock before selecting the PLL clock through external bypass mux.

When PLL losses lock, there is a hardware mechanism to automatically bypass the PLL clock to the reference clock (FREF) using the external glitch free mux. BYP\_ON\_LOCKLOSS bit in <PLL\_name>\_CTRL register enables this automatic bypass mode on PLL lock loss. When the PLL re-locks, the glitch free mux switches to PLL clock out.

The PLL Lock signal is also routed to ESM module for error reporting. ESM can be configured to generate interrupts to MCU\_M4FSS0 and R5FSS0/1 and assert Low on MCU\_ERRORn pin on PLL Lock loss for further action.

#### 6.4.5.4.1.2.3 HSDIVIDER

A PLL may contain up to 10 HSDIVIDER modules to produce more clocks with divided ratio based on the PLL synthesized clock frequency. HSDIVIDER provides only one output. The HSDIVIDER output clock frequency is given by the equations in [Table 6-29](#).

**Table 6-29. HSDIV\_CLKOUT Frequency With PLL State**

| Equation                              | PLL Mode                     |
|---------------------------------------|------------------------------|
| $HSDIV\_CLKOUT = FOUTP / (HSDIV + 1)$ | Locked                       |
| $HSDIV\_CLKOUT = FREF$                | Before lock or during relock |

Where:

- FOUTP is the PLL lock frequency.
- HSDIV is the software-configured division ratio binary value.

[Figure 6-42](#) describes the connection between a HSDIV and a specific type of PLL. Signals related only to this connections are shown in both figures.



(1) $j$  = 0 to 4;  $j$  = 5 to 9

**Figure 6-42. PLLTS16FFCLAFRACF2 and HSDIV Connection**

#### 6.4.5.4.1.2.4 ICG Module

ICG module ensures that when a particular HSDIV is not enabled the HSDIV clock output is gated off. This is a hardware module with no software control.

#### 6.4.5.4.1.2.5 PLL Power Down

PLLTS16FFCLAFRACF2 is disabled with MCU\_PLL0\_CTRL[15] PLL\_EN or PLLn\_CTRL[15] PLL\_EN.

#### 6.4.5.4.1.2.6 PLL Calibration

PLLTS16FFCLAFRACF2 has calibration feature. The calibration settings are done via `<PLL_Name>_CAL_CTRL` register. The calibration status can be monitored by reading

<PLL\_Name>\_CAL\_STAT register. For more information about device-specific information about calibration feature, see [Table 6-35](#).

#### 6.4.5.4.2 PLL Spread Spectrum Modulation Module

Spread Spectrum Modulation (SSMOD) modules on the device reduces Electro Magnetic Interference (EMI). It is a fully-digital circuit, used to modulate the frequency of the selected fractional PLLs. Programming options include selection of center spread or down spread, modulation depth, and modulation shape. The default modulation profile is triangular.

All PLLs in this family of device have SSMOD module.

SSMOD in the PLL is performed by changing the feedback divider (FRAC and FB\_DIV) in a triangular pattern. This varies the frequency of the output clock in a triangular pattern. The frequency of this pattern is the modulation frequency ( $f_m$ ). It is programmed as a ratio of the CLKIN/4.

[Figure 6-43](#) shows a diagram of the spreading generation block.



prcm-086

**Figure 6-43. Spreading Generation Block Diagram**

#### Note

$\Delta f$  is the deviation from the center frequency. The total spreading deviation is equal to twice  $\Delta f$ . The peak ( $\Delta M$ ) or the amplitude of the triangular/square pattern as a percent of  $M$  would be equal to the percent of the frequency spread ( $\Delta f$ ).  $\Delta M/M = \Delta f/f_c$ .

$f_c$  is the original output clock frequency.

$f_m$  is the spreading frequency.

This additional block generates the required waveform used to reduce EMI. This waveform is then modulated with the initial signal to add some controlled deviation to the clock signal frequency, which spreads the energy of the clock and its harmonics into a band of frequencies, and then reduces EMI. SSMOD\_DOWNSPREAD can control the position of the generated signal. It is controlled by the <PLL\_name>\_CTRL[4] DOWNSPREAD\_EN

bit of the corresponding registers. If the DOWNSPREAD\_EN bit is set to 1, the frequency spread on the lower side is twice the programmed value. The frequency spread on the higher side is 0.

The value of SSMOD\_FREQ controls the rate of the generated signal. It can be programmed as a ratio of the reference clock:  $f_{ref} / 4$ . The value that must be programmed is calculated as follows:

ModFreqDivider =  $f_{ref} / (4 \times f_m)$ , where  $f_m < f_{ref} / 70$ ,  $f_{ref} = f_{inp} / (1+N)$ , and  $f_{inp}$  is the input clock for the PLL.

#### 6.4.5.4.2.1 Definition of SSMOD

The aim of the SSMOD is to add a variation to the frequency of an original clock, which spreads the generated interference over a larger band of frequencies.

In theory, SSMOD means that the clock signal is varied around the desired frequency. For example, for a 1 GHz clock, the frequency might be 999.5 MHz at one time and 1.0005 GHz at another. Doing this constantly causes the power of the tone to be spread out more over a broader band of tight frequencies (centered at the desired tone). To realize this constant variation on the original signal, a modulation with an additional signal (called spreading waveform) is realized.

Creating an SSMOD by spreading the initial clock frequency is done by defining the following parameters:

- The spreading frequency (deviation), which is the ratio of the range of spreading frequency over the original clock frequency.

#### 6.4.5.4.2.2 SSMOD Configuration

Table 6-30 describes the PLL SSMOD control bitfields. Figure 6-44 describes the connection between a SSMOD and a PLL.

**Table 6-30. SSMOD related bitfields**

| Parameter                  | Register                                                                                                                                                               | Description                                                                                                                                                                                       |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SSMOD enable control       | <code>&lt;PLL_name&gt;n_SS_CTRL[31](1)</code><br>BYPASS_EN<br>(For example, <code>MCU_PLL0 -</code><br><code>MCU_PLL0_SS_CTRL[31]</code><br>BYPASS_EN)                 | Enable/disable the PLL SSMOD feature.                                                                                                                                                             |
| Wave table maximum address | <code>&lt;PLL_name&gt;n_SS_CTRL[25-18](1)</code><br>WV_TBL_MAXADDR<br>(For example, <code>MCU_PLL0 -</code><br><code>MCU_PLL0_SS_CTRL[25-18]</code><br>WV_TBL_MAXADDR) | Wave table maximum address. Indicates the maximum number of address bits used to access the externalwave table. These bits are not used if <code>&lt;PLL_name&gt;n_SS_CTRL[0]</code> WAVE_SEL = 0 |
| Type of spread             | <code>&lt;PLL_name&gt;n_SS_CTRL[4](1)</code><br>DOWNSPREAD_EN<br>(For example, <code>MCU_PLL0 -</code><br><code>MCU_PLL0_SS_CTRL[4]</code><br>DOWNSPREAD_EN)           | Selects center spread or down spread clock variance                                                                                                                                               |
| Wave table selection       | <code>&lt;PLL_name&gt;n_SS_CTRL[0](1)</code><br>WAVE_SEL<br>(For example, <code>MCU_PLL0 -</code><br><code>MCU_PLL0_SS_CTRL[0]</code><br>WAVE_SEL)                     | Wave pattern select External wave table should only be selected                                                                                                                                   |
| Modulation divider         | <code>&lt;PLL_name&gt;n_SS_SPREAD[19-16](1)</code><br>MOD_DIV<br>(For example, <code>MCU_PLL0 -</code><br><code>MCU_PLL0_SS_SPREAD[19-16]</code><br>MOD_DIV)           | Input clock divider. This divider sets the modulation frequency.                                                                                                                                  |
| Spread Depth               | <code>&lt;PLL_name&gt;n_SS_SPREAD[4-0](1)</code><br>SPREAD<br>(For example, <code>MCU_PLL0 -</code><br><code>MCU_PLL0_SS_SPREAD[4-0]</code><br>SPREAD)                 | Sets the spread modulation depth.                                                                                                                                                                 |

(1) n = 0 for MCU domain and n = 0 - 2, 8, 12, 15, 16 and 17 for MAIN domain



**Figure 6-44. PLL and SSMOD Connection**

#### 6.4.5.5 PLLs Device-Specific Information

Table 6-31 lists the basic information of the MCU PLL.

**Table 6-31. Basic Information of MCU\_PLL0**

| PLL name | Type               | SSMOD Available                                                                          | HSDIV Available                        | Input clock   | Comments                                                                |
|----------|--------------------|------------------------------------------------------------------------------------------|----------------------------------------|---------------|-------------------------------------------------------------------------|
| MCU_PLL0 | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0, HSDIV1, HSDIV2, HSDIV3, HSDIV4 | HFOSC0_CLKOUT | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |

(1) See [Figure 6-41, Generic PLL Functional Diagram for PLLTS16FFCLAFRACF2 type](#) for overview of the PLL.

(2) See [Section 6.4.5.5.2](#) for synthesized clock parameters.

(3) See [Section 6.4.5.5.3](#) for clock output parameters.

Table 6-32 lists the basic information of each of the MAIN PLLs.

**Table 6-32. Basic Information of MAIN Domain PLLs**

| PLL name | Type               | SSMOD Available                                                                          | HSDIV Available                                                                | Input clock        | Comments                                                                |
|----------|--------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------|-------------------------------------------------------------------------|
| PLL0     | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0, HSDIV1, HSDIV2, HSDIV3, HSDIV4, HSDIV5, HSDIV6, HSDIV7, HSDIV8, HSDIV9 | MAIN_PLL0_REF_CLK  | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |
| PLL1     | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0, HSDIV1, HSDIV2, HSDIV3, HSDIV4, HSDIV5, HSDIV6                         | MAIN_PLL1_REF_CLK  | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |
| PLL2     | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0, HSDIV1, HSDIV2, HSDIV3, HSDIV4, HSDIV5, HSDIV6, HSDIV7, HSDIV8, HSDIV9 | MAIN_PLL2_REF_CLK  | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |
| PLL8     | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0                                                                         | MAIN_PLL8_REF_CLK  | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |
| PLL12    | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0                                                                         | MAIN_PLL12_REF_CLK | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |
| PLL15    | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0, HSDIV1                                                                 | MAIN_PLL15_REF_CLK | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |
| PLL16    | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0                                                                         | MAIN_PLL16_REF_CLK | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |
| PLL17    | PLLTS16FFCLAFRACF2 | Yes, see <a href="#">Table 6-30</a> for more information on SSMOD related bitfields/bits | HSDIV0                                                                         | MAIN_PLL17_REF_CLK | See <a href="#">(1)</a> , <a href="#">(2)</a> , and <a href="#">(3)</a> |

(1) See [Figure 6-41, Generic PLL Functional Diagram for PLLTS16FFCLAFRACF2 type](#) for overview of the PLL.

(2) See [Section 6.4.5.5.2](#) for synthesized clock parameters.

(3) See [Section 6.4.5.5.3](#) for clock output parameters.

**6.4.5.5.1 SSMOD Related Bitfields Table**

Table 6-30 lists SSMOD related bitfields for all types of PLLs.

#### 6.4.5.5.2 Clock Synthesis Inputs to the PLLs

Table 6-33 lists the clock synthesis parameters for PLLTS16FFCLAFRACF2 type.

**Table 6-33. Clock synthesis Parameters for PLLTS16FFCLAFRACF2 Type**

| Parameter Name | Register                                                                                                      |
|----------------|---------------------------------------------------------------------------------------------------------------|
| FB_DIV         | <PLL_name>_FREQ_CTRL0[11-0] FB_DIV_INT<br>(For example, MCU_PLL0 -<br>MCU_PLL0_FREQ_CTRL0[11-0] FB_DIV_INT)   |
| FB_DIV_FRAC    | <PLL_name>_FREQ_CTRL1[23-0] FB_DIV_FRAC<br>(For example, MCU_PLL0 -<br>MCU_PLL0_FREQ_CTRL1[23-0] FB_DIV_FRAC) |
| POST_DIV2      | <PLL_name>_DIV_CTRL[26-24] POST_DIV2<br>(For example, MCU_PLL0 -<br>MCU_PLL0_DIV_CTRL[26-24] POST_DIV2)       |
| POST_DIV1      | <PLL_name>_DIV_CTRL[18-16] POST_DIV1<br>(For example, MCU_PLL0 -<br>MCU_PLL0_DIV_CTRL[18-16] POST_DIV1)       |
| REF_DIV        | <PLL_name>_DIV_CTRL[5-0] REF_DIV<br>(For example, MCU_PLL0 -<br>MCU_PLL0_DIV_CTRL[5-0] REF_DIV)               |

**Note**

For PLLTS16FFCLAFRACF2 type - POST\_DIV1 and POST\_DIV2 values are from 1 to 7. To ensure correct operation, POST\_DIV1 must always be programmed to a value equal to or greater than POST\_DIV2.

#### 6.4.5.5.3 Clock Output Parameter

Table 6-34 lists the control/status bit fields for output clocks.

**Table 6-34. Clock Output Parameter for PLLTS16FFCLAFRACF2 Type**

| Clock Output/Divider                                          | Parameter Name  | Control/Status Bit Field                                                                                                                          |
|---------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <PLL_name>_CLKOUT,<br><PLL_name>_HSDIVj_CLKOUT <sup>(1)</sup> | Control         | <PLL_name>_CTRL[31] BYPASS_EN<br>(For example, MCU_PLL0 -<br>MCU_PLL0_CTRL[31] BYPASS_EN)                                                         |
| <PLL_name>_HSDIVj_CLKOUT <sup>(1)</sup>                       | Control         | <PLL_name>_HSDIV_CTRLj[15] CLKOUT_EN<br>(For example, MCU_PLL0 -<br>MCU_PLL0_HSDIV_CTRL0[15] CLKOUT_EN and<br>MCU_PLL0_HSDIV_CTRL1[15] CLKOUT_EN) |
| <PLL_name>_HSDIVj_CLKOUT <sup>(1)</sup>                       | Divider control | <PLL_name>_HSDIV_CTRLj[6-0] HSDIV<br>(For example, MCU_PLL0 -<br>MCU_PLL0_HSDIV_CTRL0[6-0] HSDIV and<br>MCU_PLL0_HSDIV_CTRL1[6-0] HSDIV)          |
| PLL bypass mux                                                | Control         | <PLL_name>_CTRL[16] BYP_ON_LOCKLOSS<br>(For example, MCU_PLL0 -<br>MCU_PLL0_CTRL[16] BYP_ON_LOCKLOSS)                                             |
| Enable 4-phase clock generator                                | Control         | <PLL_name>_CTRL[5] CLK_4PH_EN (ignored if<br><PLL_name>_CTRL[4] CLK_POSTDIV_EN = 0)<br>(For example, MCU_PLL0 -<br>MCU_PLL0_CTRL[5] CLK_4PH_EN)   |
| Post divide CLK enable                                        | Control         | <PLL_name>_CTRL[4] CLK_POSTDIV_EN<br>(For example, MCU_PLL0 -<br>MCU_PLL0_CTRL[4] CLK_POSTDIV_EN)                                                 |
| Delta-Sigma modulator enable                                  | Control         | <PLL_name>_CTRL[1] DSM_EN<br>(For example, MCU_PLL0 -<br>MCU_PLL0_CTRL[1] DSM_EN)                                                                 |

**Table 6-34. Clock Output Parameter for PLLTS16FFCLAFRACF2 Type (continued)**

| Clock Output/Divider                  | Parameter Name | Control/Status Bit Field                                                          |
|---------------------------------------|----------------|-----------------------------------------------------------------------------------|
| Enable fractional noise canceling DAC | Control        | <PLL_name>_CTRL[0] DAC_EN<br>(For example, MCU_PLL0 -<br>MCU_PLL0_CTRL[0] DAC_EN) |

(1) j is the number of HSDIV for the current PLL.

#### 6.4.5.5.4 Calibration Related Bitfields

Table 6-35 lists the calibration related bitfields/bits.

**Table 6-35. Recalibration Feature Parameters**

| Recalibration feature                                | Parameter Name | Control/Status Bit Field                                                                      |
|------------------------------------------------------|----------------|-----------------------------------------------------------------------------------------------|
| Calibration enable to actively adjust for input skew | Control        | <PLL_name>_CAL_CTRL[31] CAL_EN<br>(For example, PLL12 -<br>PLL12_CAL_CTRL[31] CAL_EN)         |
| Fast calibration enabled                             | Control        | <PLL_name>_CAL_CTRL[20] FAST_CAL<br>(For example, PLL12 -<br>PLL12_CAL_CTRL[20] FAST_CAL)     |
| Calibration loop programmable counter                | Control        | <PLL_name>_CAL_CTRL[18-16] CAL_CNT<br>(For example, PLL12 -<br>PLL12_CAL_CTRL[18-16] CAL_CNT) |
| Calibration bypass                                   | Control        | <PLL_name>_CAL_CTRL[15] CAL_BYP<br>(For example, PLL12 -<br>PLL12_CAL_CTRL[15] CAL_BYP)       |
| Calibration input                                    | Control        | <PLL_name>_CAL_CTRL[11-0] CAL_IN<br>(For example, PLL12 -<br>PLL12_CAL_CTRL[11-0] CAL_IN)     |
| Output of the calibration block                      | Status         | <PLL_name>_CAL_STAT[11-0] CAL_OUT<br>(For example, PLL12 -<br>PLL12_CAL_STAT[11-0] CAL_OUT)   |

#### 6.4.5.6 PLL Controller (PLLCTRL)

The PLLCTRL manages clock alignment of CBASS clocks to the peripherals in Main and MCU domains. In addition PLLCTRL is also responsible for controlling reset propagation through the chip and providing DFT hooks for testability. Two PLL Controllers are implemented in the device - PLLCTRL0 and MCU\_PLLCTRL0. They are respectively related to PLL0 and MCU\_PLL0.



clocking-0012

**Figure 6-45. PLL Controller**

---

**Note**

PLLCTRL\_POSTDIV is not supported in this family of devices.

---

---

**Note**

The PLL Controllers registers can be accessed by any controller in the device.

A SYSCLK0 clock out of a PLLCTRL is the only synchronous clock in that domain. That means  
- MCU\_SYSCLK0 out of MCU\_PLLCTRL is the synchronous CBASS clock in MCU domain and  
SYSCLK0 out of Main PLLCTRL is the synchronous CBASS clock in Main domain.

---

## 6.4.5.7 PLL, PLLCTRL, and HSDIV Controllers Programming Guide

### 6.4.5.7.1 PLL Initialization

#### 6.4.5.7.1.1 Kick Protection Mechanism

---

**Note**

PLL configuration registers are write-protected at power-up. Software must first un-lock the PLLn\_LOCKKEY0 and PLLn\_LOCKKEY1 registers prior to writing to any chip-level registers.

---

The un-lock process shall follow the steps:

1. Write value 0x68EF3490 to PLLn\_LOCKKEY0 register.
2. Write value 0xD172BC5A to PLLn\_LOCKKEY1 register.

After these two steps a write access to the PLL registers is allowed. Writing any other data value to either of these two registers locks the kicker mechanism and blocks any writes to the PLL registers.

---

**Note**

In order to ensure that all PLL registers are write protected, software must always re-lock the kicker mechanism after completing the register writes.

---

#### 6.4.5.7.1.2 PLLCTRL Initialization

---

**Note**

For validated set of parameters that can be programmed to PLLs, please refer to the device-specific Datasheet.

---

Initially, the device powers up in PLL bypass mode. The bypass mux is a glitch free mux and is located outside the PLL module. BYPASS\_EN bit controls the bypass mux section. During Power-up, the bypass mux defaults to select FREF clock (PLL clock bypass mode).

The following shows the PLL initialization sequence.

1. Wait until supplies are stable and PORz is de-asserted. By this time the reference clock source must be up and running.
2. Default controls settings:
  - By default PLL\_EN signal is Low provided by <PLL\_name>\_CTRL register default state. This signal behaves like a reset control to the PLL.
  - By default INTL\_BYP\_EN signal is low provided by <PLL\_name>\_CTRL register default state.
  - By default BYPASS\_EN signal is high provided by PLL MMR CTRL default state. PLL clock will be bypassed externally by a glitch free mux. The output of the mux will be the reference clock FREF.
  - LOCK output of PLL will be Low.

3. Program the PLL to a valid setting that runs the VCO within the specified range. The following bits/bitfields must be programmed appropriately by software: DSM\_EN, DAC\_EN, CLK\_POSTDIV\_EN, CLK\_4PH\_EN, REF\_DIV[5:0], FB\_DIV[11:0], FB\_DIV\_FRAC[23:0], POST\_DIV1[2:0], POST\_DIV2[2:0].
4. Wait for 1  $\mu$ s to allow the PLL internal reset to complete (PLL powerdown switch pulls the loop filter voltage from rail-to-rail, which ensures the PLL will be completely powered down from any state).
5. Assert PLL\_EN to a High (by writing a '1' into PLL\_EN bit in <PLL\_name>\_CTRL register).
6. Wait for PLL Lock output to go high. Software can read the LOCK bit in <PLL\_name>\_STATS register to check if PLL has locked.
7. De-assert BYPASS\_EN signal to a Low by writing 0 into BYPASS\_EN bit in <PLL\_name>\_CTRL register.
8. Glitch free mux safely switches to the PLL clock output.

#### Note

In the case of brown out (supply dips below datasheet minimum) or loss of the reference clock, the state of the PLL will be undetermined. A full reset sequence should be initiated.

**Changing PLL setting:** During normal operation, before changing PLL settings, the PLL clock must be bypassed by setting BYPASS\_EN control to a high. Then follow steps 2 to 8 from the above sequence.

#### 6.4.5.7.1.3 PLL Programming Requirements

- A PLL VCO frequency must be set to > 1500 MHz
  - For best PLL performance, maximize VCO frequency where possible.
- A PLL must always operate in Fractional Mode (DAC\_EN and DSM\_EN set to '1'). This is true even when the FB\_DIV is a integer.
- A PLL Reference clock frequency must be > 10 MHz.
- REF\_DIV[5:0] must be set to "000001".
- Calibration procedures for FRACF PLLs in integer mode or fractional mode:
  - **Programming FRACF in Integer Mode with calibration (Static or Auto Calibration)**
    - Set all the common PLL settings (PREDIV, FB DIV, ...)
    - DACEN: 0
    - DSMEN = 0 (INT MODE)
    - FASTCAL=1
    - CALBYPASS=0
    - CALCNT[2:0]=2
    - CALIN[11:0]=0
    - CAL\_EN=1
    - SET PLL\_EN = 1
    - WAIT FOR PLL\_LOCK AND CAL\_LOCK GO HI
    - CAPTURE AND STORE CALCODE WHEN CAL\_LOCK GOES HI IF IT WILL BE USED LATER
    - IF CAL\_LOCK times out ( > 2 ms ) then continue
    - CAL\_EN=0 (OPTIONAL, THIS WILL FREEZE CALIBRATION & INTERNAL CALCODE)
  - **Programming FRACF in Fractional Mode (with Static Calcode)**
    - Set all common PLL settings to nearest integer (PREDIV, FB DIV, ...)
    - Run calibration as outlined in integer mode
    - CAPTURE AND STORE CALCODE WHEN CAL\_LOCK GOES HI IF IT WILL BE USED LATER
    - IF CAL\_LOCK times out ( > 2 ms ) then continue
    - CAL\_EN=0 (THIS WILL FREEZE CALIBRATION & INTERNAL CALCODE)
    - IF CAL\_LOCK timed out, keep CALBYPASS=0
    - IF CAL\_LOCK IS ASSERTED AND CALCODE IS CAPTURED APPLY CALCODE TO CALIN
    - CALBYPASS=1 CALCODE IS SET BY CALIN
    - ENABLE FRACTIONAL MODE
  - **Programming FRACF in Fractional Mode (Auto-Calibration Not Allowed)**
    - Set all the common PLL settings (PREDIV, FB DIV, ...)
    - DACEN=1

- DSMEN=1 (FRAC MODE)
- FASTCAL =X
- CALBYPASS=1 CALCODE IS SET BY CALIN
- CALCNT[2:0]=XX
- CALIN[11:0] = 0 (OR DESIRED CALCODE)
- CAL\_EN = 0
- SET PLL\_EN = 1
- WAIT FOR PLL\_LOCK

PLL Integer mode with Calibration enabled is recommended for applications sensitive to phase noise or jitter: Examples include Refclk for SerDes, PHY, DDR etc. See individual product datasheets for specific SoC requirements. Calibration can be bypassed for digital clocks like ARM. If Calibration is bypassed, CALIN needs to be set to 0.

When Calibration is enabled, PLL Lock time will be longer since SOC needs to wait for CAL\_LOCK. Applications sensitive to phase noise must wait for CAL\_LOCK to go high.

#### 6.4.5.7.2 HSDIV PLL Programming

<PLL\_Name>\_HSDIV\_CTRLk[15] CLKOUT\_EN = 0 cleanly disables the HSDIV output clock

<PLL\_Name>\_HSDIV\_CTRLk[6-0] HSDIV = <value> for divider

<PLL\_Name>\_HSDIV\_CTRLk[8] SYNC\_DIS = 0 insures that the divider changes occur synchronously to the internal divider of the HSDIV block.

when the clock is required,

<PLL\_Name>\_HSDIV\_CTRLk[15] CLKOUT\_EN = 1 cleanly enables the HSDIV output clock

#### 6.4.5.7.3 PLL Controllers Programming - Dividers PLLDIVn and GO Operation

The GO operation is required to change the divider ratios of the PLLDIVn registers. [Section 6.4.5.7.3.1, GO Operation](#), discusses the GO operation. [Section 6.4.5.7.3.2, Software Steps to Modify PLLDIVn Ratios](#), provides the software steps required to change the divider ratios.

##### 6.4.5.7.3.1 GO Operation

The GO operation writes to the RATIO field in the PLLDIVn. Registers do not change the dividers' divide ratios immediately. The PLLDIV dividers change to the new RATIO rates only during a GO operation. This section discusses the GO operation and alignment of the SYSCLKs.

The PLL Controller clock align control register (ALNCTL) determines which SYSCLKs must be aligned. Before a GO operation, program ALNCTL so that the appropriate clocks are aligned during the GO operation.

A GO operation is initiated by setting the GOSET bit in PLLCMD to 1. During a GO operation:

- Any SYSCLK  $n$  with the corresponding ALN  $n$  bit in ALNCTL and SYS  $n$  bit in DCHANGE set to 1 is paused at the low edge. Then the PLL Controller restarts all these SYSCLKs simultaneously, aligned at the rising edge. When the SYSCLKs are restarted, SYSCLK  $n$  toggles at the rate programmed in the RATIO field in PLLDIVn.
- Any SYSCLK  $n$  with the corresponding ALN  $n$  bit in ALNCTL cleared and the SYS  $n$  bit in DCHANGE set immediately changes to the new rate programmed in the RATIO field.
- The GOSTAT bit in PLLSTAT is set throughout the duration of a GO operation.

#### CAUTION

To help prevent errors, all device operation must be stopped before the GO operation.

#### 6.4.5.7.3.2 Software Steps to Modify PLLDIV Ratios

Perform the following steps to modify PLLDIV.

1. Check that the GOSTAT bit in PLLSTAT is cleared to show that no GO operation is currently in progress.

2. Program the RATIO field in PLLDIVn to the desired new divide-down rate. If the RATIO field changed, the PLL Controller will flag the change in the corresponding bit of DCHANGE.
3. Set the respective ALN  $n$  bits in ALNCTL to align any SYSCLKs after the GO operation.
4. Set the GOSET bit in PLLCMD to initiate the GO operation to change the divide values and align the SYSCLKs as programmed.
5. Read the GOSTAT bit in PLLSTAT to make sure the bit returns to 0 to indicate that the GO operation has completed.

#### 6.4.5.7.4 Entire Sequence for Programming PLLCTRL, HSDIV, and PLL

Table 6-36 shows the entire sequence of programming PLLCTRL, HSDIV, and PLL from an unknown state to a defined non-spread-spectrum state.

**Table 6-36. Programming Sequence of PLLCTRL, HSDIV, and PLL**

| Step                                                            | Description                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Unlock PLL registers                                            | <PLL_Name>_LOCKKEY0 (= 0x68EF3490)<br><PLL_Name>_LOCKKEY1 (= 0xD172BC5A)                                                                                                                                                                                                                           |
| If PLL0                                                         | Configure PLLCTRL block into bypass mode<br>PLLCTL[0] PLLLEN = 0<br>PLLCTL[5] PLLENSRC = 0                                                                                                                                                                                                         |
| Configure external bypass so that no transient clock propagates | <PLL_Name>_CTRL[31] BYPASS_EN = 1                                                                                                                                                                                                                                                                  |
| Delay                                                           |                                                                                                                                                                                                                                                                                                    |
| Disable HSDIV(s)                                                | <PLL_Name>_HSDIV_CTRLK[15] CLKOUT_EN = 0                                                                                                                                                                                                                                                           |
| Delay                                                           |                                                                                                                                                                                                                                                                                                    |
| Disable PLL                                                     | <PLL_Name>_CTRL[15] PLL_EN = 0                                                                                                                                                                                                                                                                     |
| Delay                                                           |                                                                                                                                                                                                                                                                                                    |
| Reset HSDIV(s)                                                  | <PLL_Name>_HSDIV_CTRLK[31] RESET = 1                                                                                                                                                                                                                                                               |
| If PLL0                                                         | Check PLLSTAT[0] GOSTAT to make sure that divider change is not currently in-progress GOSTAT should equal 0.<br>Clear GOSET bit PLLCMD[0] GOSET = 0<br>Configure divider in PLLCTRL to /1<br>PLLDIV1 = 0x8000 (enable divider and divide by 1)<br>PLLDIV2 = 0x00 (disable divider and divide by 1) |
|                                                                 | Set alignment control bits<br>ALNCTL = 3                                                                                                                                                                                                                                                           |
|                                                                 | Set GOSET bit to initiate the divider change<br>PLLCMD[0] GOSET = 1                                                                                                                                                                                                                                |
|                                                                 | Check PLLSTAT[0] GOSTAT to make sure that divider change has completed<br>GOSTAT should equal 0.                                                                                                                                                                                                   |
| Configure HSDIV(s) divider value                                | <PLL_Name>_HSDIV_CTRLK[6-0] HSDIV (=val)                                                                                                                                                                                                                                                           |
| Clear HSDIV(s) SYNC_DIS                                         | <PLL_Name>_HSDIV_CTRLK[8] SYNC_DIS = 0                                                                                                                                                                                                                                                             |
| Delay                                                           |                                                                                                                                                                                                                                                                                                    |
| Clear Reset HSDIV(s)                                            | <PLL_Name>_HSDIV_CTRLK[31] RESET = 0                                                                                                                                                                                                                                                               |
| Configure PLL multiplier                                        | Integer portion of divider<br><PLL_Name>_FREQ_CTRL0[11-0] (=val)<br>Fractional portion of divider<br><PLL_Name>_FREQ_CTRL1[23-0] (=val)                                                                                                                                                            |
| Configure PLL dividers                                          | Reference clock divider<br><PLL_Name>_DIV_CTRL[5-0] REF_DIV = 1<br>Post divider 1 <PLL_Name>_DIV_CTRL[18-16]<br>POST_DIV1 = 1                                                                                                                                                                      |

**Table 6-36. Programming Sequence of PLLCTRL, HSDIV, and PLL (continued)**

| Step                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       | Post divider 2 <PLL_Name>_DIV_CTRL[26-24]<br>POST_DIV2 = 1                                                                                                                                                                                                                                                                                                                                                       |
| Configure “random” PLL controls       | <PLL_Name>_CTRL[8] INTL_BYP_EN = 0<br><PLL_Name>_CTRL[5] CLK_4PH_EN = 0<br><PLL_Name>_DIV_CTRL[26-24] POST_DIV2 = 1<br><PLL_Name>_DIV_CTRL[18-16] POST_DIV1 = 1<br><PLL_Name>_DIV_CTRL[5-0] REF_DIV = 1<br><PLL_Name>_CTRL[1] DSM_EN = 1<br><PLL_Name>_CTRL[0] DAC_EN = 1<br><PLL_Name>_SS_CTRL[31] BYPASS_EN (SSMOD) = 1<br><PLL_Name>_CTRL[4] CLK_POSTDIV_EN – if PLL has more than 5 HSDIV blocks, 1; else 0. |
|                                       | <PLL_Name>_CTRL[16] BYP_ON_LOCKLOSS (= {0, 1})                                                                                                                                                                                                                                                                                                                                                                   |
| Delay                                 |                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Enable PLL                            | <PLL_Name>_CTRL[15] PLL_EN = 1                                                                                                                                                                                                                                                                                                                                                                                   |
| Wait for Lock                         | Wait for MCU_PLL0_STAT[0] LOCK = 1                                                                                                                                                                                                                                                                                                                                                                               |
| Enable HSDIV(s)                       | <PLL_Name>_HSDIV_CTRL[15] CLKOUT_EN = 1                                                                                                                                                                                                                                                                                                                                                                          |
| Delay                                 |                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Configure external bypass to pass PLL | <PLL_Name>_CTRL[31] BYPASS_EN = 0                                                                                                                                                                                                                                                                                                                                                                                |
| Delay                                 |                                                                                                                                                                                                                                                                                                                                                                                                                  |
| If PLL0                               | Configure PLLCTRL block into PLL mode<br>PLLCTL[0] PLLEN = 0                                                                                                                                                                                                                                                                                                                                                     |
| Lock PLL registers                    | <PLL_Name>_LOCKKEY0 (= any value)<br><PLL_Name>_LOCKKEY1 (= any value)                                                                                                                                                                                                                                                                                                                                           |

#### 6.4.5.7.5 Dual Clock Comparator (DCC)

The Dual Clock Comparator (DCC) is used to determine the accuracy of a clock signal during the time execution of an application. Specifically, the DCC is designed to detect drifts from the expected clock frequency. The desired accuracy can be programmed based on calculation for each application. The DCC measures the frequency of a selectable clock source using another input clock as a reference. Internal 12.5 MHz RC oscillator clock is used to validate HFOSC0\_CLKOUT. Then HFOSC0\_CLKOUT (most accurate clock) is used to validate/track all other clocks in the device. An additional use of this module is to measure the frequency of a selectable clock source, using an external input clock source of known frequency (MCU\_EXT\_REFCLK0, EXT\_REFCLK1 pins). There is one instance of DCC module in MCU domain and seven instances of DCC modules in Main domain to monitor critical clocks. Refer to DCC chapter for details.

#### 6.4.5.7.6 DeepSleep Clock Gating

This device supports deepsleep mode where the HFOSC0\_CLK is synchronously gated during deep-sleep entry sequence. HFOSC0 Clock loss detection mux control must be disabled during Deepsleep entry mode. (CLKLOSS\_SWITCH\_EN must be ‘0’).

In addition, HFOSC0 can be put into Power-down mode. When exiting deep-sleep mode, HFOSC0 is powered-up, wait until clock is stabilized and disable the clock gating so clock can propagate to PLL and Wake-up domain. This function is handled by Deep-sleep Hardware logic in Wake-up Domain.

**6.4.5.7.6.1 Software responsibility of clock settings during deeplsleep mode**

- Before going into deeplsleep mode, software must ensure to configure the clock mux controls of modules in MCU domain such that when it resumes from sleep mode these modules will have a functional clock when MCU domain reset is de-asserted. Examples of such modules are: TIMER, WDT/RTI, SPI, MCAN and UART. This is a very important requirement to ensure a proper reset of MCU domain modules coming out of deeplsleep mode.
- For modules in Wake-up domain, during deeplsleep resume, DM/Pulsar must ensure to first enable the functional clocks before accessing the modules in wake-up domain. This requirement is also applicable during normal mode of operation.

## Chapter 7

# Processors and Accelerators



This chapter describes the Processor and Accelerator modules in the device.

|                                                           |     |
|-----------------------------------------------------------|-----|
| 7.1 Arm Cortex-A53 Subsystem (A53SS).....                 | 643 |
| 7.2 Device Manager Cortex R5F Subsystem (WKUP_R5FSS)..... | 652 |
| 7.4 Programmable Real-Time Unit Subsystem (PRUSS).....    | 698 |

## 7.1 Arm Cortex-A53 Subsystem (A53SS)

This section describes the Arm® Cortex®-A53 Subsystem (A53SS) in the device.

## 7.1.1 A53SS Overview

### 7.1.1.1 A53SS Introduction

The SoC implements one cluster of quad-core Arm® Cortex® A53 MPCore™, with 32KB L1 instruction, 32KB L1 data, per core and 512KB L2 shared cache.

The Cortex®-A53 cores are general-purpose processors that can be used for running customer applications.

---

#### Note

Notes on references used in this document:

- A53SS is also referred to as Arm® CorePac.
  - Cortex®-A53 is often shortened to A53.
- 

The A53SS is built around the Cortex®-A53 MPCore™ (Arm® A53 Cluster), which is provided by Arm and configured by TI. It is based on the symmetric multiprocessor (SMP) architecture, and thus it delivers high performance and optimal power management, debug and emulation capabilities.

The A53 processor is a multi-issue out-of-order superscalar execution engine with integrated L1 Instruction and Data Caches, compatible with Arm®v8-A architecture. It delivers significantly more performance than its predecessors at a higher level of power efficiency.

The Arm®v8-A architecture brings a number of new features. These include 64-bit data processing, extended virtual addressing and 64-bit general purpose registers. The A53 processor is Arm's first Arm®v8-A processor aimed at providing power-efficient 64-bit processing. It features an in-order, 8-stage, dual-issue pipeline, and improved integer, Arm® Neon™, Floating-Point Unit (FPU) and memory performance.

The A53 CPU supports two execution states: AArch32 and AArch64. The AArch64 state gives the A53 CPU its ability to execute 64-bit applications, while the AArch32 state allows the processor to execute existing Arm®v7-A applications.

### 7.1.1.2 A53SS Features

The A53SS module supports the following features:

- Quad Core A53 Cluster
  - Full Arm®v8-A Architecture Compliant
    - AArch32 and AArch64 Execution States
    - All exception levels EL0-3
    - A32 Instruction Set (Previously Arm instruction set)
    - T32 instruction set (Previously Thumb instruction set)
    - A64 Instruction Set
  - Data Coherency within Cluster (L1/L2 caches)
  - Advanced SIMD and Floating Point Extensions (Arm® Neon™)
  - Armv8 Cryptography Extensions
  - Arm GICv3 architecture
  - In-order pipeline with symmetric dual-issue of most instructions
  - Harvard L1 with system MMU
    - 32 KB Instruction Cache
    - 32 KB Data Cache
  - 512KB Shared L2 Cache
  - Generic Timer(s)
  - Debug
- 128-Bit VBUSM Initiator Interfaces (for axi\_r and axi\_r channels)
- 128-Bit VBUSM Target Interface (for Accelerator Coherency Port)
- 64-bit Grey-coded system input time
- 48-bit Grey-coded debug input time

- 48-bit Grey-coded debug input time
- Integrated PBIST controller with BISOR

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

## 7.1.2 A53SS Functional Description

### 7.1.2.1 A53SS Block Diagram

### 7.1.2.2 Arm Cortex-A53 Cluster

The Arm Cortex-A53 Cluster is provided by Arm and configured by TI. [Table 7-1](#) summarizes the configuration of the Arm Cortex-A53 Cluster on this SoC.

**Table 7-1. Arm A53 Cluster Configuration**

| Parameter                                  | Value                                            |
|--------------------------------------------|--------------------------------------------------|
| Core Type                                  | A53                                              |
| Core Revision                              | r0p4                                             |
| Number of Cores                            | 4                                                |
| Bus Width                                  | 256                                              |
| L1 Instruction Cache Size                  | 32K                                              |
| L1 Data Cache Size                         | 32K                                              |
| L2 Cache Size                              | 512K                                             |
| SCU-L2 Cache Protection                    | Included                                         |
| Advanced SIMD and Floating Point Extension | Included                                         |
| Cryptography Extension                     | Included                                         |
| CPU Cache Protection                       | Included                                         |
| AMBA5 CHI or AMBA4 ACE Interface           | AMBA4 ACE<br>(configured for AXI using tie-offs) |
| Accelerator Coherency Port (ACP)           | Included                                         |
| V7 or v8 Debug Memory Map                  | v8                                               |

### Note

For a brief list of features supported by the Arm Cortex-A53 Cluster, see [A53SS Features](#).

For detailed description of the Arm A53 Cluster, see the *ARM® Cortex®-A53 MPCore Processor Technical Reference Manual*.

### 7.1.2.3 A53SS Interfaces and Async Bridges

The A53SS has the following main interfaces:

- 64-bit graycoded system input time
  - Graycode value provided by Global Timebase Counter (GTC)
  - Dedicated decoder (64-bit input) for graycode-to-binary conversion
- 48-bit graycoded debug input time
  - Graycode value provided by GTC
  - Dedicated decoder (48-bit input) for graycode-to-binary conversion
- 32-bit VBUSP target interface for debug
  - Supported by VBUSP2APB Bridge, which performs VBUSP-to-APB conversion (for controlling the Arm A53 Cluster internal debug logic)
- 32-bit ATB output port for debug/trace
  - Supported by ATB Bridge, which performs clock and voltage level conversion on the combined ATB interface
  - Connected to the Debug Subsystem
- Cross Trigger Interface (CTI) for debug
  - Connected to the Debug Subsystem
- Interface(s) with Arm GIC-500 Interrupt Controller

- Supported by GIC AXI Streaming Bridge, which performs clock and voltage level conversion on the AXI streaming protocol
- Interrupts (PPIs) from Arm A53 Cluster to GIC-500
- Interrupts (IRQ, FIQ, VIRQ, VFIQ) from GIC-500 to Arm A53 Cluster
- Power/clock interface(s)
  - Dedicated PLL for each Arm A53 Cluster
  - Dedicated LPSC for each Arm A53 Cluster, and also for each A53 core

#### 7.1.2.4 A53SS Interrupts

##### 7.1.2.4.1 A53SS Interrupt Inputs

The A53 CPU receives interrupts at its inputs (IRQ, FIQ, VIRQ, VFIQ) via the dedicated Arm GIC-500 Interrupt Controller, which resides at the SoC level (MAIN Domain) and is integrated inside the GIC0 Subsystem. The GIC-500 supports all four A53 cores in the system.

The GIC-500 is compliant to the Arm GICv3 standard and supports four types of interrupts:

- *Software Generated Interrupts (SGI)*
  - There are 16 SGIs (ID0-ID15)
  - These are inter-processor interrupts
- *Private Peripheral Interrupts (PPI)*
  - There are 16 PPIs (ID16-ID31)
  - These are wired interrupts dedicated to a specific CPU
  - Many are reserved to specific functions via convention
- *Shared Peripheral Interrupts (SPIs)*
  - There are 256 SPIs (ID32-ID288)
  - These are wired interrupts that can be routed to any core or cluster, based on the programming of that interrupt in the GIC500
- *Locality-Specific Peripheral Interrupts (LPI)*
  - There are 57,344 LPIs
  - These interrupts are used for message-based interrupts from a peripheral

The mapping of PPIs and SPIs to the GIC-500 interrupt inputs can be found in *Interrupts*.

---

#### Note

For a brief list of features supported by the GIC-500 module, see the *Interrupts* chapter.

For detailed description of the GIC-500 module, see the *Arm® CoreLink™ GIC-500 Generic Interrupt Controller Technical Reference Manual*.

---

##### 7.1.2.4.2 A53SS Interrupt Outputs

[A53SS Interrupt Outputs](#) lists the interrupts generated by the A53SS.

**Table 7-2. A53SS Interrupt Outputs**

| Interrupt Name (TI) <sup>(1)</sup>              | Interrupt Name (Arm) | Interrupt Description                                                                                                                                                                                                                       |
|-------------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>A53 Core Interrupts (PPIs)<sup>(2)</sup></b> |                      |                                                                                                                                                                                                                                             |
| A53_COREy_VCPUMNTIRQ                            | VCPUMNTIRQn          | <p>This interrupt indicates that a Virtual CPU Interface on the corresponding core needs serviced.</p> <p>This interrupt is serviced by software switching to the virtual CPU and finding what specific service needs done.</p>             |
| A53_COREy_CNTHPIRQ                              | CNTHPIRQn            | <p>This interrupt indicates a physical timer event at the EL2 (Hypervisor) exception level.</p> <p>Service of this interrupt is dependent on what the timer was set for. Software should take exception to EL2 and service accordingly.</p> |

**Table 7-2. A53SS Interrupt Outputs (continued)**

| Interrupt Name (TI) <sup>(1)</sup> | Interrupt Name (Arm) | Interrupt Description                                                                                                                                                                                                                                                     |
|------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A53_COREy_CNTPNSIRQ                | CNTPNSIRQn           | This interrupt indicates a physical timer event at the EL1 Non-Secure exception level.<br>Service of this interrupt is dependent on what the timer was set for. Software should take exception to EL1 Non-Secure and service accordingly.                                 |
| A53_COREy_CNTPSIRQ                 | CNTPSIRQn            | This interrupt indicates a physical timer event at the EL1 Secure exception level.<br>Service of this interrupt is dependent on what the timer was set for. Software should take exception to EL1 Secure and service accordingly.                                         |
| A53_COREy_CNTVIRQ                  | CNTVIRQn             | This interrupt indicates a Virtual timer event.<br>Service of this interrupt is dependent on what the timer was set for. Software should take exception and service accordingly.                                                                                          |
| A53_COREy_PMUIRQ                   | PMUIRQn              | This interrupt is generated by the Performance Monitor Unit (PMU).<br>The PMU can generate an interrupt based on several conditions, depending on programming.<br>Software should take exception and query the PMU as to the cause of the interrupt, and act accordingly. |
| A53_COREy_DCCIRQ                   | COMMIRQn             | Communications Channel receive or transmit interrupt                                                                                                                                                                                                                      |
| A53_COREy_CTIIRQ                   | CTIIRQn              | Cross Trigger Interface interrupt                                                                                                                                                                                                                                         |

(1) In this column, *y* is the A53 Core index (0 or 1)

(2) These are 'per core' interrupts

### Note

The mapping of these interrupts in the system is summarized in *A53SS Integration*, and can also be found in *Interrupts*.

For more detailed description of these interrupts and their handling, see the *Arm® Cortex®-A53 MPCore Processor Technical Reference Manual*.

## 7.1.2.5 A53SS Power Management and Clocking

### 7.1.2.5.1 A53SS Power Management

Each Arm A53 Cluster and each A53 CPU reside in a separate power domain, as follows:

There is a dedicated Local Power Sleep Controller (LPSC) for each Arm A53 Cluster, and for each A53 core, as well. The LPSC assignment is as follows:

For more details on these LPSCs, including power-up/down sequences, see *Power*.

### 7.1.2.5.2 A53SS Clocking

There is a dedicated PLL for each Arm A53 Cluster. The PLL assignment is as follows:

- PLL8 (ARM0 PLL): Dedicated for Arm A53 Cluster 0

For more details on these PLLs, see *Clocking*.

### 7.1.2.6 A53SS Debug

The A53SS supports the standard Arm debug architecture. Details on Arm debug can be found in the *On-chip Debug* chapter and the relevant Arm specifications.

### 7.1.2.7 A53SS Global and Debug Timestamps

The A53SS has two timebase input interfaces:

- 64-bit global timestamp: Used for synchronizing the Arm internal timers (via the ARM CNTVALUEB [63:0] bus)
- 48-bit debug timestamp: Can be embedded in Arm trace streams at periodic and strategic locations, allowing the temporal relationship of different trace sources to be determined

Both of them are fed by the Global Timebase Counter (GTC), which provides a 64-bit graycode value. The A53SS includes two graycode decoders (for global time and debug time, respectively), which take the asynchronous graycoded times, synchronize them to the appropriate clock, and convert them to binary time, as required by Arm.

#### **Note**

Both graycode decoders are 64-bit but the one dedicated to debug time has a 48-bit input (the upper 16 bits are tied to 0).

For more details on the GTC, see *Global Timebase Counter (GTC)*.

#### **7.1.2.8 A53SS Watchdog**

The A53SS does not have an integrated watchdog timer. Instead, this feature is provided externally by the Real Time Interrupt Module (RTI) module, which implements a windowed watchdog timer capable of issuing warm reset to the SoC, when necessary.

For more details on the RTI windowed watchdog feature, see *Real Time Interrupt Module (RTI/WWDT)*.

#### **7.1.2.9 A53SS Functional Safety - ECC Error Injection Support**

In the quad A53 CBA subsystem, there are five ECC aggregators – one for each core and one for the corepac level. Debug domain is not safety critical.

No CBASS/Bridge interconnect safety is supported. Only RAM safety is supported.

The following A53SS ECC Aggregator instances are instantiated:

- A53SS0\_ECC\_AGGR0: ECC Aggregator for Arm A53 Cluster 0, Core 0
- A53SS0\_ECC\_AGGR1: ECC Aggregator for Arm A53 Cluster 0, Core 1
- A53SS0\_ECC\_AGGR2: ECC Aggregator for Arm A53 Cluster 0, Core 2
- A53SS0\_ECC\_AGGR3: ECC Aggregator for Arm A53 Cluster 0, Core 3
- A53SS0\_ECC\_AGGR\_COREPAC: ECC Aggregator for Arm A53 Cluster 0

#### **7.1.2.9.1 A53 ECC Aggregators During Low Power States**

- When a cpu core is in WFI/WFE, the corresponding core ECC Aggregator MMR regions is not accessible and will return error status.
- Similarly when L2 is in WFI, the corepac ECC Aggregator MMR region is not accessible and will return error status.

#### **7.1.2.9.2 Auto-initialization of Memories**

All A53 L1 and L2 memory initialization is handled by the Arm core. The TI ECC aggregator is used in inject-only mode and this cannot be used for initialization. The Arm CPU will initialize the cache memories after reset.

There are no other memories in the A53 subsystem beside the cache memories

#### **7.1.2.9.3 A53 SRAM Safety**

The Arm A53 Cluster natively supports ECC/parity protection on A53 SRAMs and error injection on few memories. The A53SS adds error injection capability on all internal SRAM. This is a valuable TI addition to the Arm native implementation.

**Table 7-3. A53 SRAM Safety Support**

| RAM             | A53 Error Injection Support | TI Error Injection Support        |
|-----------------|-----------------------------|-----------------------------------|
| L1 I-Cache Data | No                          | Single error injection            |
| L1 I-Cache Tag  | No                          | Single error injection            |
| L1 D-Cache Data | Double error injection      | Single and double error injection |
| L1 D-Cache Tag  | No                          | Single error injection            |
| L1 Data Dirty   | No                          | Single error injection            |

**Table 7-3. A53 SRAM Safety Support (continued)**

| RAM               | A53 Error Injection Support | TI Error Injection Support        |
|-------------------|-----------------------------|-----------------------------------|
| TLB RAM           | No                          | Single error injection            |
| SCU Duplicate Tag | No                          | Single and double error injection |
| L2 Tag RAM        | Double error injection      | Single and double error injection |
| L2 Data RAM       | Double error injection      | Single and double error injection |

The ECC Aggregator for the cores stimulates errors in the following RAMs:

- L1 I-Cache Data RAM
- L1 I-Cache Tag RAM
- L1 D-Cache Data RAM
- L1 D-Cache Tag RAM
- L1 D-Cache Dirty RAM
- TLB RAM
- L1 SCU L1-D Duplicate Tag RAM

The ECC Aggregator for the L2 cache stimulates errors in the following RAMs:

- L2 Data RAM
- L2 Tag RAM

#### 7.1.2.9.4 A53 SRAM ECC Aggregator Configurations

There are several schemas of memory protection employed inside of the processors. The tables below describe the schema and arrangement. This describes what bits are protected, how they are protected, the behavior when an error is detected and what bits can be disturbed for ECC testing purposes. This also lists the RAMID associated with each memory to the corresponding ECC Aggregator.

The key for the protection schemes is as follows:

- Parity – Parity Bit(s) to protect data
- ECC – Error Correction Code to protect Data
- SED – Single Error Detection
- SECDED – Single Error Correction, Double Error Detection
- SEDSEC – Single Error Detection, Single Error Correction

**Table 7-4. CPU Memories Safety Details**

| Memory          | Protection    | RAM Arrangement                                                                            | CPU<br>(Core<br>ECC<br>Aggr)<br>Rams<br>Ram ID | Notes                                                                                                                                                                                                                                 |
|-----------------|---------------|--------------------------------------------------------------------------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L1 I-Cache Data | Parity SED    | 41 – Parity for 40:21<br>40:21 – Instruction<br>20 – Parity for 19:0<br>19:0 – Instruction | 0-3                                            | Error detection results in both lines being invalidated then refetched from L2 or memory                                                                                                                                              |
| L1 I-Cache Tag  | Parity SED    | 31 – Parity for 30:0<br>30:0 – Data                                                        | 4-5                                            | Error detection results in both lines being invalidated, then line refetched from L2 or memory                                                                                                                                        |
| L1 D-cache Data | ECC<br>SECDED | 38:32 – ECC<br>31:0 – Data                                                                 | 6-13                                           | Error results in line being cleaned and invalidated from L1 with single bit errors corrected as part of eviction. Line refetched from L2 or memory                                                                                    |
| L1 D-Cache Tag  | Parity SED    | 30 – Parity for 29:0<br>29:0 – Tag                                                         | 14-17                                          | Cache sizes makes LSB unnecessary (always 0) so they are removed from the actual RAM. Error results in line cleaned and invalidated from L1. SCU duplicate tags are used to get the correct address. Line refetched from L2 or memory |

**Table 7-4. CPU Memories Safety Details (continued)**

| Memory                     | Protection       | RAM Arrangement                                                                                                                                                                                                                                                                        | CPU<br>(Core<br>ECC<br>Aggr)<br>Rams<br>Ram ID       | Notes                                                                                                                                                                                                     |
|----------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L1 D-cache<br>Dirty        | Parity<br>SEDSEC | 11:10 – Way 1/3 Dirty copy 2 and 1.<br>Parity for 4<br>9:8 – Way 0/2 Dirty copy 2 and 1.<br>Parity for 0<br>7 – Way 1/3 Outer Allocation Hint<br>6 – Way 1/3 Age<br>5:4 – Way 1/3 Partial MOESI<br>3 – Way 0/2 Outer Allocation Hint<br>2 – Way 0/2 Age<br>1:0 – Way 0/2 Partial MOESI | 18                                                   | Error results in line cleaned and invalidated from L1 with single bit errors corrected as part of the eviction. Only dirty bit is protected. Other bits are just performance hints                        |
| TLB                        | Parity SED       | 116 – parity for 113:62<br>115 – Parity for 61:31<br>114 – Parity for 30:0<br>113:62 – Page Attributes<br>61:31 – Entry Identifiers<br>30:0 – Address                                                                                                                                  | 19-22                                                | Error detection results in entry invalidated, new pagewalk to refetch.                                                                                                                                    |
| SCU L1<br>Duplicate<br>Tag | ECC<br>SECDED    | 37:31 - ECC for 30:0<br>30:0 - Duplicate Tag                                                                                                                                                                                                                                           | 23-26<br>(accessed<br>by each<br>Core's<br>ecc_aggr) | Cache sizes makes LSB unnecessary (always 0) so they are removed from the actual RAM.<br>Correttable Error – Tag rewritten with correct value, access retried<br>Uncorrectable Error – Tag is invalidated |

**Table 7-5. L2 Memories Safety Details**

| Memory              | Protection    | RAM<br>Arrangement                  | RAM_ID<br>(L2 Cache<br>RAMs) | Notes                                                                                                                                                                                                      |
|---------------------|---------------|-------------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L2 Tag              | ECC<br>SECDED | 37:31 – ECC for 30:0<br>30:0 - Tag  | 0-15                         | Cache sizes makes LSB unnecessary (always 0) so they are removed from the actual RAM.<br>Correttable Error – Tag rewritten with correct value, access retried.<br>Uncorrectable Error – Tag is invalidated |
| L2 Victim           | None          | –                                   | –                            | Performance Hint Only – Error has no functional impact                                                                                                                                                     |
| L2 Data             | ECC<br>SECDED | 71:64 – ECC for 63:0<br>63:0 – Data | 16-23                        | Error results in Data corrected inline, access may stall for 1-2 cycles.<br>After correction, line might be evicted                                                                                        |
| Branch<br>Predictor | None          | –                                   | –                            | Performance Hint Only – Error has no functional impact                                                                                                                                                     |

#### 7.1.2.10 A53SS Boot

For A53SS boot sequence and any other A53SS boot details, see *Control Module (CTRL\_MMR)*.

#### 7.1.2.11 A53SS Interprocessor Communication

The Arm A53 core(s) can communicate with other device cores (R5FSS, PRUSS PRU, DMSC M3) by supporting interrupt generation to and from these cores. The interprocessor communication (IPC) interrupts are assigned in the corresponding BOOTCFG0 memory-mapped registers (MMRs) called IPC\_SETx / IPC\_CLRx. For more information, see *Control Module (CTRL\_MMR)*.

## 7.2 Device Manager Cortex R5F Subsystem (WKUP\_R5FSS)

This chapter describes the Arm Cortex R5F real-time microcontroller unit subsystem (WKUP\_R5FSS) in the device.

### 7.2.1 WKUP\_R5FSS Overview

The WKUP\_R5FSS is a single-core implementation of the Arm® Cortex®-R5F processor that acts as the Device Manager responsible for boot, resource management, and power management functions. It also includes accompanying memories (L1 caches and tightly-coupled memories), standard Arm CoreSight™ debug and trace architecture, integrated vectored interrupt manager (VIM), ECC aggregators, and various other modules for protocol conversion and address translation for easy integration into the SoC.

---

#### Note

The Cortex-R5F processor is a Cortex-R5 processor that includes the optional floating point unit (FPU) extension. In this TRM, all references to the Cortex-R5 processor apply to the Cortex-R5F processor by default.

---

There is one WKUP\_R5FSS subsystem in the device. [Table 7-6](#) shows WKUP\_R5FSS allocation across device domains.

**Table 7-6. R5FSS Allocation Across Device Domains**

| Module Instance | Domain |      |      |
|-----------------|--------|------|------|
|                 | MCU    | MAIN | WKUP |
| WKUP_R5FSS      | –      | –    | ✓    |

#### 7.2.1.1 WKUP\_R5FSS Features

The WKUP\_R5FSS supports the following features:

- Single-core Arm Cortex-R5F
  - Core revision: r1p3
  - Armv7-R profile
  - L1 memory system
    - 32KB instruction cache
      - 4x8KB ways
      - SECDED ECC protected per 64 bits
    - 32KB data cache
      - 4x8KB ways
      - SECDED ECC protected per 32 bits
    - 64KB tightly-coupled memory (TCM)
      - SECDED ECC protected per 32 bits
      - TCM hard error cache Implemented in CPU
      - Readable/writable from system
      - TCMs initialized (to 0's) at reset
      - Split into A and B banks (with B further splitting into B0 and B1 interleaved banks)
        - 32KB TCMA (ATCM)
        - 16KB TCMB0 (B0TCM)
        - 16KB TCMB1 (B1TCM)
  - Low interrupt latency with restartable instructions
  - Non-maskable interrupt (NMI)
  - Full-precision floating point (VFPv3)
  - 16 region memory protection unit (MPU)
  - 8 breakpoints

- 8 watchpoints
- Dynamic branch prediction with global history buffer and 4-entry return stack
- CoreSight debug access port (DAP)
- CoreSight embedded trace macrocell (ETM-R5) interface
- Performance monitoring unit (PMU)
- Interfaces
  - 64-bit VBUSM initiator pair (1 read, 1 write) for L3 memory accesses
  - 64-bit VBUSM target for TCM access
    - Also allows access to cache for debug purposes
  - 32-bit VBUSP initiator for peripheral access
  - 32-bit VBUSP target configuration port
  - 32-bit VBUSP target debug port
    - Allows access to all WKUP\_R5FSS internal debug logic
  - ECC/Parity support on all internal SoC bus interfaces
  - ECC/Parity support on internal SoC bus bridges
- Synchronous clock domain crossing on all interfaces
  - Interfaces can run at an integer multiple of the core frequency
- 32-bit to 36-bit region-based address translation (RAT) on memory access initiators
  - 4 regions
    - Base address + size
    - Must be size aligned
- Integrated vectored interrupt manager (VIM)
  - 256 interrupts
    - Each interrupt programmable as either IRQ or FIQ
    - Each interrupt has a programmable enable mask
    - Each interrupt has a programmable 4-bit priority
  - Priority interrupt supported
  - Vectored interrupt interface
    - Compatible with R5F VIC port
    - Programmable 32-bit vector address per interrupt
      - Address is SECDED error protected
      - Default vector addresses provided on DED
    - Software interrupt generation
- Integrated ECC aggregators
  - Support for error injection to all supported ECC memory blocks to test ECC functionality (add-on function from TI)
  - One ECC aggregator to cover all RAMs and caches
- Standard Arm CoreSight debug and trace architecture at the R5FSS level
  - Cross triggering: Supported by cross trigger interface (CTI) (per CPU) and cross trigger matrix (CTM) components
  - Processor trace: Supported by embedded trace macrocell (ETM) (per CPU) and advanced trace bus (ATB) funnel components
- Boot
  - From ROM only

See [Section 7.2.2](#) for a functional block diagram and more details on the WKUP\_R5FSS.

---

**Note**

Some features may not be available. See [Module Integration](#) for more information.

---

## 7.2.2 WKUP\_R5FSS Functional Description

### 7.2.2.1 WKUP\_R5FSS Block Diagram

Figure 7-2 shows the WKUP\_R5FSS block diagram.



Figure 7-2. WKUP\_R5FSS Block Diagram

### 7.2.2.2 WKUP\_R5FSS Cortex-R5F Core

The Cortex-R5F is a processor from Arm, which is based on the Armv7-R profile.

For a brief list of features supported by the R5F processor in this device, see [Section 7.2.1.1](#). For more detailed description of this processor, see the *Arm Cortex-R5 Technical Reference Manual*.

#### 7.2.2.2.1 L1 Caches

The R5F has a Harvard cache architecture, which means it has an independent L1 instruction cache (16KB) and L1 data cache (16KB). The instruction cache is protected by SECDED ECC per 64 bits. The data cache is protected by SECDED ECC per 32 bits.

#### 7.2.2.2.2 Tightly-Coupled Memories (TCMs)

The R5F has two tightly-coupled memories (TCMs), ATCM and BTM. The BTM is further broken down into two interleaved banks, B0TCM and B1TCM.

TCMs are low-latency, tightly integrated memories for the R5F to use. Either TCM can be used for any combination of instruction and/or data. TCM performance is equal to performance on instructions/data that are in cache. However, TCMs have some additional advantages over cache. TCMs can be loaded with instructions

that do not cache well (such as ISRs) or preloaded with code by an external source, before that code is needed, to save cache miss time. TCMs are also a good place for blocks of data for intense processing. They can be loaded (or pre-loaded by an external source) before the data is needed, saving cache miss time. The data can then be directly accessed by an external source, instead of needing to do cache evicts.

As mentioned, TCMs can be accessed (either read or written) by an external source over the TCM VBUSM target interface. This allows instructions or data to be preloaded, or for data to be read out after the R5F has processed it. The VBUSM target has a lower priority to accessing TCMs than the R5F but care must be taken to keep an external source from reading or writing TCM data that the R5F is working on. This handshaking is external to any of the R5FSS hardware.

TCMs are protected by ECC per 32 bits. For this to work, ECC must be enabled before data is written in to the TCMs (either externally or from the R5F). ECC is enabled via the following R5F system control bits: ACTLR.ATCMPCEN, ACTLR.B0TCMPCEN, and ACTLR.B1TCMPCEN, respectively.

Whether or not the TCMs are enabled is controlled by the ENABLE bit in the corresponding ATCM/BTCM region register. The default (reset) value of this bit is determined by the CPUn\_INITRAMA and CPUn\_INITRAMB bootstraps, respectively. Both ATCM and BTCM are configured for a size of 32KB in this device. Note that the BTCM size is the total of both B0TCM and B1TCM (16KB each).

If a TCM is not enabled, then it does not appear in the R5F's memory view, but it can be accessed by an external source. If a TCM is enabled, then its place in the R5F memory map is determined by a combination of bootstrap signal and system register. If the CPUn\_LOCZRAMA bootstrap signal is high, then the initial base address of ATCM is 0x0000\_0000 and the initial address of BTCM is 20'h41010. If the CPUn\_LOCZRAMA bootstrap signal is low, then the initial base address of BTCM is 0x0000\_0000 and the initial base address of ATCM is 20'h41010.

---

#### Note

This base address of 0x41010 for ATCM/BTCM based on the CPUn\_LOCZRAMA bootstrap only affects the R5F's memory view. The SoC will see the ATCM/BTCM based on the TCM target interface regions, as defined in [Section 7.2.2.3.2](#). The base address of either TCM may be overwritten via the ATCM or BTCM region register. Care must be taken not to move the base address of a TCM when it may be being accessed.

It is possible to preload a TCM with instructions and boot from it. See [Section 7.2.2.11](#) for details on TCM booting.

#### 7.2.2.2.3 WKUP\_R5FSS Special Signals

[Table 7-7](#) lists some WKUP\_R5FSS features associated with special signals.

**Table 7-7. WKUP\_R5FSS Special Features**

| Feature                                                   | Comment                                                                                              |
|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| Cluster affinity group ID                                 | R5F Cluster 0 (ID = 0x0)                                                                             |
| Exception handling state at reset<br>0 = Arm<br>1 = Thumb | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to Arm mode                                |
| CPUn execution halt when coming out of reset (CPUn_HALT)  | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to halted state                            |
| CPUn exception vectors base address                       | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to Bootvector RAM address 0x0000_0000_0200 |
| CPUn VIM base address                                     | 0x2FFF_0000                                                                                          |
| CPUn RAT base address                                     | 0x2FFE_0000                                                                                          |
| CPUn RAT accesses ID                                      | 0x4 (CPU0)                                                                                           |
| CPUn ATCM enable at reset (CPUn_INITRAMA)                 | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to disabled state                          |

**Table 7-7. WKUP\_R5FSS Special Features (continued)**

| Feature                                                                                                           | Comment                                                                     |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| CPU <sub>n</sub> BTCM enable at reset (CPU <sub>n</sub> _INITRAMB)                                                | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to enabled state  |
| CPU <sub>n</sub> A/BTCM reset base address indicator (CPU <sub>n</sub> _LOCZRAMA)<br>0 = B at 0x0<br>1 = A at 0x0 | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to 1              |
| CPU <sub>n</sub> non-maskable fast interrupts enable                                                              | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to disabled state |
| CPU <sub>n</sub> VBUSM peripheral port enabled at reset                                                           | Enabled                                                                     |
| CPU <sub>n</sub> VBUSP peripheral port enable at reset                                                            | Enabled                                                                     |
| CPU <sub>n</sub> VBUSP peripheral port base address                                                               | Mapped to 0x0_2000_0000 for low latency MAIN peripherals                    |
| CPU <sub>n</sub> VBUSP peripheral port size                                                                       | 64MB for MAIN peripherals (0x0_2000_0000 to 0x0_2FFF_FFFF)                  |
| CPU <sub>n</sub> VBUSM normal peripheral port base address                                                        | Not used                                                                    |
| CPU <sub>n</sub> VBUSM normal peripheral port size                                                                | Not used                                                                    |
| CPU <sub>n</sub> VBUSM virtual peripheral port base address                                                       | Not used                                                                    |
| CPU <sub>n</sub> VBUSM virtual peripheral port size                                                               | Not used                                                                    |
| CPU <sub>n</sub> clock stopped indication                                                                         | Status logged into MAIN_SEC_MMR register bit                                |
| CPU <sub>n</sub> WFI state                                                                                        | Status logged into MAIN_SEC_MMR register bit                                |
| CPU <sub>n</sub> WFE state                                                                                        | Status logged into MAIN_SEC_MMR register bit                                |
| CPU clockstop behavior<br>0: CPU clocks stopped in standby<br>1: CPU clocks not stopped in standby                | Controlled via MAIN_SEC_MMR register setting.<br>Defaults to 0              |

### 7.2.2.3 WKUP\_R5FSS Interfaces

#### 7.2.2.3.1 Initiator Interfaces

The WKUP\_R5FSS has several initiator interfaces:

- 64-bit VBUSM initiator pair (1 read, 1 write) for L3 memory accesses; this is the main memory interface
  - Includes region-based address translation (RAT)
- 32-bit VBUSP initiator for peripheral access
  - Includes logic that provides the R5F CPU with a private access to VIM and RAT
  - Enabled at reset

#### 7.2.2.3.2 Target Interfaces

The WKUP\_R5FSS has several target interfaces that define its internal memory space:

- 32-bit VBUSP configuration target
  - Region [0]: ECC aggregator block
- 64-bit TCM target
  - Region [0]: ATCM
  - Region [1]: BTM
  - Region [2]: Instruction cache RAMs
  - Region [3]: Data cache RAMs
- 32-bit VBUSP debug target
  - Provides access to all R5FSS internal debug logic

Regions [0] and [1] of the TCM target interface provide direct access to the TCM RAMs. Access to the RAMs is arbitrated with access from the R5F's L1 memory system. Excessive access while the R5F is also attempting access will degrade performance.

Regions [2] and [3] of the TCM target interface provide access to the cache RAMs for testing purposes. Access to the cache RAMs can only be done while the caches are disabled and should only be done for test purposes.

In addition to the target interfaces, there are peripherals (RAT and VIM) that are only accessible by the R5F. The R5F has an access to these modules via the VBUSP peripheral interface.

#### 7.2.2.4 WKUP\_R5FSS Power, Clocking and Reset

##### 7.2.2.4.1 WKUP\_R5FSS Power

The following WKUP\_R5FSS power considerations should be noted:

- WKUP\_R5FSS has a single power domain for all its internal logic

For more details on WKUP\_R5FSS power management, including power-up and power-down sequences, see *Power*.

##### 7.2.2.4.2 WKUP\_R5FSS Clocking

The WKUP\_R5FSS has four clock inputs:

- CPU0\_CLK: This is the clock for CPU0 logic
- CPU0\_ICLK: This is the clock for CPU0 interfaces

CPU0\_CLK is the clock for all of the internal CPU logic, while CPU0\_ICLK is the clock for all of the interfaces for their associated CPU (for example: VBUSM and VBUSP bridges, exception generation, debug and trace logic).

The interface clock is an integer ratio of the CPU clock. The exact ratio for this device is 1:1.

##### 7.2.2.4.3 WKUP\_R5FSS Reset

The R5FSS has two reset inputs:

- CPU0\_RST: This is the reset for the non-debug logic of CPU0
- CPU0\_DBG\_RST: This resets the CPU0 debug logic, excluding the APB interface

In addition to the reset signals, there is one halt signal:

- CPU0\_HALT

These halt signals keep the CPUs from fetching instructions when they come out of reset. The main use is to have the CPUs halted until the TCMS are loaded (when booting from TCM), though halt could be used for any other purpose.

#### 7.2.2.5 WKUP\_R5FSS Vectored Interrupt Manager (VIM)

##### 7.2.2.5.1 VIM Overview

The VIM aggregates device interrupts and sends them to the R5F CPU. It can be used in either split or single-core configuration.

The VIM module supports the following features:

- 256 interrupt inputs for the R5F core
- Each interrupt has its own 4-bit programmable priority
  - Defined via the R5FSS\_VIM\_PRI\_INT\_j register
  - The VIM provides support for priority interruption of interrupts
- Each interrupt has its own enable mask
  - Interrupt enable is done via the R5FSS\_VIM\_INTR\_EN\_SET\_j register
  - Interrupt disable is done via the R5FSS\_VIM\_INTR\_EN\_CLR\_j register
- Each interrupt can be programmed as either an IRQ or FIQ
  - Defined via the R5FSS\_VIM\_INTMAP\_j register
- Each interrupt has its own programmable 32-bit vector address associated with it
  - Defined via the R5FSS\_VIM\_VEC\_INT\_j register
  - Protected with SECDED
- One IRQn and one FIQn output per core
- Vectored interrupt interface
  - Compatible with R5F VIC port

- Default vector provided when a double-bit error is detected
  - Software interrupt generation

### 7.2.2.5.2 VIM Interrupt Inputs

The VIM supports 256 interrupt inputs per core. Each interrupt can be either a level or a pulse (both active-high). The interrupt mapping for the R5F core can be found in *Interrupt Sources*.

### 7.2.2.5.3 VIM Interrupt Outputs

The VIM has two interrupt outputs per core:

- **CoreN\_IRQn**: This is a normal interrupt for core  $N$  (active-low level). It can be serviced via the VIC interface or through the MMR interface. Whenever an interrupt input goes high, if that interrupt is mapped as an IRQ (via the `R5FSS_VIM_INTMAP_j` register) and is enabled (via the `R5FSS_VIM_INTR_EN_SET_j` register), then it will cause an IRQ to assert
  - **CoreN\_FIQn**: This is a fast (or non-maskable) interrupt for core  $N$  (active-low level). FIQs always have priority over IRQs. An FIQ can be serviced through the MMR interface. Whenever an interrupt input goes high, if that interrupt is mapped as an FIQ and is enabled, then it will cause an FIQ to assert

#### 7.2.2.5.4 VIM Interrupt Vector Table (VIM RAM)

For each VIM interrupt core, there is an associated interrupt vector table (VIM RAM) that is used to store the address of ISRs. During register vectored interrupt and hardware vectored interrupt, VIM accesses the interrupt vector table using the vector value to fetch the address of the corresponding ISR. Note that both interrupt vector tables are identical in their memory organization.

The VIM RAM is basically comprised of a set of interrupt vector registers (R5FSS\_VIM\_VEC\_INT\_j). Hence, the interrupt vector table is organized in 256 words of 30 bits, with a base address corresponding to the physical address of the first register in the group.

## Note

The lower two bits of the 32-bit interrupt vector are always 0s.

Figure 7-3 shows the VIM RAM interrupt vector map.



**Figure 7-3. VIM RAM Interrupt Vector Map**

The interrupt vector table has protection by ECC to indicate corruption due to soft errors. The ECC logic inside VIM supports SECDED. See [Table 7-10](#) for the VIM RAM ID in the ECC aggregator map.

#### 7.2.2.5.5 VIM Interrupt Prioritization

The VIM supports the interruption of the currently active interrupt by one with a higher priority. FIQs and IRQs are completely separate but both use the same mechanism.

When an interrupt goes from pending to active (FIQ: reading the R5FSS\_VIM\_FIQVEC register; IRQ: reading the R5FSS\_VIM\_IRQVEC register, or the *coreN IRQACK* going high), then the interrupt is loaded into the corresponding active register (R5FSS\_VIM\_ACTFIQ / R5FSS\_VIM\_ACTIRQ), and all interrupts of an equal or lesser priority are masked (discarded). If prior to this interrupt being cleared (by writing to the R5FSS\_VIM\_FIQVEC register, or R5FSS\_VIM\_IRQVEC register) another interrupt of higher priority arrives, then the FIQn/IRQn will be asserted and that interrupt made pending as normal. If the CPU switches this interrupt to active (by reading the R5FSS\_VIM\_FIQVEC / R5FSS\_VIM\_IRQVEC register), then the currently active interrupt will be pushed onto a stack. When an interrupt is cleared by reading the R5FSS\_VIM\_FIQVEC / R5FSS\_VIM\_IRQVEC register, if there are any interrupts on the stack, the first entry is popped off and put back into the R5FSS\_VIM\_ACTFIQ / R5FSS\_VIM\_ACTIRQ register, so that software may continue where it left off.

#### 7.2.2.5.6 VIM ECC Support

The memory that holds the interrupt vector for each interrupt is protected by SECDED ECC. Single-bit errors are corrected and written back. Double-bit errors are not corrected. If a double-bit error occurs while trying to load a vector, then the R5FSS\_VIM\_DEDVEC register is used to provide the default vector for the *coreN IRQADDRV* signal, the R5FSS\_VIM\_IRQVEC register, and the R5FSS\_VIM\_FIQVEC register. The R5FSS\_VIM\_DEDVEC should point to an ISR that handles the fact that there was an uncorrectable error in the interrupt handling.

Some possible remediating actions would be to:

1. Reconstruct the vector table and re-start the application
  - a. Potentially switch to a completely software interrupt handler in the mean time
2. Restart the application from scratch
3. Reset the device
4. Sit in a loop (or WFI) while something external (for example, the ESM) responds to the DED interrupt that will be generated

It is up to the user and the application to determine the appropriate action.

---

#### Note

An interrupt that has an uncorrectable vector error (and thus uses the DED vector) will still have the priority of the original interrupt. This makes it possible for a higher priority interrupt to supercede the handling of the error.

Control and reporting are done by the R5FSS ECC aggregator.

---

#### 7.2.2.5.7 VIM IDLE State

The VIM will indicate IDLE when there are no pending unmasked interrupts or MMR accesses. The VIM does not have a clock stop interface.

#### 7.2.2.5.8 VIM Interrupt Handling

There are multiple ways to service an interrupt depending on how much of the hardware assistance offered by the VIM the software wants to take advantage of.

For IRQs, it is recommended to use the procedure in [Section 7.2.2.5.8.1](#), but the procedures in [Section 7.2.2.5.8.2](#) or [Section 7.2.2.5.8.3](#) (if a user wants to implement a fully software prioritization scheme) may be used as alternatives.

For FIQs, it is recommended to use the procedure in [Section 7.2.2.5.8.4](#), but the procedure in [Section 7.2.2.5.8.5](#) may be used as an alternative.

---

**Note**

These descriptions do not include steps such as stack pushes and state retention that software must take in order to return from the ISR. It is assumed that the programmer is aware of these steps.

---

#### 7.2.2.5.8.1 Servicing IRQ Through Vector Interface

If the associated CPU has the vector (VIC) interface enabled, then the following method is used for servicing IRQs:

1. Hardware handshake
  - a. CPU asserts *coreN\_IRQACK* high
  - b. VIM asserts *coreN\_IRQADDRV* to indicate that the *coreN\_IRQADDR* bus is stable with the correct vector address
  - c. CPU reads *coreN\_IRQADDR*, jumps to that address, and de-asserts *coreN\_IRQACK* low
  - d. VIM de-asserts *coreN IRQn* and *coreN\_IRQADDRV*, VIM masks (discards) all IRQs with the same or lower priority
  - e. VIM loads the value from the R5FSS\_VIM\_PRIIRQ[9:0] NUM bit field (which corresponds to the vector address) into the R5FSS\_VIM\_ACTIRQ[9:0] NUM bit field, which causes the R5FSS\_VIM\_ACTIRQ[31] VALID bit to be set
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level (determined by reading the R5FSS\_VIM\_ACTIRQ[9:0] NUM bit field to determine number, and reading the appropriate bit in the R5FSS\_VIM\_INTTYPE\_j register to determine type)
  - a. Pulse
    - i. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_IRQSTS\_j register, or R5FSS\_VIM\_STS\_j register
    - ii. Clear the interrupt at the source. This way, the source can generate another pulse, if it needs to, and the VIM will process this as a new interrupt
  - b. Level
    - i. Clear the interrupt at the source
    - ii. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_IRQSTS\_j register, or R5FSS\_VIM\_STS\_j register. This way, the level should be gone at the input to the VIM, it will avoid falsely re-calling the interrupt. If the source maintains the level, then it means there is another interrupt
4. Write any value to the R5FSS\_VIM\_IRQVEC register
  - a. This will clear the priority mask and will cause all interrupts to be re-evaluated for the new highest priority interrupt
  - b. This will also clear the R5FSS\_VIM\_ACTIRQ[31] VALID bit

#### 7.2.2.5.8.2 Servicing IRQ Through MMR Interface

When an IRQ interrupt is received, the CPU should follow these steps if not using the vector interface:

1. Read the R5FSS\_VIM\_IRQVEC register and jump to that address to service the ISR
  - a. Reading this register will mask (discard) all interrupts of an equal or lower priority and de-assert the *coreN IRQn* output. If another interrupt of a higher priority becomes available, the *coreN IRQn* will re-assert, allowing priority interruption of an interrupt
  - b. Reading this register will cause the value from the R5FSS\_VIM\_PRIIRQ[9:0] NUM bit field to be loaded into the R5FSS\_VIM\_ACTIRQ[9:0] NUM bit field, and the R5FSS\_VIM\_ACTIRQ[31] VALID bit to be set
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level
  - a. Pulse

- i. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_IRQSTS\_j register
- ii. Clear the interrupt at the source
- b. Level
  - i. Clear the interrupt at the source
  - ii. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_IRQSTS\_j register
4. Write any value to the R5FSS\_VIM\_IRQVEC register
  - a. This will clear the priority mask and will cause all interrupts to be re-evaluated for the new highest priority interrupt
  - b. This will also clear the R5FSS\_VIM\_ACTIRQ[31] VALID bit

#### **7.2.2.5.8.3 Servicing IRQ Through MMR Interface (Alternative)**

If a user does not want to use the R5FSS\_VIM\_IRQVEC register, the VIM may be used as a more traditional interrupt controller. Note that in this mode, there is no hardware priority masking (because the R5FSS\_VIM\_IRQVEC register is never read). Software would be responsible for doing all priority operations.

1. Determine which interrupt to service
  - a. Read the R5FSS\_VIM\_PRIIRQ register to determine which interrupt is the highest priority IRQ currently asserted, OR
  - b. Optionally read the R5FSS\_VIM\_IRQGSTS register to determine which groups have IRQs pending, then read the R5FSS\_VIM\_IRQSTS\_j register and use a software prioritization scheme to determine which IRQ to service
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level
  - a. Pulse
    - i. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_IRQSTS\_j register
    - ii. Clear the interrupt at the source.
  - b. Level
    - i. Clear the interrupt at the source
    - ii. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_IRQSTS\_j register

#### **7.2.2.5.8.4 Servicing FIQ**

When an FIQ interrupt is received, the CPU should follow these steps:

1. Read the R5FSS\_VIM\_FIQVEC register and jump to that address to service the ISR
  - a. Reading this register will mask (discard) all interrupts of an equal or lower priority and de-assert the *coreN\_FIQn* output. If another interrupt of a higher priority becomes available, the *coreN\_FIQn* will re-assert, allowing priority interruption of an interrupt.
  - b. Reading this register will cause the value from the R5FSS\_VIM\_PRIFIQ[9:0] NUM bit field to be loaded into the R5FSS\_VIM\_ACTFIQ[9:0] NUM bit field, and the R5FSS\_VIM\_ACTFIQ[31] VALID bit to be set
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level (determined by reading the R5FSS\_VIM\_ACTFIQ[9:0] NUM bit field to determine number, and reading the appropriate bit in the R5FSS\_VIM\_INNTYPE\_j register to determine type)
  - a. Pulse
    - i. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_FIQSTS\_j register
    - ii. Clear the interrupt at the source. This way, the source can generate another pulse, if it needs to, and the VIM will process this as a new interrupt
  - b. Level
    - i. Clear the interrupt at the source

- ii. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_FIQSTS\_j register. This way, the level should be gone at the input to the VIM, it will avoid falsely re-calling the interrupt. If the source maintains the level, then it means there is another interrupt
- 4. Write any value to the R5FSS\_VIM\_FIQVEC register
  - a. This will clear the priority mask and will cause all interrupts to be re-evaluated for the new highest priority interrupt
  - b. This will also clear the R5FSS\_VIM\_ACTFIQ[31] VALID bit

#### 7.2.2.5.8.5 Servicing FIQ (Alternative)

If a user does not want to use the R5FSS\_VIM\_FIQVEC register, the VIM may be used as a more traditional interrupt controller. Note that in this mode, there is no hardware priority masking (because the R5FSS\_VIM\_FIQVEC register is never read). Software would be responsible for doing all priority operations.

1. Determine which interrupt to service
  - a. Read the R5FSS\_VIM\_FIQVEC register to determine which interrupt is the highest priority FIQ currently asserted, OR
  - b. Optionally read the R5FSS\_VIM\_FIQGSTS register to determine which groups have IRQs pending, then read the R5FSS\_VIM\_FIQSTS\_j register and use a software prioritization scheme to determine which FIQ to service
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level
  - a. Pulse
    - i. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_FIQSTS\_j register
    - ii. Clear the interrupt at the source.
  - b. Level
    - i. Clear the interrupt at the source
    - ii. Clear the status by writing a '1' to the appropriate bit in the R5FSS\_VIM\_STS\_j register, or R5FSS\_VIM\_FIQSTS\_j register.

#### 7.2.2.6 WKUP\_R5FSS Region Address Translation (RAT)

##### 7.2.2.6.1 WKUP R5FSS Usage

R5 is a micro controller with 32b address, which is only able to access up to 4GB address space. However, Sitara SoC supports 36b address and majority of the memory region beyond lower 4GB are implemented. Region based address translation block, called RAT, is introduced to allow R5 core to access full 36b SoC memory map.

Each R5 core has its own RAT block, and only R5 core itself is able to program the RAT.

Figure 7-4 shows the main R5's default 32b memory map view when main R5 is out of reset.

The full RAT functionality is described in [Section 7.2.2.6.2, RAT Function](#).



**Figure 7-4. R5 Core Default Memory Map View**



Figure 7-5. Typical Sitara SoC Memory Map View

RAT block enables R5 core to have full access on the SoC memory map including the memory region at and above 0x1\_0000\_0000.

Figure 7-6 shows how R5 access various end points, including its own ATCM, BTM, VIM and SoC memory and peripherals. R5's ATCM is by default at address 0x0, and its BTM is at address 0x4101\_0000. R5 uses address 0x2FFF\_0000 to access its VIM and 0x2FFE\_0000 to access the RAT configuration region and all the other transactions between address range 0x2000\_0000 to 0x2FFF\_FFFF are sent to the 32b peripheral interface to access the peripherals in SoC. The transactions with the rest of address are sent to RAT block, which could go through address remapping function from original R5's 32b address to 36b SoC address.



**Figure 7-6. R5 Internal Address Decoding**

#### 7.2.2.6.2 RAT Function

RAT block is responsible to do a region based address translation. For each region, user can define the starting address and size of the region and remapping the transactions to use a new address range.

The starting address and region size need to be aligned. For example, if the region size is 16KB, the starting address for that region needs to be 16KB aligned. And region size should be minimum 4KB or larger to avoid transactions cross the region boundaries.

Each RAT block supports multiple programmable regions. And it is important that those regions are not overlapping with each other.

RAT block is by default disabled, which means RAT block does not do address remapping. The 32b address coming from R5 core is directly sent out to the SoC level. The user can program each RAT remapping region individually. For the transactions does not hit any remapping region, RAT block just simply forwards the transactions to the SoC level with its original address.

#### 7.2.2.6.3 How to use RAT Block in R5

Table 7-8 shows the default R5 memory map view. Without enabling RAT function, all the regions beyond 4GB address space will not be accessible by R5.

Sitara SoC memory map is constructed the way to allow R5 and high level application processor such as A53 have similar memory map as possible. This methodology enables that R5 and ARM A53 core have a common memory map for all the SoC level memories and SoC level peripherals except a few exceptions:

- DDR's data space beyond 32b address, basically upper DDR data space beyond 2GB
- PCIe data space beyond 32b address
- OSPI data space beyond 32b address
- Debug configuration region

**Table 7-8. R5 Memory map by Default**

|                                       | <b>R5 Memory Map(32b)</b>                             | <b>SoC Memory Map (36b)</b>                |
|---------------------------------------|-------------------------------------------------------|--------------------------------------------|
| SoC Level peripheral and on-chip SRAM | 0x0 to 0x7FFF_FFFF<br>Same address as SoC memory map  | 0x0 to 0x7FFF_FFFF                         |
| 2GB DDR region                        | Same as SoC memory map:<br>0x8000_0000 to 0xFFFF_FFFF | 0x80000_0000 to 0xFFFF_FFFF                |
| Additional DDR region                 | Not accessible                                        | 0x8_8000_0000 (30GB)                       |
| Additional 8GB OSP Space              | Not accessible                                        | 0x4_0000_0000 (4GB)<br>0x5_0000_0000 (4GB) |
| Additional PCIe data space            | Not accessible                                        | 0x6_000_0000                               |
| Debug configuration region            | Not accessible                                        | 0x7_0000_0000                              |

Even though all the transactions other than going to ATCM/BTCM and transactions between address range 0x2000\_0000 to 0x2FFF\_FFFF could use RAT block to remap to different address, it is recommended that only use RAT block to remap the R5 transactions with address between 0x8000\_0000 to 0xFFFF\_FFFF.

- Any transactions from R5 with address between 0x0 to 0x7FFF\_FFFF are sent out to SoC directly (unless it is targeted to its internal end points such as A/B TCM, its VIM and RAT configuration)
- Only enable RAT to remap the transactions with address between 0x8000\_0000 to 0xFFFF\_FFFF if R5 needs to access the following address space:
  - PCIe data space at address 0x6\_0000\_0000
  - OSPI data space address 0x4\_0000\_0000 and 0x5\_0000\_0000
  - Debug configuration region at address 0x7\_0000\_0000
  - DDR data space at address 0x8\_8000\_0000



**Figure 7-7. Example of Using RAT to Access Full 36b SoC Memory Map**

#### 7.2.2.6.4 Example of Using RAT to Access Full 36b SoC Memory Map

This section shows an example on how to utilize RAT block to allow R5 to access 36 SoC Memory Map. The RAT block inside R5 has up to 8 address remapping regions.

Assuming R5 needs to access the following region:

- All the SoC level on-chip SRAM
- All the SoC level peripherals
- Access 512MB OSPI region at address 0x4\_0000\_0000
- Access 1GB DDR region at address 0x9\_0000\_0000
- Access 512MB DDR region at address 0x8000\_0000

First of all, we need to construct 32b R5 memory map as following and how those memory spaces are mapped to SoC level, shown in [Table 7-9](#). Users can define where the OSPI and DDR data space placed inside R5's memory map and how they should be mapped to SoC level address map. [Table 7-9](#) just shows one of the many possible ways to construct the memory map.

**Table 7-9. Example of R5 Address Mapping**

|                                                                                                                       | R5 Memory Map(32b)                                   | SoC Memory Map (36b)           | RAT Remapping                |
|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------|------------------------------|
| SoC Level peripheral and on-chip SRAM<br>(This is guaranteed by SoC Hardware design. No user configuration is needed) | 0x0 to 0x7FFF_FFFF<br>Same address as SoC memory map | 0x0 to 0x7FFF_FFFF             | Not RAT Remapping            |
| 512MB OSPI data region (user defined)                                                                                 | 0x8000_0000 to 0x9FFF_FFFF                           | 0x4_0000_0000 to 0x4_1FFF_FFFF | Using RAT remapping region 0 |
| 512MB DDR space (user defined)                                                                                        | 0xA000_0000 to 0xBFFF_FFFF                           | 0x8000_0000 to 0x9FFF_FFFF     | Using RAT remapping region 1 |
| Additional 1GB DDR Space (user defined)                                                                               | 0xC000_0000 to 0xFFFF_FFFF                           | 0x9_0000_0000 to 0x9_3FFF_FFFF | Using RAT remapping region 2 |

In this example, only three RAT regions are needed:

- Region 0 is used to remap R5's address between 0x8000\_0000 to 0x9FFF\_FFFF to SoC level address 0x4\_0000\_0000 to 0x4\_1FFF\_FFFF
- Region 1 is used to remap R5's address between 0xA000\_0000 to 0xBFFF\_FFFF to 0x8000\_0000 to 0x9FFF\_FFFF
- Region 2 is used to remap R5's address 0xc000\_0000 to 0xFFFF\_FFFF to 0x9\_0000\_0000 to 0x9\_3FFF\_FFFF.

In order achieving those mappings, those are the setting of the RAT configuration registers:

|                                      | Region 0                   | Region 1                   | Region 2                 | Other regions |
|--------------------------------------|----------------------------|----------------------------|--------------------------|---------------|
| Region control register              | Enabled, size set to 512MB | Enabled, size set to 512MB | Enabled, size set to 1GB | disabled      |
| Region base(32b)                     | 0x8000_0000                | 0xA000_0000                | 0xc000_0000              | Don't care    |
| Region translated lower address(32b) | 0x0000_0000                | 0x8000_0000                | 0x0000_0000              | Don't care    |
| Region translated upper address      | 0x4                        | 0x0                        | 0x9                      | Don't care    |

[Figure 7-8](#) shows how RAT is remapping the address between R5's 32b address to 36b SoC address.


**Figure 7-8. RAT Configuration Example**

### 7.2.2.7 WKUP\_R5FSS ECC Support

The R5F provides native ECC and parity support on all related memories, generating and checking the redundancy automatically. The R5F can also monitor any ECC errors on its SoC buses and bridges through the ECC aggregator. The methods for checking and reporting errors are available in the *Arm Cortex-R5 Technical Reference Manual*.

The R5FSS adds the capability of testing this logic by allowing errors (single and double bit) to be injected into memories (for testing purposes) via an ECC aggregator (per core). Note that because the R5FSS ECC aggregator is only used in error-injection mode, it only supports a subset of the generic ECC aggregator functionality in the device.

For a detailed description of the generic ECC aggregator functionality, see *ECC Aggregator*. For register descriptions of the WKUP\_R5FSS aggregators, see R5FSS\_CPU0\_ECC\_AGGR\_CFG\_REGS Registers and R5FSS\_CPU1\_ECC\_AGGR\_CFG\_REGS Registers, respectively.

Table 7-10 provides the RAM ID. This is needed for bit field [10-0] ECC\_VECTOR in the corresponding R5FSS\_CPU0\_VECTORR5FSS\_CPU0\_VECTOR register (part of the ECC aggregator register space).

**Table 7-10. RAM ID Map for ECC Aggregator (Per Core)**

| RAM ID | Memory Name      |
|--------|------------------|
| 0      | CPU0 ITAG RAM0   |
| 1      | CPU0 ITAG RAM1   |
| 2      | CPU0 ITAG RAM2   |
| 3      | CPU0 ITAG RAM3   |
| 4      | CPU0 IDATA BANK0 |
| 5      | CPU0 IDATA BANK1 |
| 6      | CPU0 IDATA BANK2 |
| 7      | CPU0 IDATA BANK3 |
| 8      | CPU0 DTAG RAM0   |
| 9      | CPU0 DTAG RAM1   |
| 10     | CPU0 DTAG RAM2   |
| 11     | CPU0 DTAG RAM3   |
| 12     | CPU0 DDIRTY RAM  |
| 13     | CPU0 DDATA RAM0  |
| 14     | CPU0 DDATA RAM1  |
| 15     | CPU0 DDATA RAM2  |
| 16     | CPU0 DDATA RAM3  |
| 17     | CPU0 DDATA RAM4  |
| 18     | CPU0 DDATA RAM5  |
| 19     | CPU0 DDATA RAM6  |
| 20     | CPU0 DDATA RAM7  |
| 21     | CPU0 ATCM BANK0  |
| 22     | CPU0 ATCM BANK1  |
| 23     | CPU0 B0TCM BANK0 |
| 24     | CPU0 B0TCM BANK1 |
| 25     | CPU0 B1TCM BANK0 |
| 26     | CPU0 B1TCM BANK1 |
| 27     | CPU0 VIM RAM     |

### 7.2.2.8 WKUP\_R5FSS Memory View

The memory view of the R5F (that is, the memory map as seen by each R5F) is a function of several things:

- Exception vector bootstrap: The R5F exception table (including boot vector) is always 32 bytes at address 0x00000000 as seen by the R5F. If not booting from a TCM, then boot is done over the main memory interface. The exception vector bootstrap is under software control, which allows these 32 bytes at address 0x00000000 to be remapped somewhere else in the SoC memory map.
- TCM locations: TCMs can be enabled or disabled and located at different places in the memory map, depending on bootstrap configuration. For more details, see [Section 7.2.2.2](#).
- Peripheral interface locations: The R5F natively supports three interfaces for peripheral access. Each can be enabled/disabled and located based on bootstrap configuration. Note that the VBUSP peripheral interface must be enabled in order to use RAT and VIM.
- RAT base address: This is determined by a bootstrap. This address is located within the VBUSP peripheral interface address space.
- VIM base address: This is determined by a bootstrap. This address is located within the VBUSP peripheral interface address space.
- RAT programming: The RAT can take regions of memory accessible by the main memory interface and map them to different addresses.

The combination of the above determines what the R5F sees where in the memory map, and over what interface different transactions come out. Every transaction that does not directly address a TCM or a peripheral interface comes over the main memory interface. Transactions on the main memory interface can be further remapped with the RAT.

See *Memory Map* for the complete R5F memory view for this device.

### 7.2.2.9 WKUP\_R5FSS Interrupts

All interrupts that are generated by the WKUP\_R5FSS are summarized in *Module Integration*, along with their mapping. They can be divided into the following groups:

- R5F CPU internal interrupts: These are described in *Arm Cortex-R5 Technical Reference Manual*.
- ECC aggregator interrupts: These are described in the *ECC Aggregator* chapter.
- RAT exception interrupt: This is described in [Section 7.2.2.6](#).

### 7.2.2.10 WKUP\_R5FSS Debug and Trace

The WKUP\_R5FSS supports standard Arm CoreSight debug and trace architecture. For more details, see the *On-chip Debug* chapter.

### 7.2.2.11 WKUP\_R5FSS Boot Options

There are two methods of booting the R5F, or rather, two methods of placing the exception vectors (of which the boot vector is one).

The first method is to have the exception vectors external to the R5F. The user can place the exception vectors at the address indicated by the exception vector bootstrap and then program the boot vector there. When the processor exits reset, it will fetch the boot vector from this location.

The second method is to boot from a TCM. To do this, software should take the following steps:

1. Assert the correct bootstraps
  - a. To boot from ATCM, set CPUn\_INITRAMA (or CPUn\_INITRAMB to boot from BTM)
  - b. Assert CPUn\_LOCZRAMA properly for the desired TCM
2. Assert CPUn\_HALT
3. Release the CPU from reset
4. Load the desired code into the TCM via the TCM target port
  - a. Exception vectors should be located at address 0x00000000 of the TCM
5. De-assert CPUn\_HALT

### 7.2.2.12 WKUP\_R5FSS Core Memory ECC Events

The R5F core generates several events as part of event bus that can be monitored by the PMU for debugging. The memory ECC related events from the event bus are exported to ESM for monitoring.

There are two ECC interrupts to the ESM that aggregate different categories of ECC events – CPU single error, CPU multi error. Each ECC event has a 2-bit event bus counter associated with it. Everytime an event occurs, the counter is incremented by 1 till it reaches the max value of 3. The interrupt is asserted if the bus counter of any event associated with the interrupt is non-zero.

Each event bus counter has a MMR decrement control to decrement the counter by 1. So, for example, if a counter value is 2, the MMR to decrement the counter would need to be written 2 times to decrement the counter to 0. The reason decrement control has been added instead of clear control is if a new error occurs between the time the status register is read and the clear MMR is written, the new error would be lost. Write-to-decrement ensures that this does not happen.

When all event bus counters of an associated interrupt are zero, the interrupt is cleared. It takes three clock cycles for the event bus counter to be decremented once the write to the decrement control MMR presents itself at the WKUP\_R5FSS boundary.

Since each of the four ECC interrupts have single bit control to set the interrupt but multiple bits for clearing it, note that once an interrupt is set using the R5FSS\_EVNT\_BUS\_ESM\_SET register, it can be cleared by setting all the bits of the R5FSS\_EVNT\_BUS\_ESM\_CLR register that correspond to that particular interrupt. For example, if bit [0] of the R5FSS\_EVNT\_BUS\_ESM\_SET register is set, it can be cleared by setting bits [7-0] of the R5FSS\_EVNT\_BUS\_ESM\_CLR register to clear the interrupt.

The R5F core event bus only signals event when it is enabled. Non-invasive or invasive debug mode needs to be enabled to enable the PMU counters.

The export of the events to the event bus can be enabled by setting the X bit in the Performance Monitor Control Register of the R5F core. For more details, refer to Arm R5 TRM.

**Table 7-11. R5F Event Bus Single-Bit Error Events**

| Event Bus Bit # | Description                                                                               | Associated Status Register                                                                               |
|-----------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| 22              | Instruction cache tag RAM parity or correctable ECC error.                                | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS0<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS0 |
| 23              | Instruction cache data RAM parity or correctable ECC error.                               | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS1<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS1 |
| 24              | Data cache tag or dirty RAM parity error or correctable ECC error, from data-side or ACP. | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS2<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS2 |
| 25              | Data cache data RAM parity error or correctable ECC error.                                | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS3<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS3 |
| 40              | ATCM single-bit ECC error.                                                                | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS4<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS4 |
| 41              | B0TCM single-bit ECC error.                                                               | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS5<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS5 |
| 42              | B1TCM single-bit ECC error.                                                               | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS6<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS6 |
| 43              | TCM correctable ECC error reported by load/store unit.                                    | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS7<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS7 |
| 44              | TCM correctable ECC error reported by prefetch unit.                                      | R5FSS_CPU0_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS8<br>R5FSS_CPU1_EVNT_BUS_SB_ERR_CNT_STATUS[0] EVNT_BUS8 |

**Table 7-12. R5F Event Bus Multi-Bit Error Events**

| Event Bus Bit # | Description                                          | Associated Status Register                                                                               |
|-----------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| 26              | TCM fatal ECC error reported from the prefetch unit. | R5FSS_CPU0_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS0<br>R5FSS_CPU1_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS0 |

**Table 7-12. R5F Event Bus Multi-Bit Error Events (continued)**

| Event Bus Bit # | Description                                                       | Associated Status Register                                                                               |
|-----------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| 27              | TCM fatal ECC error reported from the load/store unit.            | R5FSS_CPU0_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS1<br>R5FSS_CPU1_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS1 |
| 33              | Data cache data RAM fatal ECC error.                              | R5FSS_CPU0_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS2<br>R5FSS_CPU1_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS2 |
| 34              | Data caches tag/dirty RAM fatal ECC error, from data-side or ACP. | R5FSS_CPU0_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS3<br>R5FSS_CPU1_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS3 |
| 37              | ATCM multi-bit ECC error.                                         | R5FSS_CPU0_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS4<br>R5FSS_CPU1_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS4 |
| 38              | B0TCM multi-bit ECC error.                                        | R5FSS_CPU0_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS5<br>R5FSS_CPU1_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS5 |
| 39              | B1TCM multi-bit ECC error.                                        | R5FSS_CPU0_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS6<br>R5FSS_CPU1_EVNT_BUS_MB_ERR_CNT_STATUS[0] EVNT_BUS6 |

### 7.2.3 Vectored Interrupt Manager (VIM)

This section describes the VIM module in the device.

#### 7.2.3.1 VIM Overview

The Vectored Interrupt Manager (VIM) aggregates interrupts to a CPU. It is intended for use with a Cortex R5 from ARM. The VIM has up to 1024 interrupt inputs, which may be either level or pulse. Each interrupt has a programmable priority (0-highest through 15-lowest). Each interrupt may also be mapped as an IRQ or FIQ (FIQ is also often denoted as Non-Maskable Interrupt, or NMI).

##### 7.2.3.1.1 VIM Features

- 32-1024 Interrupt inputs
  - Configurable by groups of 32
- Each interrupt has its own 4-bit programmable priority
  - Supports Priority interruption of interrupts
- Each interrupt has its own enable mask
- Each interrupt can be programmed as either an IRQ or FIQ
- Each interrupt has its own programmable 32-bit Vector address associated with it
  - Protected with SECDED
- One IRQn and FIQn output
- Vectored Interrupt Interface
  - Compatible with ARM Cortex R5 VIC Port
- Default Vector provided when a Double-Bit error is detected
- Provides clock phase inputs so VIM can run at CPU clock while interface runs at a different, synchronous clock

##### 7.2.3.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

#### Note

Some features may not be available. See *Module Integration* for more information.

---

#### 7.2.3.2 VIM Functional Description

##### 7.2.3.2.1 Block Diagram

Figure 7-9 shows the Vectored Interrupt Manager block diagram.

**Figure 7-9. VIM Block Diagram**



#### 7.2.3.2.2 Interrupt Inputs

The VIM can have up to 1024 interrupt inputs, build-time configurable by multiples of 32 (*num\_interrupts* parameter). Each interrupt can be either a level or a pulse (both active high).

Level interrupts are synchronized to the VIM clock. This synchronized value is captured in to a flop.

Pulse interrupts use rising edge detection. Each input has its own edge detection circuit. It is recommended that if pulses are pipelined between the source and the VIM, that the pipe stage replicates the pipe flop and ORs the output in order to protect against transient errors in the pipeline flop. Once an edge has been detected, the raw status is set.

There is no minimum pulse width, as true edge detection is used. The input signal should, however, be glitch free.

#### 7.2.3.2.3 Interrupt Outputs

The VIM has two interrupt outputs, *coreN\_IRQn* and *coreN\_FIQn* (active low levels). Each interrupt input for core *N* can be programmed to influence either the *coreN\_IRQn* or *coreN\_FIQn* output via the Group *M* Interrupt Map Register (Base Address + 0x200 + *N*\*0x20 + 0x18).

#### 7.2.3.2.4 Priority Interrupt / Nested Interrupts

Each interrupt has a priority number assigned to it (set using the 4.1.20 Interrupt Q Priority Register (Base Address + 0x1000 + *Q*\*0x4) register). Legal values are 0 to 15 where 0 is the highest priority and 15 is the lowest priority. The highest priority interrupt is the pending interrupt with the smallest priority number. If two pending interrupts have the same priority, the interrupt lowest numerically (0 through maximum number of interrupts) is prioritized. IRQs and FIQs are prioritized separately.

The VIM supports the interrupt of the currently active interrupt by one with a higher priority. FIQs and IRQs are completely separate, but both use the same mechanism. When an interrupt goes from pending to active (FIQ: reading the FIQ Vector Address (Base Address + 0x1C), IRQ: reading the IRQ Vector Address (Base Address + 0x18) or the *coreN\_IRQACK* going high), then the interrupt is loaded into the corresponding Active Register, and all interrupts of an equal or lesser priority are masked off (see note below). If, before this interrupt is cleared (writing the FIQ Vector Address (Base Address + 0x1C) or IRQ Vector Address (Base Address + 0x18)) another interrupt of higher priority arrives, then the FIQn/IRQn will be asserted and that interrupt made pending as normal. The CPU may or may not service the higher priority interrupt. If the CPU switches this interrupt to active, by reading the corresponding Vector Address Register (or *coreN\_IRQACK* going high for an IRQ), then the currently active interrupt will be pushed on to a stack. When an interrupt is cleared by writing the Vector Address Register, if there are any interrupts on the stack, the first entry is popped off and put back into the Active Register, so that software may continue where it left off. Note that the IRQVEC/FIQVEC address registers are *not* repopulated with the old vector as it's assumed that the ISR is picking back up where it left off. Only the

interrupt number and priority are restored to the ACTIRQ/ACTFIQ registers. If software needs the vector again, it will have to read it by using the interrupt number.

---

**Note**

"Masked off" means that they are masked off from priority arbitration to interrupt the currently active interrupt, it does NOT mean that the status bits in the registers are masked off. i.e. this priority masking has NO EFFECT on whether the status bits are visible in the masked registers such as the Group M Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M \times 0x20$  + 0x04).

---

#### 7.2.3.2.5 VIC Port

The VIM is designed to work with the VIC interface of an ARM Cortex R5.

#### 7.2.3.2.6 Latency

There are several factors that go in to the speed of processing an interrupt: the interrupt controller, the processor, and the system latency.

The VIM behaves deterministically (except for synchronizer delay). [Table 7-13](#) shows the latency of the VIM.

**Table 7-13. VIM Latency**

| Step                           | Cycles | Note                                                          |
|--------------------------------|--------|---------------------------------------------------------------|
| Edge Detection                 | 2-3    | Synchronizing to VIM Clock                                    |
| Interrupt Capture              | 1      |                                                               |
| Prioritization and Vector Read | 1      | IRQ Could be stalled here if an FIQ is reading the Vector RAM |
|                                |        | IRQ/FIQ output asserted                                       |

The next factor is the processor itself

**Table 7-14. Processor Interrupt Latency**

| Step           | Cycles <sup>(1)</sup> | Note                                                                 |
|----------------|-----------------------|----------------------------------------------------------------------|
| Take Exception |                       |                                                                      |
| Store State    |                       | Stack system registers etc                                           |
| Read Vector    | 1                     | Through MMR or VIC interface (for IRQ. VIC interface will be faster) |
| Jump to Vector |                       |                                                                      |

(1) These steps are dependent on the processor. See R5 spec for details.

The final factor is system latency to access the actually instructions for the ISR. This will be dependent on where the instructions are (cache, TCM, system memory etc) and dependent on the system latency to reach those memories (1 cycle for cache/TCM, System dependent for external memory)

#### 7.2.3.2.7 Safety

The memory that holds the interrupt vector for each interrupt is protected by SECDED ECC. Single-bit errors are corrected and written back. Double-bit errors are not corrected. If a double-bit error occurs while trying to load a vector, then the DED Vector Address (Base Address + 0x30) is used instead for the coreN\_IRQADDRV, IRQ Vector Address (Base Address + 0x18), and FIQ Vector Address (Base Address + 0x1C). The DED Vector Address should point to an ISR that handles the fact that there was an uncorrectable error in the interrupt handling. Some possible remediating actions would be to:

1. Reconstruct the vector table and re-start the application
  - a. Potentially switch to a completely software interrupt handler in the mean time
2. Restart the application from scratch
3. Reset the device
4. Sit in a loop (or WFI) while something external (say the ESM) responds to the DED interrupt that will be generated

It is up to the user and the application to determine the appropriate action.

An interrupt that has an uncorrectable vector error and thus uses the DED Vector, will still have the priority of the original interrupt (i.e. for masking purposes). This makes it possible for a higher priority interrupt to supercede the handling of the error.

Control and reporting are done by an external ECC aggregator through sVbus ports.

#### 7.2.3.2.8 IDLE

The VIM will indicate IDLE when there are no pending unmasked interrupts or MMR accesses. The VIM does not have a clock stop interface because it does not have a clock IPG. To clock stop the sub-system that includes the VIM, disable (mask) all interrupts and wait for the IDLE signal to assert.

#### 7.2.3.3 Interrupt Conditions

##### 7.2.3.3.1 CPU Interrupts

See [Table 7-15](#) for the interrupts generated by the module.

**Table 7-15. Interrupts**

| Interrupt  | Description                |
|------------|----------------------------|
| core0_IRQn | IRQ Interrupt (Active Low) |
| core0_FIQn | FIQ Interrupt (Active Low) |

##### 7.2.3.3.2 Interrupt Description

###### 7.2.3.3.2.1 coreN\_IRQn

This is a normal interrupt, active low level, for Core N. It can be serviced via the VIC interface or through the MMR interface.

###### 7.2.3.3.2.2 coreN\_FIQn

This is a fast (or non-maskable) interrupt, active low level, for Core N. FIQs always have priority over IRQs. An FIQ can be serviced through the MMR interface.

###### 7.2.3.3.3 Interrupt Condition Control

###### 7.2.3.3.3.1 coreN\_IRQn

Whenever an interrupt input goes high, if that interrupt is mapped as an IRQ (Group N Interrupt Map Register (Base Address + 0x200 + N\*0x20 + 0x18)) and is enabled (Group N Interrupt Enabled Set Register (Base Address + 0x200 + N\*0x20 + 0x08)), and its priority is not masked (4.1.11 IRQ Priority Mask Register (Base Address + 0x28), and it is not masked because of nested interrupt priority masking (2.2.5 Priority Interrupt / Nested Interrupts), then it will cause an IRQ to assert.

###### 7.2.3.3.3.2 coreN\_FIQn

Whenever an interrupt input goes high, if that interrupt is mapped as an FIQ (Group N Interrupt Map Register (Base Address + 0x200 + N\*0x20 + 0x18)) and is enabled (Group N Interrupt Enabled Set Register (Base Address + 0x200 + N\*0x20 + 0x08)), and its priority is not masked (4.1.12 FIQ Priority Mask Register (Base Address + 0x2C)), and it is not masked because of nested interrupt priority masking (2.2.5 Priority Interrupt / Nested Interrupts), then it will cause an FIQ to assert.

###### 7.2.3.3.4 Interrupt Handling

There are multiple ways to service an interrupt depending on how much of the hardware assistance offered by the VIM software wants to take advantage of. For IRQs, it is recommended to use 3.4.1 IRQ through the Vector Interface, but 3.4.2 or 3.4.3 (if a user wants to implement a fully software prioritization scheme) may be used as alternatives. For FIQs, it is recommended to use 3.4.4 FIQ, but 3.4.5 may be used as an alternative.

---

**Note**

These descriptions do not include steps such as stack pushes and state retention that software must take in order to return from the ISR. It is assumed that the programmer is aware of these steps.

#### **7.2.3.3.4.1 IRQ through the Vector Interface**

If the attached CPU has the Vector Interface enabled, then the following method is used for servicing IRQs

1. Hardware handshake
  - a. CPU asserts coreN\_IRQACK signal high
  - b. VIM asserts coreN\_IRQADDRV to indicate that the coreN\_IRQADDR bus is stable with the correct Vector Address
  - c. CPU reads the coreN\_IRQADDR, jumps to that address, and de-asserts coreN\_IRQACK signal low
  - d. VIM de-asserts coreN\_IRQn\_intr and coreN\_IRQADDRV, VIM masks all IRQs with the same or lower priority
  - e. VIM loads the value from the Prioritized IRQ (Base Address + 0x08) (which corresponds to the vector address) to be loaded into the Active IRQ (Base Address + 0x20) and the valid bit to be set
2. Service an interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level (Determined by reading the Active IRQ (Base Address + 0x20) to determine number and reading the Group M Type Map Register (Base Address + 0x200 + M\*0x20 + 0x1C) to determine type)
  - a. Pulse
    - i. Clear the status by writing a 1 to the appropriate bit in the Group M Interrupt Enabled Status/Clear Register (Base Address + 0x400 + M\*0x20 + 0x04) or Group M Interrupt IRQ Enabled Status/Clear Register (Base Address + 0x400 + M\*0x20 + 0x10)
    - ii. Clear the interrupt at the source
      1. This way, the source can generate another pulse if it needs to and the VIM will process this as a new interrupt
  - b. Level
    - i. Clear the interrupt at the source
    - ii. Clear the status by writing a 1 to the appropriate bit in the Group M Interrupt Enabled Status/Clear Register (Base Address + 0x400 + M\*0x20 + 0x04) or Group M Interrupt IRQ Enabled Status/Clear Register (Base Address + 0x400 + M\*0x20 + 0x10)
      1. This way, the level should be gone at the input to the VIM, it will avoid falsely re-calling the interrupt
      2. If the source maintains the level, then it means there is another interrupt
4. Write any value to the IRQ Vector Address (Base Address + 0x18)
  - a. This will clear the priority mask and all interrupts to be re-evaluated for the new highest priority interrupt.
  - b. This will clear the valid bit of the Active IRQ (Base Address + 0x20)

#### **7.2.3.3.4.2 IRQ through MMR Interface**

When an IRQ interrupt is received, the CPU should follow these steps if not using the Vector Interface.

1. Read the IRQ Vector Address (Base Address + 0x18) and jump to that address to service the ISR
  - a. Reading this register will mask all interrupts of an equal or lower priority and de-assert the IRQn output. If another interrupt of a higher priority becomes available, the IRQn will re-assert, allowing priority interruption of an interrupt.
  - b. Reading this register will cause the value from the Prioritized IRQ (Base Address + 0x08) (which corresponds to the vector address) to be loaded into the Active IRQ (Base Address + 0x20) and the valid bit to be set
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level (Determined by reading the Active IRQ (Base Address + 0x20) to determine number and reading the Group M Type Map Register (Base Address + 0x200 + M\*0x20 + 0x1C) to determine type)

- a. Pulse
    - i. Clear the status by writing a 1 to the appropriate bit in the Group  $M$  Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x04$ ) or Group  $M$  Interrupt IRQ Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x10$ )
    - ii. Clear the interrupt at the source
      - 1. This way, the source can generate another pulse if it needs to and the VIM will process this as a new interrupt
  - b. Level
    - i. Clear the interrupt at the source
    - ii. Clear the status by writing a 1 to the appropriate bit in the Group  $M$  Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x04$ ) or Group  $M$  Interrupt IRQ Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x10$ )
      - 1. This way, the level should be gone at the input to the VIM, it will avoid falsely re-calling the interrupt
      - 2. If the source maintains the level, then it means there is another interrupt
4. Write any value to the IRQ Vector Address (Base Address + 0x18)
- a. This will clear the priority mask and all interrupts to be re-evaluated for the new highest priority interrupt.
  - b. This will clear the valid bit of the Active IRQ (Base Address + 0x20)

#### 7.2.3.4.3 IRQ through MMR Interface (Alternative)

If a user does not want to use the Vector Address registers, the VIM may be used as a more traditional interrupt controller. Note that in this mode, priority masking will not work if route 1b is used (below) as the hardware prioritization may not match the software prioritization scheme. In this case, software would be responsible for doing all priority operations

- 1. Determine which interrupt to service
  - a. Read the Prioritized IRQ (Base Address + 0x08) to determine which interrupt is the highest priority IRQ currently asserted OR
  - b. Optionally read the IRQ Group Status (Base Address + 0x10) to determine which groups have IRQs pending, then read the Group  $M$  Interrupt IRQ Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x10$ ) and use a software prioritization scheme to determine which IRQ to service
- 2. Service the interrupt
- 3. Read the IRQ Vector Address (Base Address + 0x18)
  - a. Note, this step can be done any time before step 4
  - b. Value is ignored
- 4. Depending on whether the original source of the interrupt was a pulse or a level (Determined by reading the Group  $M$  Type Map Register (Base Address + 0x200 +  $M*0x20 + 0x1C$ ) to determine type)
  - a. Pulse
    - i. Clear the status by writing a 1 to the appropriate bit in the Group  $M$  Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x04$ ) or Group  $M$  Interrupt IRQ Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x10$ )
    - ii. Clear the interrupt at the source
      - 1. This way, the source can generate another pulse if it needs to and the VIM will process this as a new interrupt
  - b. Level
    - i. Clear the interrupt at the source
    - ii. Clear the status by writing a 1 to the appropriate bit in the Group  $M$  Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x04$ ) or Group  $M$  Interrupt IRQ Enabled Status/Clear Register (Base Address + 0x400 +  $M*0x20 + 0x10$ )
      - 1. This way, the level should be gone at the input to the VIM, it will avoid falsely re-calling the interrupt

2. If the source maintains the level, then it means there is another interrupt
5. Write any value to the IRQ Vector Address (Base Address + 0x18)

#### **7.2.3.3.4.4 FIQ**

When an FIQ interrupt is received, the CPU should follow these steps.

1. Read the FIQ Vector Address (Base Address + 0x1C) and jump to that address to service the ISR
  - a. Reading this register will mask all interrupts of an equal or lower priority and de-assert the FIQn output. If another interrupt of a higher priority becomes available, the FIQn will re-assert, allowing priority interruption of an interrupt.
  - b. Reading this register will cause the value from the Prioritized FIQ (Base Address + 0x0C) (which corresponds to the vector address) to be loaded into the Active FIQ (Base Address + 0x24) and the valid bit to be set
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level (Determined by reading the Active FIQ (Base Address + 0x24) to determine number and reading the Group M Type Map Register (Base Address + 0x200 +  $M \cdot 0x20 + 0x1C$ ) to determine type)
  - a. Pulse
    - i. Clear the status by writing a 1 to the appropriate bit in the Group M Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M \cdot 0x20 + 0x04$ ) or Group M Interrupt FIQ Enabled Status/Clear Register (Base Address + 0x400 +  $M \cdot 0x20 + 0x14$ )
    - ii. Clear the interrupt at the source
      1. This way, the source can generate another pulse if it needs to and the VIM will process this as a new interrupt
  - b. Level
    - i. Clear the interrupt at the source
    - ii. Clear the status by writing a 1 to the appropriate bit in the Group M Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M \cdot 0x20 + 0x04$ ) or Group M Interrupt FIQ Enabled Status/Clear Register (Base Address + 0x400 +  $M \cdot 0x20 + 0x14$ )
      1. This way, the level should be gone at the input to the VIM, it will avoid falsely re-calling the interrupt
      2. If the source maintains the level, then it means there is another interrupt
4. Write any value to the FIQ Vector Address (Base Address + 0x1C)
  - a. This will clear the priority mask and all interrupts to be re-evaluated for the new highest priority interrupt.
  - b. This will clear the valid bit of the Active FIQ (Base Address + 0x24)

#### **7.2.3.3.4.5 FIQ (Alternative)**

If a user does not want to use the Vector Address registers, the VIM may be used as a more traditional interrupt controller. Note that in this mode, there is no hardware priority masking (because the FIQ Vector Address (Base Address + 0x1C) is never read). Software would be responsible for doing all priority operations

1. Determine which interrupt to service
  - a. Read the Prioritized FIQ (Base Address + 0x0C) to determine which interrupt is the highest priority FIQ currently asserted OR
  - b. Optionally read the FIQ Group Status (Base Address + 0x14) to determine which groups have IRQs pending, then read the Group M Interrupt FIQ Enabled Status/Clear Register (Base Address + 0x400 +  $M \cdot 0x20 + 0x14$ ) and use a software prioritization scheme to determine which FIQ to service
2. Service the interrupt
3. Depending on whether the original source of the interrupt was a pulse or a level (Determined by reading the Group M Type Map Register (Base Address + 0x200 +  $M \cdot 0x20 + 0x1C$ ) to determine type)
  - a. Pulse

- i. Clear the status by writing a 1 to the appropriate bit in the Group  $M$  Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M^*0x20 + 0x04$ ) or Group  $M$  Interrupt FIQ Enabled Status/Clear Register (Base Address + 0x400 +  $M^*0x20 + 0x14$ )
- ii. Clear the interrupt at the source
  - 1. This way, the source can generate another pulse if it needs to and the VIM will process this as a new interrupt
- b. Level
  - i. Clear the interrupt at the source
  - ii. Clear the status by writing a 1 to the appropriate bit in the Group  $M$  Interrupt Enabled Status/Clear Register (Base Address + 0x400 +  $M^*0x20 + 0x04$ ) or Group  $M$  Interrupt FIQ Enabled Status/Clear Register (Base Address + 0x400 +  $M^*0x20 + 0x14$ )
    - 1. This way, the level should be gone at the input to the VIM, it will avoid falsely re-calling the interrupt
    - 2. If the source maintains the level, then it means there is another interrupt

#### 7.2.3.4 Memory Map

Each Interrupt Core ( $N = 0$ ) has its own MMR interface with its own independent memory map

**Table 7-16. Core  $N$  Memory Map**

| Address Offset              | Register                                              |
|-----------------------------|-------------------------------------------------------|
| 0x00                        | Revision Register                                     |
| 0x04                        | Info Register                                         |
| 0x08                        | Prioritized IRQ                                       |
| 0x0C                        | Prioritized FIQ                                       |
| 0x10                        | IRQ Group Status                                      |
| 0x14                        | FIQ Group Status                                      |
| 0x18                        | IRQ Vector Address                                    |
| 0x1C                        | FIQ Vector Address                                    |
| 0x20                        | Active IRQ                                            |
| 0x24                        | Active FIQ                                            |
| 0x28-0x2F                   | Reserved                                              |
| 0x30                        | DED Vector Address                                    |
| 0x34-0x1FF                  | Reserved                                              |
| 0x400 + $M^*0x20 + 0x00$    | Group $M$ Interrupt Raw Status/Set Register           |
| 0x400 + $M^*0x20 + 0x04$    | Group $M$ Interrupt Enabled Status/Clear Register     |
| 0x400 + $M^*0x20 + 0x08$    | Group $M$ Interrupt Enabled Set Register              |
| 0x400 + $M^*0x20 + 0x0C$    | Group $M$ Interrupt Enabled Clear Register            |
| 0x400 + $M^*0x20 + 0x10$    | Group $M$ Interrupt IRQ Enabled Status/Clear Register |
| 0x400 + $M^*0x20 + 0x14$    | Group $M$ Interrupt FIQ Enabled Status/Clear Register |
| 0x400 + $M^*0x20 + 0x18$    | Group $M$ Interrupt Map Register                      |
| 0x400 + $M^*0x20 + 0x1C$    | Group $M$ Type Map Register                           |
| 0x1000 + $Q^*0x4 - 0x01FFF$ | Interrupt Q Priority Register                         |
| 0x2000 + $Q^*0x4 - 0x2FFF$  | Interrupt Q Vector Register                           |

There are  $M$  interrupt groups (0 through  $num\_groups-1$ ) with 32 interrupts per group.

There are  $Q$  interrupt inputs where  $Q = M * 32$ .

Accesses to the Interrupt Q Vector Register (Base Address + 0x2000 +  $Q^*0x4$ ) must be word-aligned, 32-bit accesses. Any write received with no bytes enabled will be ignored. Any writes receive with all bytes enabled will be executed. Any other write will not execute and will return an error status of Addressing Error.

### 7.2.3.5 Module I/O

#### 7.2.3.5.1 Clocks, Reset, Emulation

**Table 7-17. Clocks, Reset, Emulation**

| Pin Name           | Type | Function                      |
|--------------------|------|-------------------------------|
| core0_clk          | In   | Clock for Core 0              |
| core0_phase        | In   | Phase Indicator for Core 0    |
| core0_srst_n       | In   | Sync Module Reset for Core 0  |
| core0_arst_n       | In   | Async Module Reset for Core 0 |
| core0_clkstop_idle | Out  | Clock Stop Idle               |

#### 7.2.3.5.2 VBUSP Target Interface

(N=0). Core0 interface is used for interrupt core 0.

**Table 7-18. VBUSP Target Interface**

| Pin Name                | Type | Function                  |
|-------------------------|------|---------------------------|
| coreN_cfg_req           | In   | Request                   |
| coreN_cfg_address[13:0] | In   | Address (byte address)    |
| coreN_cfg_dir           | In   | Direction (read or write) |
| coreN_cfg_xcnt[2:0]     | In   | Transaction Count         |
| coreN_cfg_byten[3:0]    | In   | Byte enables              |
| coreN_cfg_wdata[31:0]   | In   | Write data                |
| coreN_cfg_rdatap[31:0]  | Out  | Read data                 |
| coreN_cfg_rready        | Out  | Read ready                |
| coreN_cfg_wready        | Out  | Write ready               |
| coreN_cfg_rstatus[2:0]  | Out  | Read Status               |
| coreN_cfg_emudbg        | In   | Emulation Debug           |

#### 7.2.3.5.3 Interrupt Inputs

Core0 interface is used for interrupt core 0.

**Table 7-19. Interrupt Inputs**

| Pin Name             | Type | Function                |
|----------------------|------|-------------------------|
| core0_in_intr[Q-1:0] | In   | Core 0 Interrupt Inputs |

#### 7.2.3.5.4 Interrupt Outputs

**Table 7-20. Interrupt Outputs**

| Pin Name        | Type | Function                                    |
|-----------------|------|---------------------------------------------|
| core0_IRQn_intr | Out  | IRQ Interrupt for core 0– Active Low Level  |
| core0_FIQn_intr | Out  | FIQ Interrupt for core 0 – Active Low Level |

#### 7.2.3.5.5 VIC Interfaces

(N=0). Core0 interface is used for interrupt core 0.

**Table 7-21. VIC Interfaces**

| Pin Name                | Type | Function          |
|-------------------------|------|-------------------|
| coreN_vic_IRQADDRV      | Out  | IRQ Address Valid |
| coreN_vic_IRQADDR[31:2] | Out  | IRQ Address       |

**Table 7-21. VIC Interfaces (continued)**

| Pin Name         | Type | Function              |
|------------------|------|-----------------------|
| coreN_vic_IRQACK | In   | Interrupt Acknowledge |

**7.2.3.5.6 Compare Outputs**

These pins will never be on an isolation boundary and therefore their isolation values are don't-care. Y is dependent on the configuration

**Table 7-22. Compare Outputs**

| Pin Name               | Type | Function                          |
|------------------------|------|-----------------------------------|
| core0_compare_bus[Y:0] | Out  | Comparison Bus for Core0 to CCMR5 |

**7.2.3.5.7 ECC Control and Status Bus**

(N=0). Core0 interface is used for interrupts for core 0.

**Table 7-23. ECC Control and Status Bus**

| Signal Name            | Dir | Default Val | Description                               |
|------------------------|-----|-------------|-------------------------------------------|
| coreN_ramecc_strb      | In  | 1'b0        | Strobe to sample the incoming serial data |
| coreN_ramecc_txd       | In  | 1'b0        | Output serial data                        |
| coreN_ramecc_rxd       | Out | 1'b0        | Input serial data                         |
| coreN_ramecc_pend[1:0] | Out | 2'd0        | Level Interrupt source                    |

**7.2.3.5.8 DFT****Table 7-24. DFT**

| Signal Name          | Dir | Default Val | Description                |
|----------------------|-----|-------------|----------------------------|
| dft_clk_force_en     | In  | 1'b0        | DFT Clock Force Enable     |
| dft_partition_enn    | In  | 1'b0        | DFT Clock Partition Enable |
| dft_scan_en          | In  | 1'b0        | DFT Scan Enable            |
| dft_async_rst_sel    | In  | 1'b0        | DFT Async Reset Select     |
| dft_test_async_rst_n | In  | 1'b0        | DFT Async Test Reset       |
| dft_tft_mcp_dis      | In  | 1'b0        | DFT MCP Disable            |
| dft_local_clk_en     | In  | 1'b0        | DFT Local Clock Enable     |

**7.2.3.5.9 RAM GPIO****Table 7-25. RAM GPIO**

| Signal Name             | Dir | Default Val | Description |
|-------------------------|-----|-------------|-------------|
| coreN_ramdft_gpi[255:0] | In  | 256'd0      | RAM GPI     |
| coreN_ramdft_gpo[255:0] | Out | 256'd0      | RAM GPO     |

**7.2.3.6 Programmer's Guide****7.2.3.6.1 Initialization Sequence**

At initialization, the following tasks should be performed:

1. Program the DED Vector Address (Base Address + 0x30)
2. Program Group *M* Interrupt Map Register (Base Address + 0x200 + *M*\*0x20 + 0x18)
3. Program Group *M* Type Map Register (Base Address + 0x200 + *M*\*0x20 + 0x1C)
4. Program Interrupt Q Priority Register (Base Address + 0x1000 + Q\*0x4)
5. Program Interrupt Q Vector Register (Base Address + 0x2000 + Q\*0x4)
6. Enable interrupts via the Group *M* Interrupt Enabled Set Register (Base Address + 0x400 + *M*\*0x20 + 0x08)

Note that the Interrupt Q Vector Register (Base Address + 0x2000 + Q\*0x4) for each interrupt that will be enabled must be written before the interrupt is enabled, even if software is not going to use the vector. Whenever an interrupt is prioritized, the RAM location for the interrupt is read, and if that location is un-initialized, an ECC error will be reported. If the vectors aren't being used, then the RAM can be initialized by writing 0x0 to every location.

#### **7.2.3.6.2 DED Behavior**

Whenever there is 2-bit error detect on a Vector Address, the DED Vector Address (Base Address + 0x30) overrides all other vectors. Software should provide an ISR to handle this scenario at this address.

#### **7.2.3.6.3 Power Up/Down Sequence**

Before a clean power down, software should check that there are no pending interrupts, disable all interrupts, and wait for the clkstop\_idle output.

## 7.3 Cortex-M4F Subsystem (MCU\_M4FSS)

This chapter describes the Arm Cortex-M4F based safety processing microcontroller unit (MCU\_M4FSS) in the device.

|                                             |     |
|---------------------------------------------|-----|
| 7.3.1 MCU_M4FSS Overview.....               | 685 |
| 7.3.2 MCU_M4FSS Functional Description..... | 686 |

### 7.3.1 MCU\_M4FSS Overview

The MCU\_M4FSS is an Arm Cortex-M4F based subsystem that can run safety processing or be used as a general purpose MCU. During the boot process, the MCU\_M4FSS will be configured by an initial software running on a different core. Following configuration, software will release the safety processor (M4F) out of reset, and at this point safety processor code or general purpose code can start execution.

#### Note

The Cortex-M4F processor is a Cortex-M4 processor that includes the optional floating point unit (FPU) extension.

The MCU\_M4FSS is designed to meet SIL-2 safety requirements. Safety is enabled for all major subsystem components that include ECC / EDC features:

- ECC: I-RAM, D-RAM
- EDC: I-RAM, D-RAM, ECC\_AGGR, RAT, CBASS, AHB2VBUSP bridges

There is one MCU\_M4FSS in the device. [Table 7-26](#) shows MCU\_M4FSS allocation across device domains.

**Table 7-26. MCU\_M4FSS Allocation Across Device Domains**

| Module Instance | Domain |      |
|-----------------|--------|------|
|                 | MCU    | MAIN |
| MCU_M4FSS0      | ✓      | —    |

#### 7.3.1.1 MCU\_M4FSS Features

The MCU\_M4FSS supports the following features:

- Arm Cortex-M4F RISC CPU
  - Single-core implementation
  - Core revision is r0p1
  - Armv7-M architecture
  - Memory protection unit (MPU)
  - Nested vectored interrupt controller (NVIC), to achieve low interrupt latency
    - 64 external interrupts
    - 3-bit priority (8 priority levels)
  - Bus interfaces
    - Three advanced high-performance bus-lite (AHB-Lite) interfaces: ICode, DCode, and system bus interfaces
    - Private peripheral bus (PPB) based on advanced peripheral bus (APB) interface
- 256KB SRAM memory system divided into two banks
  - 192KB of instruction code (I-RAM)
  - 64KB of data space (D-RAM)
- Ability to execute code from internal SRAMs or external memories
- External initiators can access internal SRAMs if allowed
- 32-bit to 36-bit region-based address translation (RAT)
- Fault detection and correction
  - SECDED ECC protection on I-RAM
  - SECDED ECC protection on D-RAM
  - Fault error interrupt generation
- Standard Arm debug and trace architecture

#### Note

Some features may not be available. See *Module Integration* for more information.

### 7.3.2 MCU\_M4FSS Functional Description

#### 7.3.2.1 MCU\_M4FSS Block Diagram

Figure 7-10 shows the MCU\_M4FSS block diagram.



Figure 7-10. MCU\_M4FSS Block Diagram

#### 7.3.2.2 MCU\_M4FSS Processor

The M4F is a low-power processor that features low gate count, low interrupt latency, and low-cost debug. It is intended for deeply embedded applications that require optimal interrupt response features. Some key features of the M4F processor core include:

- A subset of the Thumb instruction set, defined in the Armv7-M architecture
- Banked stack pointer (SP)
- Hardware integer divide instructions, SDIV and UDIV
- Handler and thread modes
- Thumb and debug states
- Support for interruptible-continued instructions LDM, STM, PUSH, and POP for low interrupt latency

A nested vectored interrupt controller (NVIC) is closely integrated with the processor core, to achieve low latency interrupt processing. NVIC features include:

- 64 external interrupts
- 3-bit priority (8 priority levels)
- Dynamic reprioritization of interrupts
- Priority grouping

- This enables selection of preempting interrupt levels and non-preempting interrupt levels
- Support for tail-chaining and late arrival of interrupts
  - This enables back-to-back interrupt processing without the overhead of state saving and restoration between interrupts
- Processor state automatically saved on interrupt entry, and restored on interrupt exit, with no instruction overhead

The M4F processor also includes:

- Bus interfaces for memory access (ICode, DCode, system) and debug access (PPB APB)
- Memory protection unit (MPU)
- Various debug and trace units

For more details on the M4F processor, refer to the following documents:

- *Arm Cortex-M4 Processor Technical Reference Manual*
- *Arm Cortex-M4 Devices Generic User Guide*

### **7.3.2.3 MCU\_M4FSS Internal RAMs**

The MCU\_M4FSS has a total of 256KB of SRAM divided into two banks: 192KB of I-RAM, and 64KB of D-RAM. The I-RAM memory is intended mainly for M4F's instruction code, and D-RAM for M4F's data. The M4F allows concurrent fetch for instruction code and data via dedicated buses (I-Code and D-Code, respectively).

The MCU\_M4FSS supports unified memory for both banks (I-RAM and D-RAM), which means instruction code and data can be placed in any bank. In order to get optimal performance, it is highly recommend that instruction code be placed in I-RAM and data be placed in D-RAM; this allows the M4F to fetch in parallel instruction code and data from two different physical banks using two independent I-Code and D-Code buses. For instance, the D-RAM can be used to store instruction code in case the latter is spanning over the 192KB I-RAM.

Furthermore, the following applies:

- Both RAMs are organized in 32-bits words
- Both RAMs are initialized during reset - that is, there is no auto-initialization sequencing
- Both RAMs are ECC SECDED protected
  - Support for write-back upon single bit correction
- Data fetch is given higher priority over instruction fetch to avoid locking M4F

### **7.3.2.4 MCU\_M4FSS Interfaces**

#### **7.3.2.4.1 Controller Interfaces**

The MCU\_M4FSS has three 32-bit advanced high-performance bus-lite (AHB-Lite) interfaces:

- ICode for instructions
- DCode for data
- System bus

#### **7.3.2.4.2 Peripheral Interfaces**

The MCU\_M4FSS has two peripheral interfaces:

- 32-bit VBUSP configuration interface - ECC Aggregator block
- 32-bit Debug interface

### **7.3.2.5 MCU\_M4FSS Power, Clocking and Reset**

See specific integration, power, clocking, and reset chapters.

### **7.3.2.6 MCU\_M4FSS Memory View**

The M4F processor has a fixed default memory map that provides up to 4GB of addressable memory. The predefined memory map allows the built-in peripherals, such as NVIC, MPU, SysTick and debug components, to be accessed by simple memory access instructions. Thus, most system features are accessible in program code. The M4F design has an internal bus infrastructure optimized for this memory usage.

The MCU\_M4FSS memory map is presented in *Memory Map*. Note that bit-banding is not supported.

### 7.3.2.7 MCU\_M4FSS RAT

#### 7.3.2.7.1 RAT Usage

M4F is a micro controller with 32b address, which is only able to access up to 4GB address space. However, Sitara SoC supports 36b address and majority of the memory region beyond lower 4GB are implemented. Region based address translation block, called RAT, is introduced to allow R5 core to access full 36b SoC memory map.

Each R5 core has its own RAT block, and only R5 core itself is able to program the RAT.

Figure 7-11 shows the main R5's default 32b memory map view when main R5 is out of reset.

The full RAT functionality is described in *Region-based Address Translation (RAT) Module*.



Figure 7-11. R5 Core Default Memory Map View



**Figure 7-12. Typical Sitara SoC Memory Map View (36b address)**

RAT block enables R5 core to have full access on the SoC memory map including the memory region at and above 0x1\_0000\_0000.

Figure 7-13 shows how R5 access various end points, including its own ATCM, BTM, VIM and SoC memory and peripherals. R5's ATCM is by default at address 0x0, and its BTM is at address 0x4101\_0000. R5 uses address 0x2FFF\_0000 to access its VIM and 0x2FFE\_0000 to access the RAT configuration region and all the other transactions between address range 0x2000\_0000 to 0x2FFF\_FFFF are sent to the 32b peripheral interface to access the peripherals in SoC. The transactions with the rest of address are sent to RAT block, which could go through address remapping function from original R5's 32b address to 36b SoC address.



Figure 7-13. R5 Internal Address Decoding

Table 7-27. MCU R5 Memory Map View

| Starting Address | End Address | Region                                                                                                                   | Notes                                                                                                                                                                                              |
|------------------|-------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x 0000_0000     | 0x0000_7FFF | ATCM                                                                                                                     | ATCM is by default disabled. Before it is enabled, its address can be remapped to a different location through CP15. Access from other masters uses the SoC level memory address assigned to ATCM. |
| 0x0000_8000      | 0x03FF_FFFF | sent to SoC level through 64b VBUSM initiator                                                                            |                                                                                                                                                                                                    |
| 0x0400_0000      | 0x07FD_FFFF | peripheral region. Sent to SoC level to access the SoC level peripherals in address range of 0x2000_0000 to 0x2FFD_FFFF. |                                                                                                                                                                                                    |
| 0x07FE_0000      | 0x07FE_0FFF | R5's own RTA configuration region                                                                                        |                                                                                                                                                                                                    |
| 0x07FF_0000      | 0x07FF_3FFF | R5's own VIM                                                                                                             |                                                                                                                                                                                                    |
| 0x0800_0000      | 0x410F_FFFF | sent to SoC level through 64b VBUSM initiator. Do not use RAT for address remapping.                                     |                                                                                                                                                                                                    |
| 0x4101_0000      | 0x4101_7FFF | R5's BTM                                                                                                                 | BTM by default is enabled. And access from SoC level uses the SoC level memory address assigned to BTM.                                                                                            |
| 0x4101_8000      | 0x7FFF_FFFF | sent to SoC level through 64b VBUSM initiator. Do not use RAT for address remapping.                                     |                                                                                                                                                                                                    |

**Table 7-27. MCU R5 Memory Map View (continued)**

| Starting Address | End Address | Region                                                                                  | Notes |
|------------------|-------------|-----------------------------------------------------------------------------------------|-------|
| 0x8000_0000      | 0xFFFF_FFFF | Could use RAT for address remapping if it is needed before sent to 64b VBUSM initiator. |       |

### 7.3.2.7.2 RAT Function

RAT block is responsible to do a region based address translation. For each region, user can define the starting address and size of the region and remapping the transactions to use a new address range.

The starting address and region size need to be aligned. For example, if the region size is 16KB, the starting address for that region needs to be 16KB aligned. And region size should be minimum 4KB or larger to avoid transactions cross the region boundaries.

Each RAT block supports multiple programmable regions. And it is important that those regions are not overlapping with each other.

RAT block is by default disabled, which means RAT block does not do address remapping. The 32b address coming from R5 core is directly sent out to the SoC level. The user can program each RAT remapping region individually. For the transactions does not hit any remapping region, RAT block just simply forwards the transactions to the SoC level with its original address.

### 7.3.2.7.3 How to use RAT Block in R5

**Table 7-28** shows the default R5 memory map view. Without enabling RAT function, all the regions beyond 4GB address space will not be accessible by R5.

Sitara SoC memory map is constructed the way to allow R5 and high level application processor such as A53 have similar memory map as possible. This methodology enables that R5 and ARM A53 core have a common memory map for all the SoC level memories and SoC level peripherals except a few exceptions:

- DDR's data space beyond 32b address, basically upper DDR data space beyond 2GB
- PCIe data space beyond 32b address
- OSPI data space beyond 32b address
- Debug configuration region

**Table 7-28. R5 Memory map by Default**

|                                       | R5 Memory Map(32b)                                    | SoC Memory Map (36b)                       |
|---------------------------------------|-------------------------------------------------------|--------------------------------------------|
| SoC Level peripheral and on-chip SRAM | 0x0 to 0x7FFF_FFFF<br>Same address as SoC memory map  | 0x0 to 0x7FFF_FFFF                         |
| 2GB DDR region                        | Same as SoC memory map:<br>0x8000_0000 to 0xFFFF_FFFF | 0x80000_0000 to 0xFFFF_FFFF                |
| Additional DDR region                 | Not accessible                                        | 0x8_8000_0000 (30GB)                       |
| Additional 8GB OSP Space              | Not accessible                                        | 0x4_0000_0000 (4GB)<br>0x5_0000_0000 (4GB) |
| Additional PCIe data space            | Not accessible                                        | 0x6_000_0000                               |
| Debug configuration region            | Not accessible                                        | 0x7_0000_0000                              |

Even though all the transactions other than going to ATCM/BTCM and transactions between address range 0x2000\_0000 to 0x2FFF\_FFFF could use RAT block to remap to different address, it is recommended that only use RAT block to remap the R5 transactions with address between 0x8000\_0000 to 0xFFFF\_FFFF.

- Any transactions from R5 with address between 0x0 to 0x7FFF\_FFFF are sent out to SoC directly (unless it is targeted to its internal end points such as A/B TCM, its VIM and RAT configuration)
- Only enable RAT to remap the transactions with address between 0x8000\_0000 to 0xFFFF\_FFFF if R5 needs to access the following address space:
  - PCIe data space at address 0x6\_0000\_0000

- OSPI data space address 0x4\_0000\_0000 and 0x5\_0000\_0000
- Debug configuration region at address 0x7\_0000\_0000
- DDR data space at address 0x8\_8000\_0000


**Figure 7-14. Main R5 RAT Configuration**

#### 7.3.2.7.4 Example of Using RAT to Access Full 36b SoC Memory Map

This section shows an example on how to utilize RAT block to allow R5 to access 36 SoC Memory Map. The RAT block inside R5 has up to 8 address remapping regions.

Assuming R5 needs to access the following region:

- All the SoC level on-chip SRAM
- All the SoC level peripherals
- Access 512MB OSPI region at address 0x4\_0000\_0000
- Access 1GB DDR region at address 0x9\_0000\_0000
- Access 512MB DDR region at address 0x8000\_0000

First of all, we need to construct 32b R5 memory map as following and how those memory spaces are mapped to SoC level, shown in [Table 7-29](#). Users can define where the OSPI and DDR data space placed inside R5's memory map and how they should be mapped to SoC level address map. [Table 7-29](#) just shows one of the many possible ways to construct the memory map.

**Table 7-29. Example of R5 Address Mapping**

|                                                                                                                       | R5 Memory Map(32b)                                   | SoC Memory Map (36b)           | RAT Remapping                |
|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------|------------------------------|
| SoC Level peripheral and on-chip SRAM<br>(This is guaranteed by SoC Hardware design. No user configuration is needed) | 0x0 to 0x7FFF_FFFF<br>Same address as SoC memory map | 0x0 to 0x7FFF_FFFF             | Not RAT Remapping            |
| 512MB OSPI data region (user defined)                                                                                 | 0x8000_0000 to 0x9FFF_FFFF                           | 0x4_0000_0000 to 0x4_1FFF_FFFF | Using RAT remapping region 0 |
| 512MB DDR space (user defined)                                                                                        | 0xA000_0000 to 0xBFFF_FFFF                           | 0x8000_0000 to 0x9FFF_FFFF     | Using RAT remapping region 1 |
| Additional 1GB DDR Space (user defined)                                                                               | 0xC000_0000 to 0xFFFF_FFFF                           | 0x9_0000_0000 to 0x9_3FFF_FFFF | Using RAT remapping region 2 |

In this example, only three RAT regions are needed:

- Region 0 is used to remap R5's address between 0x8000\_0000 to 0x9FFF\_FFFF to SoC level address 0x4\_0000\_0000 to 0x4\_1FFF\_FFFF
- Region 1 is used to remap R5's address between 0xA000\_0000 to 0xBFFF\_FFFF to 0x8000\_0000 to 0x9FFF\_FFFF
- Region 2 is used to remap R5's address 0xc000\_0000 to 0xFFFF\_FFFF to 0x9\_0000\_0000 to 0x9\_3FFF\_FFFF.

In order achieving those mappings, those are the setting of the RAT configuration registers:

|                                      | Region 0                   | Region 1                   | Region 2                 | Other regions |
|--------------------------------------|----------------------------|----------------------------|--------------------------|---------------|
| Region control register              | Enabled, size set to 512MB | Enabled, size set to 512MB | Enabled, size set to 1GB | disabled      |
| Region base(32b)                     | 0x8000_0000                | 0xA000_0000                | 0xc000_0000              | Don't care    |
| Region translated lower address(32b) | 0x0000_0000                | 0x8000_0000                | 0x0000_0000              | Don't care    |
| Region translated upper address      | 0x4                        | 0x0                        | 0x9                      | Don't care    |

[Figure 7-15](#) shows how RAT is remapping the address between R5's 32b address to 36b SoC address.


**Figure 7-15. RAT Configuration Example**

### 7.3.2.8 MCU\_M4FSS ECC Support

The MCU\_M4FSS includes an ECC aggregator module that combines ECC errors from various local sources, such as RAMs, interconnects and bridges. **Table 7-30** provides the mapping of ECC errors within the MCU\_M4FSS ECC aggregator. Two separate interrupts are generated for ECC error: correctable and non-correctable.

The full ECC aggregator functionality is described in *ECC Aggregator*.

**Table 7-30. "Fault Detected" Interrupt Mapping for MCU\_M4FSS ECC Aggregator**

| Interrupt Number (RAM ID) | Source                                                                       |
|---------------------------|------------------------------------------------------------------------------|
| 0                         | lram_ramecc_pend                                                             |
| 1                         | dram_ramecc_pend                                                             |
| 2                         | lram_busecc_pend                                                             |
| 3                         | dram_busecc_pend                                                             |
| 4                         | blazar_rat_edc_ctrl_busecc_pend                                              |
| 5                         | blazar_cbass_vbusp_s_p2p_bridge_vbusp_s_bridge_busecc_pend                   |
| 6                         | blazar_cbass_lecc_s_p2p_bridge_lecc_s_bridge_busecc_pend                     |
| 7                         | blazar_cbass_blazar_scr_scr_blazar_cbass_blazar_scr_scr_edc_ctrl_busecc_pend |
| 8                         | blazar_cbass_vbus_clk_edc_ctrl_cbass_int_vbus_busecc_pend                    |
| 9                         | blazar_sys_scr_vbus_clk_edc_ctrl_cbass_int_vbus_busecc_pend                  |
| 10                        | blazar_la2v_i_edc_ctrl_busecc                                                |
| 11                        | blazar_la2v_d_edc_ctrl_busecc                                                |
| 12                        | blazar_la2v_s_edc_ctrl_busecc                                                |

### 7.3.2.9 MCU\_M4FSS Interrupts

See specific integration chapter.

### 7.3.2.10 MCU\_M4FSS Debug and Trace

The MCU\_M4FSS supports the following debug and trace features:

- Full debug, including data matching for watchpoint generation
- Full trace, including ITM, ETM and DWT
  - HTM port is not present
  - TPIU is not present
- DAP interface
- ITM and ETM interfaces
- CTM crossbar to map CTI triggers to CTM channels through a CS\_CTI module
- Debug infrastructure is reset with POR reset

### 7.3.2.11 MCU\_M4FSS Time Sync

The MCU\_M4FSS supports a 48-bit input interface for synchronizing to the global time counter (GTC). The 48-bit timestamp can be appended with ITM messages. Timestamping is a mechanism whereby a global timestamp value is periodically inserted at strategic locations into the trace stream. Timestamps can be used to correlate trace from various sources. Each trace source samples the timestamp value and inserts it as an absolute value into the trace stream.

The global timestamp value coming to the MCU\_M4FSS is gray-encoded. It is then internally converted to its binary value.

For more details on the device time synchronization, refer to the following sections:

- *Global Timebase Counter (GTC)*

- *Time Sync*

#### 7.3.2.12 MCU\_M4FSS SysTick

The MCU\_M4FSS includes a 24-bit count-down system timer (SysTick) that can be used as a real time operating system (RTOS) tick timer or as a simple counter. The MCU\_M4FSS\_SYSTICK register in the MCU\_CTRL\_MMR module provides the calibration settings required for proper SysTick operation.

#### 7.3.2.13 MCU\_M4FSS Initialization

The MCU\_M4FSS has a local reset input. This input is driven by PSC, but controlled by software (PSC MMRs, with programmable default state). This local reset resets just the M4F processor. When the PSC (controlled by software) brings the MCU\_M4FSS out of reset, the M4F CPU is held in reset through this local reset, but everything else will be running (except debug logic). This allows to pre-load the RAMs in the MCU\_M4FSS. Software then releases the local reset and M4F starts executing the pre-loaded code in the RAMs.

Software can repeat the initialization process over and over by following these steps:

1. Execute WFI instruction
2. Transition MCU\_M4FSS to a DISABLE/OFF state through PSC (PSC will wait for MCU\_M4FSS to be IDLE which includes MCU\_M4FSS asserting WFI)
3. Transition MCU\_M4FSS to an ENABLE/ON state through PSC (local reset will be held asserted)
4. Pre-load RAMs
5. Release local reset

## 7.4 Programmable Real-Time Unit Subsystem (PRUSS)

This section describes the Programmable Real-Time Unit Subsystem in the device.

---

### Note

The supported set of features and peripherals is device part number dependent. For more information, see the device datasheet.

---

---

### Note

The PRU Subsystem (PRUSS) is a subset of the PRU Industrial Communication Subsystem (PRU-ICSS) found on other TI processors. The superset names "PRU-ICSS", and "ICSSM" are used in some parts of the TRM to refer to the PRU Subsystem. Reference the PRU-ICSS Module Integration section for information about PRU-ICSS features that are unsupported in PRU-ICSS.

---

### 7.4.1 PRUSS Overview

The Programmable Real-Time Unit Subsystem (PRUSS) consists of:

- Two 32-bit load/store RISC CPU cores — Programmable Real-Time Units (PRU0 and PRU1)
- Data RAMs per PRU core (DRAM)
- Instruction RAMs per PRU core (IRAM)
- Shared RAM (SRAM)
- Peripheral modules: UART0, ECAP0, IEP0, MDIO
- Interrupt Controller (INTC) per core

The programmable nature of the PRU cores, along with their access to pins, events and all device resources, provides flexibility in implementing fast real-time responses, specialized data handling operations, custom peripheral interfaces, and in offloading tasks from the other processor cores of the device.

The PRU cores are programmed with a small, deterministic instruction set. Each PRU can operate independently or in coordination with each other and can also work in coordination with the device-level host CPU. This interaction between processors is determined by the nature of the firmware loaded into the PRU's instruction memory.

#### 7.4.1.1 PRUSS Key Features

The PRUSS subsystem includes the following main features:

- Two 32-bit load/store RISC CPU cores — Programmable Real-Time Units (PRU0 and PRU1), each with:
  - 20 Enhanced General-Purpose Inputs (EGPI) and 20 Enhanced General-Purpose Outputs (EGPO)
  - Asynchronous capture [Serial Capture Unit (SCU)] with 3-channel peripheral interface and Sigma-Delta demodulation support
    - The 3-channel peripheral interface supports multiple different encoder protocols such as EnDAT 2.2, HDSL, and Tamagawa.
  - program memory per PRU (PRU0\_IRAM and PRU1\_IRAM) with ECC
  - MAC (Multiplier with optional Accumulation)
  - CRC16/CRC32 hardware accelerator
  - RX XFR2VBUS
- Scratchpad Memory (SPAD) with 3 banks of  $30 \times 32$ -bit registers:
  - 3 banks for the PRU0 and PRU1 cores
- 32 KB Shared general purpose memory RAM with ECC (Data RAM2), shared between PRU0 and PRU1
- Two 8 KB (shared) Data Memories with ECC (Data RAM0 and Data RAM1)
- 36-bit VBUSM Controller Port:
  - Optional address translation for all transactions to External Host
- 16 Software Events generated by 2 PRUs
- One Enhanced Capture Module (ECAP0)

- Interrupt Controller (INTC)
  - Up to 32 internal events, generated by modules, internal to the PRUSS
  - Up to 32 external events, generated by the system
  - Supports up to 10 interrupt channels
  - Generation of 8 Host interrupts:
    - 8 Host interrupts, exported from the PRUSS for signaling the Arm interrupt controllers (pulse and level provided)
  - Each system event can be enabled and disabled
  - Each host event can be enabled and disabled
  - Hardware prioritization of events
- One 32-bit VBUSP target port for memory mapped register and internal memories access
- Flexible power management support
- Integrated 32-bit Interconnect

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

## 7.4.2 PRUSS Environment

This section describes the PRUSS external connections (environment).

### 7.4.2.1 PRUSS Internal Pinmux

The PRUSS external interface signals are described in [Table 7-31](#). The PRUSS has a large number of available I/O signals. Most of these are multiplexed with other functional signals at the device level.

The PRUSS also support an internal wrapper multiplexing that expands the device top-level multiplexing. This wrapper multiplexing is controlled by the GPCFGx\_REG register (where  $x = 0$  or  $1$ ) in the PRUSS CFG register space and allows MII\_RT, 3 channel Peripheral Interface (with EnDAT capabilities), and Sigma Delta functionality to be muxed with the PRU GPIO device signals, as shown in [Figure 7-16](#). The PRUSS wrapper multiplexing is described with the device-level signals in [Table 7-31](#). Note that the device top-level muxing has higher priority over the internal PRUSS muxing.



1.  $n$  represents a valid instance of PRU in a domain.

**Figure 7-16. PRUSS Internal Wrapper Multiplexing**

#### Note

Additionally to PRUSS wrapper multiplexing the device I/O logic maps the PRUSS signals to the different device pins by programming the associated IOMUX CTRLMMR register.



**Figure 7-17. PRU-ICSS External Interface I/Os**

### PRUSS I/O Signals

Table 7-31 describes the PRUSS< k> I/O signals.

< k> is the number of PRUSS in the device. See the Data sheet for additional details.

**Table 7-31. PRUSS I/O Signals**

| Device Level Signal                             | Alternate Function via Internal Multiplexing | I/O <sup>(1)</sup>        | Description   | Pin Reset <sup>(2)</sup> |
|-------------------------------------------------|----------------------------------------------|---------------------------|---------------|--------------------------|
| ICSS_GPCFG0_REG[29-26] PR< k>_PRU0_GP_MUX_SEL = |                                              |                           |               |                          |
| PRU0 GP Signals                                 | 0h - GPIO mode (default)                     | 1h - PERIF mode           | 2h - MII mode | 3h - SD mode             |
| PR0_PRU0_GPO0                                   | pr< k>_pru0_pru_r30_out[0]                   | pr< k>_pru0_perif0_clk    |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO1                                   | pr< k>_pru0_pru_r30_out[1]                   | pr< k>_pru0_perif0_out    |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO2                                   | pr< k>_pru0_pru_r30_out[2]                   | pr< k>_pru0_perif0_out_en |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO3                                   | pr< k>_pru0_pru_r30_out[3]                   | pr< k>_pru0_perif1_clk    |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO4                                   | pr< k>_pru0_pru_r30_out[4]                   | pr< k>_pru0_perif1_out    |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO5                                   | pr< k>_pru0_pru_r30_out[5]                   | pr< k>_pru0_perif1_out_en |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO6                                   | pr< k>_pru0_pru_r30_out[6]                   | pr< k>_pru0_perif2_clk    |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO7                                   | pr< k>_pru0_pru_r30_out[7]                   | pr< k>_pru0_perif2_out    |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO8                                   | pr< k>_pru0_pru_r30_out[8]                   | pr< k>_pru0_perif2_out_en |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO9                                   | pr< k>_pru0_pru_r30_out[9]                   |                           |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO10                                  | pr< k>_pru0_pru_r30_out[10]                  | pr< k>_mii_txdf0[3]       |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO11                                  | pr< k>_pru0_pru_r30_out[11]                  | pr< k>_mii_txdf1[3]       |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO12                                  | pr< k>_pru0_pru_r30_out[12]                  | pr< k>_mii_txdf11[3]      |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO13                                  | pr< k>_pru0_pru_r30_out[13]                  | pr< k>_mii_txdf2[3]       |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO14                                  | pr< k>_pru0_pru_r30_out[14]                  | pr< k>_mii_txdf3[3]       |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO15                                  | pr< k>_pru0_pru_r30_out[15]                  | pr< k>_mii_txen[3]        |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO16                                  | pr< k>_pru0_pru_r30_out[16]                  |                           |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO17                                  | pr< k>_pru0_pru_r30_out[17]                  |                           |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO18                                  | pr< k>_pru0_pru_r30_out[18]                  |                           |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO19                                  | pr< k>_pru0_pru_r30_out[19]                  |                           |               | PRU0 R30 Outputs 0       |
| PR0_PRU0_GPO10                                  | pr< k>_pru0_pru_r31_in[0]                    | pr< k>_pru0_sdo_0k        |               | PRU0 R31 Inputs HiZ      |
| PR0_PRU0_GPO11                                  | pr< k>_pru0_pru_r31_in[1]                    | pr< k>_pru0_sdo_d         |               | PRU0 R31 Inputs HiZ      |
| PR0_PRU0_GPO12                                  | pr< k>_pru0_pru_r31_in[2]                    | pr< k>_pru0_sd1_clk       |               | PRU0 R31 Inputs HiZ      |
| PR0_PRU0_GPO13                                  | pr< k>_pru0_pru_r31_in[3]                    | pr< k>_pru0_sd1_d         |               | PRU0 R31 Inputs HiZ      |
| PR0_PRU0_GPO14                                  | pr< k>_pru0_pru_r31_in[4]                    | pr< k>_pru0_sd2_clk       |               | PRU0 R31 Inputs HiZ      |
| PR0_PRU0_GPO15                                  | pr< k>_pru0_pru_r31_in[5]                    | pr< k>_pru0_sd2_d         |               | PRU0 R31 Inputs HiZ      |

**Table 7-31. PRUSS I/O Signals (continued)**

| Device Level Signal | Alternate Function via Internal Multiplexing | I/O <sup>(1)</sup>                           | Description     | Pin Reset <sup>(2)</sup> |
|---------------------|----------------------------------------------|----------------------------------------------|-----------------|--------------------------|
| PR0_PRU0_GPI6       | pr<k>_pru0_pru_r31_in[6]                     | pr<k>_mii_mru0_clk                           | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI7       | pr<k>_pru0_pru_r31_in[7]                     | pr<k>_pru0_sd3_d                             | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI8       | pr<k>_pru0_pru_r31_in[8]                     | pr<k>_pru0_txlink                            | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI9       | pr<k>_pru0_pru_r31_in[9]                     | pr<k>_mii0_col                               | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI10      | pr<k>_pru0_pru_r31_in[10]                    | pr<k>_mii0_crs                               | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI11      | pr<k>_pru0_pru_r31_in[11]                    | pr<k>_pru0_perif1_in                         | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI12      | pr<k>_pru0_pru_r31_in[12]                    | pr<k>_pru0_perif2_in                         | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI13      | pr<k>_pru0_pru_r31_in[13]                    | pr<k>_pru0_pru_r31_in[12]                    | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI14      | pr<k>_pru0_pru_r31_in[14]                    | pr<k>_pru0_pru_r31_in[13]                    | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI15      | pr<k>_pru0_pru_r31_in[15]                    | pr<k>_pru0_pru_r31_in[14]                    | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI16      | pr<k>_pru0_pru_r31_in[16]                    | pr<k>_mii_mt1_clk, pr<k>_pru0_pru_r31_in[16] | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI17      | pr<k>_pru0_pru_r31_in[17]                    | pr<k>_pru0_sd8_d                             | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI18      | pr<k>_pru0_pru_r31_in[18]                    | pr<k>_pru0_sd7_d                             | PRU0_R31 Inputs | HiZ                      |
| PR0_PRU0_GPI19      | pr<k>_pru0_pru_r31_in[19]                    | pr<k>_pru0_pru_r31_in[18]                    | PRU0_R31 Inputs | HiZ                      |
| PRU1 GP Signals     | ICSS_GPCFG1_REG[29:26] PR0_PRU1_GP_MUX_SEL = |                                              |                 |                          |
|                     | 0h - GPIO mode (default)                     | 1h - PERIF mode                              | 2h - MII mode   | 3h - SD mode             |
| PR0_PRU1_GPO0       | pr<k>_pru1_pru_r30_out[0]                    | pr<k>_pru1_perif0_clk                        |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO1       | pr<k>_pru1_pru_r30_out[1]                    | pr<k>_pru1_perif0_out                        |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO2       | pr<k>_pru1_pru_r30_out[2]                    | pr<k>_pru1_perif0_out_en                     |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO3       | pr<k>_pru1_pru_r30_out[3]                    | pr<k>_pru1_perif1_clk                        |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO4       | pr<k>_pru1_pru_r30_out[4]                    | pr<k>_pru1_perif1_out                        |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO5       | pr<k>_pru1_pru_r30_out[5]                    | pr<k>_pru1_perif1_out_en                     |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO6       | pr<k>_pru1_pru_r30_out[6]                    | pr<k>_pru1_perif2_clk                        |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO7       | pr<k>_pru1_pru_r30_out[7]                    | pr<k>_pru1_perif2_out                        |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO8       | pr<k>_pru1_pru_r30_out[8]                    | pr<k>_pru1_perif2_out_en                     |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO9       | pr<k>_pru1_pru_r30_out[9]                    |                                              |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO10      | pr<k>_pru1_pru_r30_out[10]                   |                                              |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO11      | pr<k>_pru1_pru_r30_out[11]                   | pr<k>_mii0_txd0[3]                           |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO12      | pr<k>_pru1_pru_r30_out[12]                   | pr<k>_mii0_txd1[3]                           |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO13      | pr<k>_pru1_pru_r30_out[13]                   | pr<k>_mii0_txd2[3]                           |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO14      | pr<k>_pru1_pru_r30_out[14]                   | pr<k>_mii0_txd3[3]                           |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO15      | pr<k>_pru1_pru_r30_out[15]                   | pr<k>_mii0_txen[3]                           |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO16      | pr<k>_pru1_pru_r30_out[16]                   |                                              |                 | 0 PRU1_R30 Outputs       |
| PR0_PRU1_GPO17      | pr<k>_pru1_pru_r30_out[17]                   |                                              |                 | 0 PRU1_R30 Outputs       |

**Table 7-31. PRUSS I/O Signals (continued)**

| Device Level Signal               | Alternate Function via Internal Multiplexing | I/O <sup>(1)</sup>        | Description                     | Pin Reset <sup>(2)</sup> |
|-----------------------------------|----------------------------------------------|---------------------------|---------------------------------|--------------------------|
| PR0_PRU1_GPO18                    | pr<k>_pru1_pru_i30_out[18]                   | 0                         | PRU1 R30 Outputs                | 0                        |
| PR0_PRU1_GPO19                    | pr<k>_pru1_pru_i30_out[19]                   | 0                         | PRU1 R30 Outputs                | 0                        |
| PR0_PRU1_GPIO0                    | pr<k>_pru1_pru_i31_in[0]                     | pr<k>_mii_rxdf[0]         | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO1                    | pr<k>_pru1_pru_i31_in[1]                     | pr<k>_mii_rxdf[1]         | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO2                    | pr<k>_pru1_pru_i31_in[2]                     | pr<k>_mii_rxdf[2]         | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO3                    | pr<k>_pru1_pru_i31_in[3]                     | pr<k>_mii_rxdf[3]         | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO4                    | pr<k>_pru1_pru_i31_in[4]                     | pr<k>_mii_rxdv            | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO5                    | pr<k>_pru1_pru_i31_in[5]                     | pr<k>_mii_rxer            | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO6                    | pr<k>_pru1_pru_i31_in[6]                     | pr<k>_mii_mr1_clk         | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO7                    | pr<k>_pru1_pru_i31_in[7]                     | pr<k>_mii_sd3_d           | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO8                    | pr<k>_pru1_pru_i31_in[8]                     | pr<k>_mii_rxlink          | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO9                    | pr<k>_pru1_pru_i31_in[9]                     | pr<k>_mii_col             | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO10                   | pr<k>_pru1_pru_i31_in[10]                    | pr<k>_mii_crs             | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO11                   | pr<k>_pru1_pru_i31_in[11]                    | pr<k>_pru1_perif2_in      | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO12                   | pr<k>_pru1_pru_i31_in[12]                    | pr<k>_pru1_sd4_d          | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO13                   | pr<k>_pru1_pru_i31_in[13]                    | pr<k>_pru1_sd5_dlk        | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO14                   | pr<k>_pru1_pru_i31_in[14]                    | pr<k>_pru1_sd5_d          | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO15                   | pr<k>_pru1_pru_i31_in[15]                    | pr<k>_pru1_sd6_dlk        | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO16                   | pr<k>_pru1_pru_i31_in[16]                    | pr<k>_pru1_pru_i31_in[16] | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO17                   | pr<k>_pru1_pru_i31_in[17]                    | pr<k>_pru1_sd6_d          | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO18                   | pr<k>_pru1_pru_i31_in[18]                    | pr<k>_pru1_sd7_dlk        | PRU1 R31 Inputs                 | HiZ                      |
| PR0_PRU1_GPIO19                   | pr<k>_pru1_pru_i31_in[19]                    | pr<k>_pru1_sd7_d          | PRU1 R31 Inputs                 | HiZ                      |
| MDIO                              |                                              |                           |                                 |                          |
| PR0_MDIO0_MDC                     | pr<k>_mdio_mdclk                             | 0                         | MDIO Clock                      | 0                        |
| PR0_MDIO0_MDO                     | pr<k>_mdio_data                              | I/O                       | MDIO Data                       | HiZ                      |
| Industrial Ethernet (IEP0)        | Industrial Ethernet                          |                           |                                 |                          |
| PR0_IEPO_EDIO_OUTVALID            | pr<k>_lepo_edio_outvalid                     | 0                         | IEPO Digital I/O Output Valid   | 0                        |
| PR0_IEPO_EDIO_DATA_IN_OU_T[31:28] | pr<k>_lepo_edio_data_in_out[31:28]           | I/O                       | IEPO Digital I/O Data In/Out    | HiZ                      |
| PR0_IEPO_EDC_SYNC_OUT0            | pr<k>_lepo_edc_sync_out0                     | 0                         | IEPO Distributed Clock Sync Out | 0                        |
| PR0_IEPO_EDC_SYNC_OUT1            | pr<k>_lepo_edc_sync_out1                     | 0                         | IEPO Distributed Clock Sync Out | 0                        |
| PR0_IEPO_EDC_LATCH_IN0            | pr<k>_lepo_edc_latch_in0                     | 1                         | IEPO Distributed Clock Latch In | HiZ                      |

**Table 7-31. PRUSS I/O Signals (continued)**

| Device Level Signal    | Alternate Function via Internal Multiplexing | I/O <sup>(1)</sup> | Description                                         | Pin Reset <sup>(2)</sup> |
|------------------------|----------------------------------------------|--------------------|-----------------------------------------------------|--------------------------|
| PRO_IEP0_EDC_LATCH_IN1 | pr<k>_iep0_edc_latch_in1                     |                    |                                                     |                          |
| UART0                  | UART0                                        |                    |                                                     |                          |
| PRO_UART0_CTSn         | pr<k>_uart0_cts_n                            | I                  | UART0 Clear to Send                                 | HiZ                      |
| PRO_UART0_RTn          | pr<k>_uart0_rts_n                            | O                  | UART0 Request to Send                               | 1                        |
| PRO_UART0_RXD          | pr<k>_uart0_rxd                              | I                  | UART0 Receive Data                                  | HiZ                      |
| PRO_UART0_TXD          | pr<k>_uart0_txd                              | O                  | UART0 Transmit Data                                 | 1                        |
| ECAP0                  | ECAP0                                        |                    |                                                     |                          |
| PRO_ECAP0_IN_APWM_OUT  | pr<k>_ecap0_ecap_capin_apwm_o                | I/O                | Enhanced capture (ECAP0) input or Auxiliary PWM out | HiZ                      |
| PRO_ECAP0_SYNC_IN      | pr<k>_ecap0_ecap_syncin                      | I                  | Enhanced capture (ECAP0) Sync In                    | 0                        |
| PRO_ECAP0_SYNC_OUT     | pr<k>_ecap0_ecap_syncout                     | O                  | Enhanced capture (ECAP0) Sync Out                   | 0                        |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) The PRU internal pinmux mapping provided in the TRM is part of the original hardware definition of the PRU. However, due to the flexibility provided by the IP and associated firmware configurations, this is not necessarily a hard requirement. The first PRU implementation for AM65x had the MII TX pins swapped during initial SoC integration and this convention was maintained for subsequent PRU revisions to enable firmware reuse. To make use of the SDK firmware, use the SYSCONFIG generated PRU pin mapping.

#### 7.4.2.2 PRUSS Fast GPIO pins

Each PRUSS PRU processor implements fast general purpose outputs (GPO) through its R30 register and fast general purpose inputs (GPI) through its R31 register. The device multiplexes all GPI signals and their corresponding GPO signals onto the same device pin using different device multiplexing modes. In some applications it may be necessary for the PRU to switch between GPO and GPI operation in a fast (or at least a deterministic) manner. This is not possible using SoC level pin muxing since each pin being switched requires a write to a separate pin configuration register located in Control Module (CTRL\_MMRO).

In order to address the fast switching issue, special I/O pin connectivity for the PRUSS GPO/GPI pins is implemented. This feature makes use of the IEP EDIO signal controls to provide input/output switching using a single SoC level pin multiplexing mode.

The IEP EDIO interface has 32 data input (DATA\_IN) and 32 data output (DATA\_OUT) signals. It also has a set of 32 corresponding data output enable (DATA\_OUT\_EN) signals to be used as (active low) output driver enables to allow each DATA\_OUT/DATA\_IN to be implemented as a bidirectional pin. On this device, only 4 of the IEP EDIO I/Os of each PRUSS module are pinned out (PRG[2:0]\_IEP\_EDIO\_DATA\_IN\_OUT[31:28]). This leaves a majority of the DATA\_OUT\_EN signals unused. The device allows these unused output enables to be optionally re-purposed for use as GPO enables. This allows each PRUSS GP pin to function as either a GPO or as a GPI when the I/O pin is configured for the GPO muxmode.

A set of SoC level registers (CTRLMMR\_ICSS[2:0]\_CTRL[2:0]) are used to determine the behavior of each GPO mode pin. When a register's [19-0]GPM\_BIDI bit field is set to 0h (default value), the corresponding GPO pin operates only as an output when the GPO multiplexing mode is selected and is driven with the R30 bit value. The corresponding GPI signal (PRUSS GPI<n> input, where n = 0 to 19) is driven low. When a register's [19-0]GPM\_BIDI bit field is set to 1h, the corresponding ICSS\_DIGIO\_DATA\_OUT\_EN\_REG[31-0] DATA\_OUT\_EN bit field is used to control the GPO output buffer. If [31-0] DATA\_OUT\_EN bit field is set to 0h the output is driven and the pin acts as a GPO. If [31-0] DATA\_OUT\_EN bit field is set to 1h the output is disabled and the pin acts as a GPI.

The PRU[1:0]\_GPM[19:0] output signals are propagated to the PRG\_PRU[1:0]\_GPO[19:0] pins using Muxmode 0 function and the PRU[1:0]\_GPN[19:0] input signals are propagated to the PRG\_PRU[1:0]\_GPI[19:0] pins using Muxmode 1 function. Any GPO (Muxmode 0 function) can be made bidirectional by setting the corresponding bit field [19-0]GPM\_BIDI in CTRLMMR\_ICSS\_CTRL[2:0] register.

### 7.4.3 PRUSS Top Level Resources Functional Description

This section provides functional description of the device integrated PRU Subsystems modules.

The PRU<sub>n</sub> (where n = 0 or 1) cores within each PRUSS have access to all resources on the SoC through the VBUSM Interface Controller port, and the external host processors can access the PRUSS resources through the VBUSP Interface Target port. The use of XFR2VBUS allows BroadSide 32Bytes of data transfer to/from SoC CBASS0 Interconnect at 256-bit bursts using the VBUSM Controller port. The 32-bit Internal CBASS Interconnect bus will be the primary interconnect between all components internal to the PRUSS. There are two equally symmetrical halves in each PRUSS known as SLICE0 and SLICE1. Each slice will share several resources while capable of working independently of each other. There are two sets of XFR2VBUS for each Slice. PRUs also has the ability to submit 32-bit bursts transitions, but this will require RAT configuration.

Each of the Slices contains one RAT (Region based Address Translation) module. The RAT module is used to translate 32-bit address of the PRU core to 48-bit physical address.

The PRU cores within the subsystems also have access to all resources on the SoC through the External CBASS0 Interconnect. A subsystem local Interrupt Controller — INTC handles system input events and posts events back to the device-level host CPUs.

Figure 7-18 shows an overview of the PRUSS Functional Block Diagram.

**Figure 7-18. PRUSS Functional Block Diagram**

Table 7-32 summarizes the mapping between hardware modules and PRU0/1 cores.

**Table 7-32. Hardware Module Broadside ID Mapping**

| Hardware Module | Broadside ID                                                             |                                                                    |
|-----------------|--------------------------------------------------------------------------|--------------------------------------------------------------------|
| MPY/MAC         | 00                                                                       | 2 copies:<br>PRU1/0                                                |
| CRC16/32        | 01                                                                       | 2 copies:<br>PRU1/0                                                |
| SPAD Bank0      | 10                                                                       | shared between PRU1/0                                              |
| SPAD Bank1      | 11                                                                       | shared between PRU1/0                                              |
| SPAD Bank2      | 12                                                                       | shared between PRU1/0                                              |
| RX L2           | 20/21                                                                    | 2 copies:<br>PRU1/0                                                |
| TX L2           | 40                                                                       | 2 copies:<br>PRU1/0                                                |
| XFR2VBUSP       | 0x60 for RD_ID0<br>0x61 for RD_ID1<br>0x62 for WD_ID0<br>0x63 for WD_ID1 | 2 copies shared of RX per SLICE<br>2 copies shared of TX per SLICE |

#### 7.4.3.1 PRUSS Reset Management

The device supports warm reset isolation (Hard/Soft Reset, Watchdog Reset) on PRUSS.

#### 7.4.3.2 PRUSS Power and Clock Management

The PRUSS supports two levels of clock gating. First level gates all clocks inside the PRUSS when requested by the . The second level allows user software to enable/disable clocks in the clock gating register ICSS\_CGR\_REG to some internal modules, as follows:

- IEP
- ECAP0
- UART0
- INTC

The appropriate configuration registers block controls its local module set inside PRUSS.

#### 7.4.3.2.1 PRUSS CORE Clock Generation



**Figure 7-19. PRU-ICSS Clock Diagram**

The CORE, BUS, and IEP Clock all use the 200 MHz SYS\_CLK as a source clock. The UART clock is configurable by configuring the UART clock source select register as well as the UART clock divider value register. Each of these clock sources has a configurable clock gate that can be configured with the appropriate clock gate register

#### 7.4.3.2.2 PRUSS Idle State

The below lists the clock management settings applicable at PRUSS subsystem level (first level of local power management).

A transition from an ACTIVE/Normal state to an IDLE state is performed as per the sequence:

1. The host processor requests that the PRU firmware goes into IDLE state and waits for acknowledgement.
2. The host issues Clock Stop Request for each module in the PRU\_ICSS\_CGR register with gateable clocks defined at second power management level (see [Section 7.4.3.2](#))
3. The PRUSS acknowledges IDLE Request and send Clock Stop Acknowledge to the host processor.
4. The PSC can de-assert PWR\_CLK\_EN
5. The main clocks can get turned off

A transition from an IDLE state to an ACTIVE/ Normal state is performed as per the sequence:

1. Turn on the main external clocks
2. The PSC can assert PWR\_CLK\_EN
3. The host will need to de-assert Clock Stop Request for each module, defined in PRU\_ICSS\_CGR register,
4. The PRUSS firmware need to de-assert Clock Stop Acknowledge for each module defined in PRU\_ICSS\_CGR register and then wait for the Clock Stop Acknowledge de-assert

## 5. The PRUSS firmware will de-assert Clock Stop Acknowledge

### 7.4.3.2.3 PRUSS Protect

Write protect block allows software to enable safety protection to prevent corruption of key configuration and debug registers and the Instruction memories (IRAM's) of all PRU cores (PRU0/PRU1). Write protection is also supported for Data RAM0 and Data RAM1.

This is achieved by blocking the byte enables during a write transaction if enabled. When enabled, it will prevent any unwanted write transaction to these elements. To Enable/Disable this feature, software will first need to unlock the write access to this block through the PROT\_UNLOCK\_KEY register then configure the protection through PROT\_CFG register and relock.

### 7.4.3.2.4 Module Clock Configurations at PRUSS Top Level

**IEP functional clock source selection:** The clock source selection to the IEP module is done in register CTRLMMR\_PRU\_ICSS\_CLKSEL[19-16] IEP\_CLKSEL (where n = 0 or 1) in the CTRL\_MMR0 location. For more information on these PRUSS level input clocks, refer to the *PRUSS Integration*.

**Enhanced GPIO clock divider settings:** In certain sample/shift clock settings of the PRU0 and PRU1 EGPIOS (when enabled in serial mode) two cascaded fractional dividers are done in the PRU\_ICSS\_CFG top level configuration registers PRU\_ICSS\_GPCFG0 and PRU\_ICSS\_GPCFG1. In addition, EGPIO clock active edge selection control can be exerted via the bit PRU0\_GPI\_CLK\_MODE for PRU0 EGPIO and PRU1\_GPI\_CLK\_MODE for the PRU1 EGPIO.

- For the serial PRU0's EGPOs:
  - PRU\_ICSSM\_GPCFG0\_REG[24-20] PRU0\_GPO\_DIV1
  - PRU\_ICSSM\_GPCFG0\_REG[19-15] PRU0\_GPO\_DIV0
- For the serial PRU0's EGPIs:
  - PRU\_ICSSM\_GPCFG0\_REG[12-8] PRU0\_GPI\_DIV1
  - PRU\_ICSSM\_GPCFG0\_REG[7-3] PRU0\_GPI\_DIV0
- For the serial PRU1's EGPOs:
  - PRU\_ICSSM\_GPCFG1\_REG[24-20] PRU1\_GPO\_DIV1
  - PRU\_ICSSM\_GPCFG1\_REG[19-15] PRU1\_GPO\_DIV0
- For the serial PRU1's EGPIs:
  - PRU\_ICSSM\_GPCFG1\_REG[12-8] PRU1\_GPI\_DIV1
  - PRU\_ICSSM\_GPCFG1\_REG[7-3] PRU1\_GPI\_DIV0

### 7.4.3.3 Other PRUSS Module Functional Registers at Subsystem Level

**Enhanced GPIO.** The other functional mode setting for PRUs EGPIOS at PRUSS top registers level are:

- PRU\_ICSSM\_GPCFG0 / PRU\_ICSSM\_GPCFG1[14] PRU0\_GPO\_MODE (PRU0 or PRU1) — to select between direct or serial EGPO output mode of operation.
- PRU\_ICSSM\_GPCFG0 / PRU\_ICSSM\_GPCFG1[25] PRU0\_GPO\_SH\_SEL (PRU0 or PRU1) — to select between the EGPO shadow registers 0 and 1 used for output shifting. For more details, refer to the [Section 7.4.4.2.2.3.4, Enhanced General-Purpose Module Outputs \(R30\)](#).
- PRU\_ICSSM\_GPCFG0 / PRU\_ICSSM\_GPCFG1[1-0] PRU0\_GPI\_MODE (PRU0 or PRU1) — selects the EGPI input mode of operation ( selects between "direct input", "parallel capture", "28-bit shift" or "MII\_RT" modes).
- PRU\_ICSSM\_GPCFG0 / PRU\_ICSSM\_GPCFG1[13] PRU0\_GPI\_SB (PRU0 or PRU1) — start bit event status for 28-bit EGPI input shift mode. For more details, refer to the [Section 7.4.4.2.2.3, Enhanced General-Purpose Module Inputs \(R31\)](#).

### 7.4.3.4 PRUSS Memory Maps

The PRUSS comprises various distinct addressable regions that are mapped to both a local and global memory map. The local memory maps are maps with respect to the PRU point of view. The global memory maps are maps with respect to the Host point of view, but can also be accessed by the PRUSS. Each PRUSS can also

access the memories within the other PRUSS subsystem without going through an external port, thanks to PRUSS VBUSP expansion port.

#### 7.4.3.4.1 PRUSS Local Memory Map

The PRUSS memory map is documented in [Table 7-33](#) (Instruction Space) and in [Table 7-34](#) (Data Space). Note that these two memory maps are implemented inside the PRUSS and are local to the components of the PRUSS.

##### 7.4.3.4.1.1 PRUSS Local Instruction Memory Map

Each PRU (PRU0 and PRU1) has a dedicated 16KB of Instruction Memory (16KB for PRUSS) which needs to be initialized by an external to PRUSS Host processor before a PRU core executes any instructions.

**CAUTION**

The PRUSS PRU0/1\_IRAM regions are ONLY accessible from controllers, external to the PRUSS (like Arm) when the PRU0/PRU1 is NOT running. The access is via PRUSS target port on the device CBASS0 interconnect.

**Table 7-33. PRUSS Local Instruction Memory Map**

| Start Address | PRU0       | PRU1       |
|---------------|------------|------------|
| 0000 0000h    | 16 KB IRAM | 16 KB IRAM |

##### 7.4.3.4.1.2 PRUSS Local Data Memory Map

The local data memory map in [Table 7-34](#) allows each PRU core to access the PRUSS addressable regions (both its own subsystem and the other subsystem) and the external host's memory map.

**Table 7-34. PRUSS Local Data Memory Map**

| Start Address | PRU0                         | PRU1                         |
|---------------|------------------------------|------------------------------|
| 0000 0000h    | Data 8KB RAM0                | Data 8KB RAM1                |
| 0000 2000h    | Data 8KB RAM1                | Data 8KB RAM0                |
| 0000 8000h    | RAT_SLICE0                   | RAT_SLICE0                   |
| 0000 9000h    | RAT_SLICE1                   | RAT_SLICE1                   |
| 0001 0000h    | Data 32 KB RAM2 (Shared RAM) | Data 32 KB RAM2 (Shared RAM) |
| 0002 0000h    | INTC                         | INTC                         |
| 0002 2000h    | PRU0 Control                 | PRU0 Control                 |
| 0002 4000h    | PRU1 Control                 | PRU1 Control                 |
| 0002 4C00h    | PROTECT                      | PROTECT                      |
| 0002 6000h    | CFG                          | CFG                          |
| 0002 8000h    | UART0                        | UART0                        |
| 0002 E000h    | IEP0                         | IEP0                         |
| 0003 0000h    | ECAP0                        | ECAP0                        |
| 0003 2000h    | MII_RT_CFG                   | MII_RT_CFG                   |
| 0003 2400h    | MII_MDIO                     | MII_MDIO                     |
| 0003 3000h    | MII_G_RT_CFG                 | MII_G_RT_CFG                 |

##### 7.4.3.4.2 PRUSS Global Memory Map

The global view of the PRUSS internal memories and control ports is shown in [Table 7-35](#). The offset addresses of each region are implemented inside the PRUSS but the global device memory mapping places the PRUSS target port in the address range shown in the external PRUSS Host top-level memory map.

The global memory map is with respect to the Host point of view (that is, device Arm ), but it can also be accessed by the PRUSS itself. Note that PRU0 and PRU1 can use either the local or global addresses to access their internal memories, but using the local addresses provides access time several cycles faster than using the global addresses. This is because when accessing via the global address the access has to be routed through the CBASS0 switch fabric outside PRUSS and back in through the PRUSS target port.

Each of the PRU cores can access the rest of the device memory (including memory mapped peripheral and configuration registers) using the global memory space addresses.

**Table 7-35. PRUSS Global Memory Map**

| Offset Address | PRUSS Target             |
|----------------|--------------------------|
| 0000 0000h     | Data 8 KB RAM0           |
| 0000 2000h     | Data 8 KB RAM1           |
| 0000 8000h     | RAT_SLICE0               |
| 0000 9000h     | RAT_SLICE1               |
| 0001 0000h     | Data 32 KB RAM2 (shared) |
| 0002 0000h     | PRUSS INTC               |
| 0002 2000h     | PRU0 Control             |
| 0002 2400h     | PRU0 Debug               |
| 0002 4000h     | PRU1 Control             |
| 0002 4400h     | PRU1 Debug               |
| 0002 4C00h     | PROTECT                  |
| 0002 6000h     | PRUSS CFG                |
| 0002 8000h     | PRUSS UART0              |
| 0002 E000h     | IEP0                     |
| 0002 F000h     | Reserved                 |
| 0003 0000h     | ECAP0                    |
| 0003 2000h     | MII_RT_CFG               |
| 0003 2400h     | MII_MDIO                 |
| 0003 3000h     | MII_G_RT_CFG             |
| 0003 4000h     | PRU0 IRAM                |
| 0003 8000h     | PRU1 IRAM                |

#### 7.4.4 PRUSS PRU Cores

This section describes the functionality of the two Programmable Real-time Unit (PRU) processors (PRU0 and PRU1), integrated in the device PRUSS.

##### 7.4.4.1 PRU Cores Overview

The PRU is a processor optimized for performing embedded tasks that require manipulation of packed memory mapped data structures, handling of system events that have tight real-time constraints and interfacing with systems external to the SoC. The PRU is both very small and very efficient at handling such tasks.

The major attributes of the PRU are shown in [Table 7-36](#).

**Table 7-36. PRU Features**

| Attribute                                | Value                                                                                                                                                                                                                                                                  |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IO Architecture                          | Load/Store                                                                                                                                                                                                                                                             |
| Data Flow Architecture                   | Register to Register                                                                                                                                                                                                                                                   |
| <i>Core Level Bus Architecture</i>       |                                                                                                                                                                                                                                                                        |
| Type                                     | 4-Bus Harvard (1 Instruction, 3 Data)                                                                                                                                                                                                                                  |
| Instruction I/F                          | 32-Bit Modified VBUSP Controller                                                                                                                                                                                                                                       |
| Memory I/F 0                             | 32-Bit VBUSP Controller                                                                                                                                                                                                                                                |
| Memory I/F 1                             | 32-Bit VBUSP Controller                                                                                                                                                                                                                                                |
| <i>Execution Model</i>                   |                                                                                                                                                                                                                                                                        |
| Issue Type                               | Scalar                                                                                                                                                                                                                                                                 |
| Pipelining                               | None (Purposefully)                                                                                                                                                                                                                                                    |
| Ordering                                 | In Order                                                                                                                                                                                                                                                               |
| ALU Type                                 | Unsigned Integer                                                                                                                                                                                                                                                       |
| <i>Registers</i>                         |                                                                                                                                                                                                                                                                        |
| General Purpose (GP)                     | 30 (R1 – R30)                                                                                                                                                                                                                                                          |
| External Status                          | 0 (R31)                                                                                                                                                                                                                                                                |
| GP/Indexing                              | 0 (R0)                                                                                                                                                                                                                                                                 |
| Addressability in Instruction            | Bit, Byte (8-bit), Half-word (16-bit), Word (32-bit), Pointer                                                                                                                                                                                                          |
| <i>Addressing Modes</i>                  |                                                                                                                                                                                                                                                                        |
| Load Immediate                           | 16-bit Immediate                                                                                                                                                                                                                                                       |
| Load/Store – Memory                      | Register Base + Register Offset<br>Register Base + 8-bit Immediate Offset<br>Register Base with auto increment/decrement<br>Constant Table Base + Register Offset<br>Constant Table Base + 8-bit Immediate Offset<br>Constant Table Base with auto increment/decrement |
| Data Path Width                          | 32-bit                                                                                                                                                                                                                                                                 |
| Instruction Width                        | 32-bit                                                                                                                                                                                                                                                                 |
| Accessibility to Internal PRU Structures | Provides 32-bit VBUSP target with three regions: <ul style="list-style-type: none"> <li>Instruction RAM</li> <li>Control/Status registers</li> <li>Debug access to internal registers (R0-R31) and constant table</li> </ul>                                           |

The processor is based on a four-bus architecture which allows instructions to be fetched and executed concurrently with data transfers. In addition, an input is provided in order to allow external status information

to be reflected in the internal processor status register. Figure 7-20 shows a block diagram of the processing element and the associated instruction RAM/ROM that contains the code that is to be executed.



icss-005a

**Figure 7-20. PRU Block Diagram**

#### 7.4.4.2 PRU Cores Functional Description

This section describes the PRU cores supported functionality by describing the constant table, module interface and enhanced GPIOs.

##### 7.4.4.2.1 PRU Constant Table

The PRU Constants Table is a structure of hard-coded memory addresses for commonly used peripherals and memories. The constants table is used for more efficiently load/store data to these commonly accessed addresses by:

- Eliminating the PRU instruction that pre-loads a hard-coded address into the internal register file.
- Maximizing the usage of the PRU register file for embedded processing applications by moving many of the commonly used constant or deterministically calculated base addresses from the internal register file to an external table.

**Table 7-37. PRU0/1 Constant Table**

| Entry No. | Region Pointed To       | Value [31:0] |
|-----------|-------------------------|--------------|
| 0         | PRUSS INTC (local)      | 0002_0000h   |
| 1         | PRUSS IEP (local)       | 0002_F000h   |
| 2         | PRUSS IEP_0x100 (local) | 0002_F100h   |
| 3         | PRUSS ECAP0 (local)     | 0003_0000h   |

Table 7-37. PRU0/1 Constant Table (continued)

| Entry No. | Region Pointed To                          | Value [31:0]                         |
|-----------|--------------------------------------------|--------------------------------------|
| 4         | PRUSS CFG (local)                          | 0002_6000h                           |
| 5         | PRUSS CFG_0x100 (local)                    | 0002_6100h                           |
| 6         | PRUSS INTC_0x200 (local)                   | 0002_0200h                           |
| 7         | PRUSS UART0 (local)                        | 0002_8000h                           |
| 8         | PRUSS IEP0_0x100 (local)                   | 0002_E100h                           |
| 9         | PRUSS CFG (local)                          | 0003_3000h                           |
| 10        | RESERVED                                   | RSERVED                              |
| 11        | PRUSS PRU0 Control (local)                 | 0002_2000h PRU0                      |
|           | RESERVED                                   | RESERVED                             |
|           | RESERVED                                   | RESERVED                             |
|           | PRUSS PRU1 Control (local)                 | 0002_4000h PRU1                      |
| 12        | RESERVED                                   | RESERVED                             |
| 13        | RESERVED                                   | RESERVED                             |
| 14        | RESERVED                                   | RESERVED                             |
| 15        | RESERVED                                   | 6000_0000h                           |
| 16        | RESERVED                                   | 7000_0000h                           |
| 17        | RESERVED                                   | 8000_0000h                           |
| 18        | RESERVED                                   | 9000_0000h                           |
| 19        | RESERVED                                   | A000_0000h                           |
| 20        | RESERVED                                   | B000_0000h                           |
| 21        | MDIO (local)                               | 0003_2400h                           |
| 22        | RAT SLICE0 (local)                         | 0000_8000h PRU0                      |
|           | RAT SLICE1 (local)                         | 0000_9000h PRU1                      |
| 23        | Reserved                                   | C000_0000h                           |
| 24        | PRUSS PRU0/PRU1 Data RAM (local)           | 0000_0n00h, n = c24_blk_index[3:0]   |
| 25        | PRUSS PRU1/PRU0 Data RAM (local)           | 0000_2n00h, n = c25_blk_index[3:0]   |
| 26        | PRUSS IEP (local)                          | 0002_En00h, n = c26_blk_index[3:0]   |
| 27        | PRUSS MII_RT/SGMII0_CFG/SGMII1_CFG (local) | 0003_2n00h, n = c27_blk_index[3:0]   |
| 28        | PRUSS Shared RAM (local)                   | 00nn_nn00h, nnnn = c28_pointer[15:0] |
| 29        | RESERVED                                   | 0Dnn_nn00h, nnnn = c29_pointer[15:0] |
| 30        | RESERVED                                   | 0Enn_nn00h, nnnn = c30_pointer[15:0] |
| 31        | RESERVED                                   | 0Fnn_nn00h, nnnn = c31_pointer[15:0] |

### Note

The addresses in constants entries 24–31 are partially programmable. Their programmable bit field (for example, c24\_blk\_index[3:0]) is programmable through the PRU CTRL register space. As a general rule, the PRU should configure this field before using the partially programmable constant entries.

#### 7.4.4.2.2 PRU Module Interface

The PRU module interface consists of the PRU internal registers 30 and 31 (R30 and R31). Figure 7-21 shows the PRU module interface and the functionality of R30 and R31. The register R31 serves as an interface with the dedicated PRU general purpose input (GPI) pins and PRUSS INTC. Reading R31 returns status information from the GPI pins and PRUSS INTC via the PRU Real Time Status Interface. Writing to R31 generates PRU

system events via the PRU Event Interface. The register R30 serves as an interface with the dedicated PRU general purpose output (GPO) pins.

#### Note

The below sections cover different functional modes of the PRUn cores, (where n=0,1), enhanced GPIO (EGPIO) interface. The register bits which control EGPIO functionalities are part of the (PRUSS CFG) space. For descriptions of these EGPIO register bitfield controls, refer to the [Section 7.4.3.3](#).



icss-005b

**Figure 7-21. PRU Module Interface**

#### 7.4.4.2.2.1 Real-Time Status Interface Mapping (R31): Interrupt Events Input

The PRU Real Time Status Interface directly feeds information into register 31 (R31) of the PRU's internal register file. The firmware on the PRU uses the status information to make decisions during execution. The status interface is comprised of signals from different modules inside of the PRUSS which require some level of interaction with the PRU. More details on the Host interrupts imported into bit 30 and 31 of register R31 of both the PRUs is provided in the [, PRUSS Local Interrupt Controller](#).

**Table 7-38. Real-Time Status Interface Mapping (R31) Field Descriptions**

| Bit  | Field                   | Description                                            |
|------|-------------------------|--------------------------------------------------------|
| 31   | pru_intr_in[1]          | PRU Host Interrupt 1 from local PRUSS INTC             |
| 30   | pru_intr_in[0]          | PRU Host Interrupt 0 from local PRUSS INTC             |
| 29-0 | pru<n>_r31_status[29:0] | Status inputs from primary input via Enhanced GPI port |

#### 7.4.4.2.2.2 Event Interface Mapping (R31): PRU System Events

This PRU Event Interface directly feeds pulsed event information out of the PRU's internal ALU. These events are exported out of the PRUSS and need to be connected to the system interrupt controller at the SoC level. The event interface can be used by the firmware to create software interrupts from the PRU to the Host processor.



icss-005c

Figure 7-22. Event Interface Mapping (R31)

Table 7-39. Event Interface Mapping (R31) Field Descriptions

| Bit  | Field                | Description                    |
|------|----------------------|--------------------------------|
| 31-6 | Reserved             |                                |
| 5    | pru<n>_r31_vec_valid | Valid strobe for vector output |
| 4    | Reserved             |                                |
| 3-0  | pru<n>_r31_vec[3:0]  | Vector output                  |

Simultaneously writing a '1' to pru<n>\_r31\_vec\_valid (R31 bit 5) and a channel number from 0 to 15 to pru<n>\_r31\_vec[3:0] (R31 bits 3-0) creates a pulse on the output of the corresponding prk\_pru\_mst\_intr[x]\_intr\_req INTC system event. For example, writing '100000' will generate a pulse on prk\_pru\_mst\_intr[0]\_intr\_req, writing '100001' will generate a pulse on prk\_pru\_mst\_intr[1]\_intr\_req, and so on to where writing '101111' will generate a pulse on prk\_pru\_mst\_intr[15]\_intr\_req and writing '0xxxxx' will not generate any system event pulses. The output values from both PRU cores in a subsystem are ORed together.

The output channels 0-15 are connected to the INTC system events 16-31, respectively. This allows the PRU to assert one of the system events 16-31 by writing to its own R31 register. The system event is used to either post a completion event to one of the host CPUs (Arm) or to signal the other PRU. The host to be signaled is determined by the system interrupt to interrupt channel mapping (programmable). The 16 events are named as prk\_pru\_mst\_intr<15:0>\_intr\_req. See the *PRUSS Interrupt Requests Mapping*, in the section *PRUSS Local Interrupt Controller*, for more details.

#### 7.4.4.2.2.3 General-Purpose Inputs (R31): Enhanced PRU GP Module

The PRUSS implements an enhanced General Purpose Input/Output (GPIO) module with SCU that supports the following general-purpose input modes: direct input, 16-bit parallel capture, 28-bit serial shift in, and MII\_RT.

Register R31 serves as an interface with the general-purpose inputs. [Table 7-40](#) describes the input modes in detail.

---

**Note**

Each PRU core can only be configured for one GPI mode at a time. Each mode uses the same R31 signals and internal register bits for different purposes. A summary is found in [Table 7-41](#).

---

**Note**

The PRU\_ICSSM\_GPCFG0 register, bitfield [29-26] PR1\_PRU0\_GP\_MUX\_SEL (PRU0 or PRU1) in the PRUSS CFG register space needs to be set to 0h for GP mode. For a given PRU core, the following IO modes are mutually exclusive: GP mode, Sigma Delta mode, and 3 channel Peripheral I/F mode.

**Table 7-40. PRU R31 (GPI) Modes**

| Mode                    | Function                                                                                                                                                                                                                                                                  | Configuration                                                                                                                                                                                                                                                                                                                     |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Direct input            | GPI[19:0] feeds directly into the PRU R31                                                                                                                                                                                                                                 | Default state                                                                                                                                                                                                                                                                                                                     |
| 16-bit parallel capture | DATAIN[0:15] is captured by the posedge or negedge of CLOCKIN                                                                                                                                                                                                             | <ul style="list-style-type: none"> <li>Enabled by PRU_ICSSM_GPCFG0 register (PRU0 or PRU1)</li> <li>CLOCKIN edge selected by PRU_ICSSM_GPCFG0 register</li> </ul>                                                                                                                                                                 |
| 28-bit shift in         | DATAIN is sampled and shifted into a 28-bit shift register. <ul style="list-style-type: none"> <li>Shift Counter (Cnt_16) feature is mapped to pru&lt;n&gt;_r31_status[28].</li> <li>SB (Start Bit detection) feature is mapped to pru&lt;n&gt;_r31_status[29]</li> </ul> | <ul style="list-style-type: none"> <li>Enabled and disabled by PRU_ICSSM_GPECFG0 register (PRU0 or PRU1)</li> <li>Cnt_16 is self clearing and is connected to the PRU INTC</li> <li>Start Bit (SB) is cleared by PRU_ICSSM_GPECFG0 register</li> <li>Start Bit value (0h or 1h) selected by PRU_ICSSM_GPECFG0 register</li> </ul> |
| PERIF                   | The 3 channel Peripheral Interface supports functionality for operations utilized the EnDat 2.2 and BiSS protocols.                                                                                                                                                       | Enabled by PRU_ICSSM_GPCFG0[1-0] PRU0_GPI_MODE register (value: 1h), where n = 0 or 1                                                                                                                                                                                                                                             |
| MII_RT                  | mii_rt_r31_status [29:0] internally driven by the MII_RT module                                                                                                                                                                                                           | Enabled by PRU_ICSSM_GPCFG0[1-0] PRU<n>_GPI_MODE register (value: 2h), where n = 0 or 1                                                                                                                                                                                                                                           |
| Sigma Delta             | Up to nine channels of concurrent counting with clock source configuration for each channel.                                                                                                                                                                              | Enabled by PRU_ICSSM_GPCFG0[1-0] PRU<n>_GPI_MODE register (value: 3h), where n = 0 or 1                                                                                                                                                                                                                                           |

**Table 7-41. PRU GPI Signals and Configurations**

| Pad Names at Device Level <sup>(1)</sup> | GPI Modes    |                  |                 |       |        |             |
|------------------------------------------|--------------|------------------|-----------------|-------|--------|-------------|
|                                          | Direct Input | Parallel Capture | 28-Bit Shift in | PERIF | MII    | Sigma Delta |
| PR<k>_PRU<n>_GPIO0                       | GPIO0        | DATAIN0          | DATAIN          |       | RXD[0] | SD0_CLK     |
| PR<k>_PRU<n>_GPIO1                       | GPIO1        | DATAIN1          |                 |       | RXD[1] | SD0_DATA    |
| PR<k>_PRU<n>_GPIO2                       | GPIO2        | DATAIN2          |                 |       | RXD[3] | SD1_CLK     |
| PR<k>_PRU<n>_GPIO3                       | GPIO3        | DATAIN3          |                 |       | RXDV   | SD1_DATA    |
| PR<k>_PRU<n>_GPIO4                       | GPIO4        | DATAIN4          |                 |       | RXER   | SD2_CLK     |
| PR<k>_PRU<n>_GPIO5                       | GPIO5        | DATAIN5          |                 |       | RX_CLK | SD2_DATA    |
| PR<k>_PRU<n>_GPIO6                       | GPIO6        | DATAIN6          |                 |       |        | SD3_CLK     |
| PR<k>_PRU<n>_GPIO7                       | GPIO7        | DATAIN7          |                 |       | RXLINK | SD3_DATA    |
| PR<k>_PRU<n>_GPIO8                       | GPIO8        | DATAIN8          |                 |       | COL    | SD4_CLK     |

Table 7-41. PRU GPI Signals and Configurations (continued)

| Pad Names at Device Level <sup>(1)</sup> | GPI Modes    |                  |                 |            |                   |                        |
|------------------------------------------|--------------|------------------|-----------------|------------|-------------------|------------------------|
|                                          | Direct input | Parallel Capture | 28-Bit Shift in | PERIF      | MII               | Sigma Delta            |
| PR<k>_PRU<n>_GPIO9                       | GPIO9        | DATAIN9          |                 | PERIFO_IN  | CRS               | SD4_DATA               |
| PR<k>_PRU<n>_GPIO10                      | GPIO10       | DATAIN10         |                 | PERIF1_IN  |                   | SD5_CLK                |
| PR<k>_PRU<n>_GPIO11                      | GPIO11       | DATAIN11         |                 | PERIF2_IN  |                   | SD5_DATA               |
| PR<k>_PRU<n>_GPIO12                      | GPIO12       | DATAIN12         |                 |            |                   | SD6_CLK                |
| PR<k>_PRU<n>_GPIO13                      | GPIO13       | DATAIN13         |                 |            |                   | SD6_DATA               |
| PR<k>_PRU<n>_GPIO14                      | GPIO14       | DATAIN14         |                 |            |                   | SD7_CLK                |
| PR<k>_PRU<n>_GPIO15                      | GPIO15       | DATAIN15         |                 |            |                   | SD7_DATA               |
| PR<k>_PRU<n>_GPIO16                      | GPIO16       | CLOCKIN          |                 | R31_IN[16] | TX_CLK,R31_IN[16] | SD8_CLK,<br>R31_IN[16] |
| PR<k>_PRU<n>_GPIO17                      | GPIO17       |                  |                 |            |                   | SD8_DATA               |
| PR<k>_PRU<n>_GPIO18                      | GPIO18       |                  |                 |            |                   |                        |
| PR<k>_PRU<n>_GPIO19                      | GPIO19       |                  |                 |            |                   |                        |

(1) These pins are also used for Sigma Delta or Peripheral I/F mode.

#### 7.4.4.2.2.3.1 PRU EGPIs Direct Input

The pru<n>\_r31\_status[0:19] bits of the internal PRU register file are mapped to device-level, general purpose input pins (PRU0\_GPI[0:19]). In GPI Direct Input mode, PRU0\_GPI[0:19] feeds directly to pru<n>\_r31\_status[0:19].

Each PRU of the PRUSS has a separate mapping to device input signals - PRn\_PRU0\_GPI[19:0] for the PRU0 core and PRn\_PRU1\_GPI[19:0] for the PRU1 core. There are general purpose inputs in total. For more details, refer also to the *PRUSS-M Environment*. See the device's system reference guide or datasheet for device specific pin mapping.

#### Note

The following PRU IO are not pinned out at the device level: PR0\_PRU0\_GPIO[7,17,18,19]



Figure 7-23. PRU R31 (EGPI) Direct Input Mode Block Diagram

#### 7.4.4.2.2.3.2 PRU EGPIs 16-Bit Parallel Capture

The `pru<n>_r31_status[0:15]` and `pru<n>_r31_status[16]` bits of the internal PRU register file mapped to device-level, general purpose input pins (PRU0\_DATAIN [0:15] and PRU0\_CLOCKIN, respectively). PRU0\_CLOCKIN is designated for an external strobe clock, and is used to capture PRU0\_DATAIN [0:15].

The PRU< n >\_DATAIN can be captured either by the positive or the negative edge of PRU< n >\_CLOCK, programmable through the PRUSS CFG register space. If the clocking is configured through the PRUSS CFG register to be positive, then it will equal PRU< n >\_CLOCK; however, if the clocking is configured to be negative, then it will equal PRU< n >\_CLOCK inverted.



**Figure 7-24. PRU R31 (EGPI) 16-Bit Parallel Capture Mode Block Diagram**

#### 7.4.4.2.2.3.3 PRU EGPIs 28-Bit Shift In

In 28-bit shift in mode, the device-level, general-purpose input pin PRU< n >\_DATAIN is sampled and shifted into a 28-bit shift register on an internal clock pulse. The register fills in LSB order (from bit 0 to 27) and then overflows into a bit bucket. The 28-bit register is mapped to `pru<n>_r31_status[0:27]` and can be cleared in software through the PRU\_ICSS\_GPCFG0[13] PRU0\_GPI\_SB register (PRU0 or PRU1).

Note that by default, the PRU will continually capture and shift the DATAIN input when the GPI mode has been set. However, clearing the PRU\_ICSS\_GPCFG0[1] PRU0\_GPI\_SHIFT\_EN bit will freeze the shift operation.

The shift rate is controlled by the effective divisor of two cascaded dividers applied to the PRU-ICSS< n >\_CORE\_CLK clock ( ). These cascaded dividers can each be configured through the PRUSS CFG register space to a value of {1, 1.5, ..., 16}. Table 7-42 shows sample effective clock values and the divisor values that can be used to generate these clocks.

**Table 7-42. PRU EGPIs Effective Clock Values**

| Generated clock | PRU0_GPI_DIV0 | PRU0_GPI_DIV1 |
|-----------------|---------------|---------------|
| 8-MHz           | 12.5 (17h)    | 2 (02h)       |
| 10-MHz          | 10 (12h)      | 2 (02h)       |
| 16-MHz          | 16 (1Eh)      | 1 (00h)       |
| 20-MHz          | 10 (12h)      | 1 (00h)       |

The 28-bit shift mode also supports the following features:

- SB (Start Bit detection) is mapped to `pru<n>_r31_status[29]` and is set when the first 1 (default) or 0 is captured on PRU< n >\_DATAIN. The Start Bit value (1 or 0) is configured through the PRU\_ICSS\_GPCFG0[0] PRU0\_GPI\_SB\_P bit (PRU0 or PRU1). The SB flag in `pru<n>_r31_status[29]` is cleared in software through the PRUSS CFG register space.

- Cnt\_16 (Shift Counter) is mapped to pru<n>\_r31\_status[28] and is set on every 16 shift clock samples after the Start Bit has been received. CNT\_16 is self clearing and is connected to the local PRUSS INTC. See the *PRUSS Local Interrupt Controller* for more details.
- The PRU\_ICSS\_GPECFG0[1] PRU0\_GPI\_SHIFT\_EN bit can stop or freeze the current shift operation and disable the search for a new Start Bit, if an SB event has not occurred.



**Figure 7-25. PRU R31 (EGPI) 28-Bit Shift Mode**

#### 7.4.4.2.3.3.1 PRU EGPI Programming Model

Follow this steps to configure the PRU EGPI in 28-bit shift input mode:

1. Clear PRU\_ICSS\_GPECFG0[1] PRU0\_GPI\_SHIFT\_EN bit (PRU0 or PRU1)
2. Clear/Set PRU\_ICSS\_GPECFG0[0] PRU0\_GPI\_SB\_P bit (PRU0 or PRU1)
3. Clear Start Bit by writing 1h to PRU\_ICSS\_GPCFG0[13] PRU0\_GPI\_SB bit
4. Program the dividers through:  
 $\text{PRU\_ICSS\_GPCFG0[24-20]} \text{ PRU0\_GPO\_DIV1 bit (PRU0 or PRU1)}$   
 $\text{PRU\_ICSS\_GPCFG0[19-15]} \text{ PRU0\_GPO\_DIV0 bit (PRU0 or PRU1)}$
5. Enable Shift Input Mode by writing to PRU\_ICSS\_GPECFG0[1] PRU0\_GPI\_SHIFT\_EN bit

#### 7.4.4.2.3.4 General-Purpose Outputs (R30): Enhanced PRU GP Module

The PRUSS implements an enhanced General Purpose Input/Output (GPIO) module that supports two general-purpose output modes: direct output and shift out.

Table 7-43 describes these modes in detail.

##### Note

Each PRU core can only be configured for one GPO mode at a time. Each mode uses the same R30 signals and internal register bits for different purposes. A summary is found in Table 7-43.

##### Note

The PRU\_ICSS\_GPCFG0 register, bitfield [29-26] PR1\_PRU0\_GP\_MUX\_SEL (PRU0 or PRU1) in the PRUSS CFG register space needs to be set to 0h for GP mode. For a given PRU core, the following IO modes are mutually exclusive: GP mode, Sigma Delta mode, and 3 channel Peripheral I/F mode.

**Table 7-43. PRU R30 (EGPO) Output Mode**

| Mode          | Function                                                                                                                                                                                                                                                                                                                                                                             | Configuration                                                                                                                             |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Direct output | pru<n>_r30[19:0] feeds directly to GPO[19:0]                                                                                                                                                                                                                                                                                                                                         | Default state                                                                                                                             |
| Shift out     | <ul style="list-style-type: none"> <li>pru&lt;n&gt;_r30[0] is shifted out on DATAOUT on every rising edge of pru&lt;n&gt;_r30[1] (CLOCKOUT).</li> <li>LOAD_GPO_SH0 (Load Shadow Register 0) is mapped to pru&lt;n&gt;_r30[29].</li> <li>LOAD_GPO_SH1 (Load Shadow Register 1) is mapped to pru&lt;n&gt;_r30[30].</li> <li>ENABLE_SHIFT is mapped to pru&lt;n&gt;_r30[31].</li> </ul> | Enabled by PRU_ICSS_GPCFG0 register (PRU0 or PRU1)<br>Free Running Clock or Fixed Clock Count Mode selected by PRU_ICSS_GPECFG0 register. |

**Table 7-44. GPO Mode Descriptions**

| Pad Names at Device Level <sup>(1)</sup> | GPO Modes     |           |
|------------------------------------------|---------------|-----------|
|                                          | Direct output | Shift out |
| PR<k>_PRU<n>_GPO0                        | GPO0          | DATAOUT   |
| PR<k>_PRU<n>_GPO1                        | GPO1          | CLOCKOUT  |
| PR<k>_PRU<n>_GPO2                        | GPO2          |           |
| PR<k>_PRU<n>_GPO3                        | GPO3          |           |
| PR<k>_PRU<n>_GPO4                        | GPO4          |           |
| PR<k>_PRU<n>_GPO5                        | GPO5          |           |
| PR<k>_PRU<n>_GPO6                        | GPO6          |           |
| PR<k>_PRU<n>_GPO7                        | GPO7          |           |
| PR<k>_PRU<n>_GPO8                        | GPO8          |           |
| PR<k>_PRU<n>_GPO9                        | GPO9          |           |
| PR<k>_PRU<n>_GPO10                       | GPO10         |           |
| PR<k>_PRU<n>_GPO11                       | GPO11         |           |
| PR<k>_PRU<n>_GPO12                       | GPO12         |           |
| PR<k>_PRU<n>_GPO13                       | GPO13         |           |
| PR<k>_PRU<n>_GPO14                       | GPO14         |           |
| PR<k>_PRU<n>_GPO15                       | GPO15         |           |
| PR<k>_PRU<n>_GPO16                       | GPO16         |           |
| PR<k>_PRU<n>_GPO17                       | GPO17         |           |
| PR<k>_PRU<n>_GPO18                       | GPO18         |           |
| PR<k>_PRU<n>_GPO19                       | GPO19         |           |

(1) These pins are also used for Sigma Delta or Peripheral I/F mode.

#### 7.4.4.2.2.3.4.1 PRU EGPOs Direct Output

The PRU0\_r30 [19:0] bits of the internal PRU register files are mapped to device-level, general-purpose output pins (PRU0\_GPO[0:19]). In GPO Direct Output mode, PRU0\_r30[0:19] feed directly to PRU0\_GPO[0:19]. Each PRU of the PRUSS has a separate mapping to pins, so that there are 40 total general-purpose outputs from the PRUSS. See the device's system reference guide or datasheet for device-specific pin mapping.



icss-009

**Figure 7-26. PRU R30 (EGPO) Direct Output Mode Block Diagram****7.4.4.2.2.3.4.2 PRU EGPO Shift Out**

In shift out mode, data is shifted out of PRU0\_r30[0] (PRU0\_DATAOUT) on every rising edge of PRU0\_r30[1] (PRU0\_CLOCK). The shift rate is controlled by the effective divisor of two cascaded dividers applied to the PRUSS<n>\_CORE\_CLK clock (.). These cascaded dividers can each be configured through the PRUSS CFG register space to a value of {1, 1.5, ..., 16}. Table 7-45 shows sample effective clock values and the divisor values that can be used to generate these clocks. Note that shift out mode supports two clocking submodes - Free Running Clock Mode (default) and Fixed Clock Count Mode. The clocking submode is selected through PRU\_ICSS\_GPECFG0[5] PRU0\_GPO\_SHIFT\_CLK\_FREE. In Free Running Clock Mode, PRU0\_CLOCKOUT is a free running clock that starts when the PRU GPO mode is set to shift out mode.

**Table 7-45. Effective Clock Values**

| Generated Clock | PRU0_GPO_DIV0 | PRU0_GPO_DIV1 |
|-----------------|---------------|---------------|
| 8 MHz           | 12.5 (17h)    | 2 (02h)       |
| 10 MHz          | 10 (12h)      | 2 (02h)       |
| 16 MHz          | 16 (1Eh)      | 1 (00h)       |
| 20 MHz          | 10 (12h)      | 1 (00h)       |

Shift out mode uses two 16-bit shadow registers (GPO\_SH0 and GPO\_SH1) to support ping-pong buffers. Each shadow register has independent load controls programmable through PRU0\_r30[29:30] (PRU0\_LOAD\_GPO\_SH[0:1]). While PRU0\_LOAD\_GPO\_SH[0:1] is set, the contents of PRU<n>\_R30[0:15] are loaded into GPO\_SH0 and GPO\_SH1 shadow registers.

The data shift will start from the LSB or MSB of GPO\_SH0 when PRU<n>\_R30[31] (PRU0\_ENABLE\_SHIFT) is set. The LSB or MSB setting is configurable through PRU\_ICSS\_GPECFG0[4] PRU0\_GPO\_SHIFT\_SWAP. Note that if no new data is loaded into GPO\_SH0/GPO\_SH1 after shift operation, the shift operation will continue looping and shifting out the pre-loaded data.

For Free Running Clock Mode, the shift operation will continue until PRU0\_ENABLE\_SHIFT is cleared. When PRU0\_ENABLE\_SHIFT is cleared, the shift operation will finish shifting out the current shadow register, stop, and then reset.

For Fixed Clock Count Mode, the number of data bits to be shifted out is defined by PRU\_ICSS\_GPECFG0[15-8] PRU0\_GPO\_SHIFT\_CNT. PRU<n>\_CLOCKOUT will stop either high or low with the last data bit. The last data bit will remain persistent. However, the clock stop state is configurable through PRU\_ICSS\_GPECFG0[16] PRU0\_GPO\_SHIFT\_CLK\_HIGH.

The source of PR<k>\_PRU<n>\_GPO[2:15] is configurable by PRU\_ICSS\_GPECFG0[6] PRU0\_GPO\_SHIFT\_GP\_EN. By default, if any device-level pins mapped to PRU<n>\_R30[2-15] are configured for the PR<k>\_PRU<n>\_GPO[2:15] pinmux mode, then these pins will reflect the shadow register value written to PRU<n>\_R30. Any pin configured for a different pinmux setting will not reflect the shadow register value written to PRU<n>\_R30. However, setting PRU\_ICSS\_GPECFG0[6] PRU0\_GPO\_SHIFT\_GP\_EN = 1h allows PRU<n>\_R30[2:15] to be controlled by PRU<n>\_R30\_SHADOW[2-15], which is updated by PRU<n>\_R30[2:15] when PRU<n>\_R30[28] = 1h.



icss-010

**Figure 7-27. PRU R30 (GPO) Shift Out Mode Block Diagram**

#### 7.4.4.2.2.3.4.2.1 PRU EGPO Programming Model

After the PRU is initialized, the software should only enable Shift Out Mode configuration per initialization.

#### 7.4.4.2.2.3.5 Sigma Delta (SD) Decimation Filtering

Sigma-delta Sinc filtering is achieved by the combination of PRU hardware and firmware. PRU hardware provides hardware integrators that do the accumulation part of Sinc filtering, while the differentiation part is done in firmware.

The integrator serves to count the number of 1's per clock event. Each channel has three cascaded counters, which are the accumulators for the Sinc3 filter. Each counter is 28 bits, giving a maximum count of 268,435,456. Each channel has a free running rollover clock counter. This sample counter updates the count value on the effective clock event for that channel. Each channel also contains a programmable counter compare block, and the compare register has a size of 8 bits. However, the minimum value is 4 and maximum value is 256 due to the 28-bit accumulator. Once sample counter compare value is reached, the shadow register copy is updated and the shadow register copy flag is set.

Features of the integrators in PRUs SD Demodulator:

- Up to 9 channels concurrent counting
- Software can read all 3 stages accumulators
- Flexible clock source configuration for each channel; option of independent clock source for each channel or one clock source for three channels
- Programmable, 8-bit sample counter compare register; used to set the OSR of Sinc filter
- Three 28-bit cascaded counters per channel for accumulation, only Sinc3 and Sinc2 modes supported
- Common channel enable (all channels are active or none are active)
- Fast 1 and 0 min/max count sliding programmable window for each of the 9 channels

#### 7.4.4.2.2.3.5.1 Sigma Delta Block Diagram and Signals

The Sigma Delta's I/Os are multiplexed with the PRU GPIO/GPO signals, as shown in [Table 7-46](#).

Note: The PR<k>\_PRU<n>\_GP\_MUX\_SEL bitfield in the PRU\_ICSS\_GPCFG0 register (where k = 0 or 1 and n = 0 or 1) must be set to 3h for configure the GPIO/GPO signals for SD mode.

**Table 7-46. PRU GPIO Signals and Configurations for Sigma Delta**

| Signal Names at Device Level <sup>(1)</sup> | Sigma Delta (SD) Mode | Function                       |
|---------------------------------------------|-----------------------|--------------------------------|
| PR<k>_PRU<n>_GPIO                           | SD0_CLK               | SD demodulator clock channel 0 |
| PR<k>_PRU<n>_GPI1                           | SD0_D                 | SD demodulator data channel 0  |

**Table 7-46. PRU GPI Signals and Configurations for Sigma Delta (continued)**

| Signal Names at Device Level <sup>(1)</sup> | Sigma Delta (SD) Mode | Function                       |
|---------------------------------------------|-----------------------|--------------------------------|
| PR<k>_PRU<n>_GPI2                           | SD1_CLK               | SD demodulator clock channel 1 |
| PR<k>_PRU<n>_GPI3                           | SD1_D                 | SD demodulator data channel 1  |
| PR<k>_PRU<n>_GPI4                           | SD2_CLK               | SD demodulator clock channel 2 |
| PR<k>_PRU<n>_GPI5                           | SD2_D                 | SD demodulator data channel 2  |
| PR<k>_PRU<n>_GPI6                           | SD3_CLK               | SD demodulator clock channel 3 |
| PR<k>_PRU<n>_GPI7                           | SD3_D                 | SD demodulator data channel 3  |
| PR<k>_PRU<n>_GPI8                           | SD4_CLK               | SD demodulator clock channel 4 |
| PR<k>_PRU<n>_GPI9                           | SD4_D                 | SD demodulator data channel 4  |
| PR<k>_PRU<n>_GPI10                          | SD5_CLK               | SD demodulator clock channel 5 |
| PR<k>_PRU<n>_GPI11                          | SD5_D                 | SD demodulator data channel 5  |
| PR<k>_PRU<n>_GPI12                          | SD6_CLK               | SD demodulator clock channel 6 |
| PR<k>_PRU<n>_GPI13                          | SD6_D                 | SD demodulator data channel 6  |
| PR<k>_PRU<n>_GPI14                          | SD7_CLK               | SD demodulator clock channel 7 |
| PR<k>_PRU<n>_GPI15                          | SD7_D                 | SD demodulator data channel 7  |
| PR<k>_PRU<n>_GPI16                          | SD8_CLK               | SD demodulator clock channel 8 |
| PR<k>_PRU<n>_GPI17                          | SD8_D                 | SD demodulator data channel 8  |
| PR<k>_PRU<n>_GPI18                          | -                     |                                |
| PR<k>_PRU<n>_GPI19                          | -                     |                                |

- (1) Note: These signals are shared with the GP and Peripheral I/Fs. To configure for Sigma Delta, PRU\_ICSS\_GPCFG0[29-26] PR1\_PRU0\_GP\_MUX\_SEL (where k = 0 or 1 and n = 0 or 1) needs to be set to 3h for SD mode.

The PR<k>\_PRU0\_GPI1 signal (muxed with SD0\_D) can be used as SD\_CLKOUT when PRUSS generates clock. This is a trade-off as PRU application will lose one SD channel. SD\_CLKOUT needs to go through a clock generator chip if driving multiple sigma delta modulators and also be looped back into PRUSS as SD\_CLKIN, typically pru\_gpi16.

Note: To output the SD clock on PR<k>\_PRU0\_GPO1, this device requires that the PRU core be configured for both SD and shift out mode (PRU\_ICSS\_GPCFG0[29-26] PR1\_PRU0\_GP\_MUX\_SEL = 3h and PRU\_ICSS\_GPCFG0[14] PRU<n>\_GPO\_MODE = 1h). Be sure to configure the shift out mode's clock divisors before enabling shift out mode (PRU\_ICSS\_GPCFG0[14] PRU<n>\_GPO\_MODE = 1h). Additionally, the PRUSS, PRU0 SD clock is routed to both PR0\_PRU0\_GPO1 and PR0\_PRU1\_GPO1. Figure 7-28 shows a block diagram of the Sigma Delta implementation. Full description of the PRU R30 and R31 registers are shown in Table 7-48 and Table 7-49.



**Figure 7-28. Sigma Delta Block Diagram**

Note: Each channel can independently be configured to use one of three external clock sources.

**Table 7-47** shows the clock source options, selectable through PRU\_ICSS\_PRU0\_SD\_CLK\_SELi[1-0] PRU0\_SD\_CLK\_SELi (where n = 0 or 1 and i = 0 to 8).

**Table 7-47. Sigma Delta External Clock Sources**

| PRU0_SD_CLK_SELi value | Clock Source                                                                                                                             |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 0                      | pr<k>_pru<n>_sd8_clk                                                                                                                     |
| 1                      | pr<k>_pru<n>_sd<i>_clk                                                                                                                   |
| 2                      | pr<k>_pru<n>_sd0_clk for sd0, sd1, and sd2;<br>pr<k>_pru<n>_sd3_clk for sd3, sd4, and sd5;<br>pr<k>_pru<n>_sd6_clk for sd6, sd7, and sd8 |

#### 7.4.4.2.2.3.5.2 PRU R30 / R31 Interface

The PRU uses the R30 and R31 registers to interface with the Sigma Delta interface. **Table 7-48** and **Table 7-49** shows the R31 and R30 interface for the Sigma Delta mode. Note that only the parameters and data for one channel can be viewed at a time. The channel to be viewed is determined by the r30[29:26] (channel\_select).

**Table 7-48. Sigma Delta PRU Registers: R31**

| Bits  | Field Name             | Description                                                                                                                                             |
|-------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | Reserved               |                                                                                                                                                         |
| 29    | shadow_update_flag_ovf | Shadow update flag overflow, set when over sample count equals over sample size and shadow_update_flag is still set. Set bit R31[24] to clear the flag. |
| 28    | shadow_update_flag     | Shadow update flag, set when over sample count equals over sample size and shadow_update_flag is still set. Set bit R31[24] to clear the flag.          |

**Table 7-48. Sigma Delta PRU Registers: R31 (continued)**

| Bits | Field Name                                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27-0 | data_out[27-0]/<br>shadow_update_flag_clr (R31[24]) /<br>re_init (R31[23]) | data_out[27] (read): most-significant bit of sample data shadow_update_flag_clr<br>(write):<br>re_init (write): Set to reset all counters, flags, and shadow copy.<br>Updates over_sample_size based on the current<br>PRU_ICSS_PRU0_SD_SAMPLE_SIZEi[7-0] register (where n = 0 or 1 and i = 0<br>to 8) on the selected channel.<br>shadow_update_flag_clr (write): Set to clear shadow_update_flag and<br>shadow_update_flag_ovf (if set). |

**Table 7-49. Sigma Delta PRU Registers: R30**

| Bits  | Field Name            | Description                                                                                                                            |
|-------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | Reserved              |                                                                                                                                        |
| 29-26 | channel_select[3-0]   | Channel select<br>0h: Channel 0<br>...<br>8h: Channel 8<br>9h: Reserved<br>...<br>Fh: Reserved                                         |
| 25    | channel_en            | Global Channel enable (affects all 9 channels).<br>0h: All channels disabled. Counters/flags are cleared.<br>1h: All channels enabled. |
| 24-23 | Reserved              |                                                                                                                                        |
| 22    | snoop                 | Enable snoop (i.e. fetch data) on the selected channel.<br>0h: acc1/acc2/acc3 shadow copy<br>1h: current acc1/acc2/acc3                |
| 21    | sample_counter_select | Read sample counter.<br>0h: Not selected<br>1h: Sample count selected                                                                  |
| 20-0  | Reserved              |                                                                                                                                        |

The PRUSS CFG register space has additional registers for controlling the SD demodulator module:

- PRU\_ICSS\_PRU0\_SD\_CLK\_SELi[5-4] PRU0\_SD\_ACC\_SELi (where n = 0 or 1, i = 0 to 8) - Selects accumulator 1, 2 or 3 as source (acc1/acc2/acc3).
- PRU\_ICSS\_PRU0\_SD\_CLK\_SELi[2] PRU0\_SD\_CLK\_INVi (where n = 0 or 1, i = 0 to 8) - Inverts clock.
- PRU\_ICSS\_PRU0\_SD\_CLK\_SELi[1-0] PRU0\_SD\_CLK\_SELi (where n = 0 or 1, i = 0 to 8) - Selects the clock source.
- PRU\_ICSS\_PRU0\_SD\_SAMPLE\_SIZEi[7-0] PRU0\_SD\_SAMPLE\_SIZEi (where n = 0 or 1, i = 0 to 8) - Selects number of samples to read before giving output.

#### 7.4.4.2.2.3.5.3 Sigma Delta Description

Figure 7-29 shows a block diagram of the Sigma Delta hardware integrators and integration with the PRU R30 / R31 interface for a single channel.



**Figure 7-29. Sigma Delta Hardware Integrators Block Diagram (snoop = 0)**



**Figure 7-30. Sigma Delta Hardware Integrators Block Diagram (snoop = 1)**

The three accumulators (acc1-acc3) for each channel are simple 28 bit adders. The input for acc1 is 1-bit, while the inputs for acc2 and acc3 are 28-bits. On each positive edge of the CLK\_OUT, all three 28-bit counters (acc1-acc3) and the sample counter for each channel will get updated as follows:

```

acc1 = acc1 + data_in
acc2 = acc2 + acc1
acc3 = acc3 + acc2
sample_count = sample_count + 1

```

Each accumulator will rollover at 0xFF\_FFFF. For example if acc2 = 0x10 and acc3 = 0xFF\_FFFF, then acc3 will update to 0x00\_0000F on the next clock event. Sample counter will rollover when it equals the defined sample size (PRU\_ICSS\_PRU0\_SD\_SAMPLE\_SIZEi[7-0] PRU0\_SD\_SAMPLE\_SIZEi).

Note that while the channels are not enabled, no operations are performed and all flags and counters are cleared. If a new sample size is to be loaded, the PRU firmware should assert re\_init (r31[23]), and all stored count values are cleared to 0.

Fast detect block is used to detect fast changes in the amount of ones, presented in a programmable sliding window of 4 to 32 bits. The sliding window is controlled by PRU\_ICSS\_PRU0\_SD\_SAMPLE\_SIZEi[10-8] PRU0\_FD\_WINDOW\_SIZE\_i bit field.

Fast detect must be enabled through the PRU\_ICSS\_PRU0\_SD\_SAMPLE\_SIZEi[23] PRU0\_FD\_EN\_i register before SD is enabled. It will start the compare after the first 32 sample clocks. Fast detect block will remain active until a re\_init (r31[23]) is asserted.

The Sigma Delta interface has two status flags:

- Shadow update flag (r31[28])
- Shadow update flag overflow (r31[29])

When sample\_counter equals the defined sample size (PRU\_ICSS\_PRU0\_SD\_SAMPLE\_SIZEi[7-0] PRU0\_SD\_SAMPLE\_SIZEi), then the acc1/acc2/acc3 shadow register copy will be updated, the shadow\_update\_flag (r31[28]) will be set, and sample\_counter will rollover to 0. The PRU firmware can clear this flag by writing '1' to shadow\_update\_flag\_clr (r31[28]). If sample\_count equals the defined sample size and the shadow\_update\_flag is still set, then shadow\_update\_flag\_ovf (r31[29]) will be set. Similarly, the PRU firmware can clear this flag by writing '1' to shadow\_update\_flag\_ovf\_clr (r31[29]). Note that the clear operation for both flags has a higher priority than the set event.

The PRU firmware can monitor the acc2/acc3 and sample\_counter values through data\_out[27-0] (r31[27-0]).

Table 7-50 shows the configuration options for data\_out[27-0].

**Table 7-50. Data\_out[27-0] Configuration Options**

| snoop (r30[22]) | sample_counter_select (r30[21]) | data_out (r31[27-0])                                                                                                                    |
|-----------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0               | 0                               | Reads acc1/acc2/acc3 shadow register copy. See <a href="#">Figure 7-29 Sigma Delta Hardware Integrators Block Diagram (snoop = 0)</a> . |
| 1               | 0                               | Reads acc1/acc2/acc3 directly. See <a href="#">Figure 7-30 Sigma Delta Hardware Integrators Block Diagram (snoop = 1)</a> .             |
| 0               | 1                               | Reads sample_counter shadow register copy. See <a href="#">Figure 7-29 Sigma Delta Hardware Integrators Block Diagram (snoop = 0)</a> . |
| 1               | 1                               | Reads sample_counter directly. See <a href="#">Figure 7-30 Sigma Delta Hardware Integrators Block Diagram (snoop = 1)</a> .             |

#### 7.4.4.2.2.3.5.4 Sigma Delta Basic Programming Example

The following programming example assumes that the PRU is configured for Sigma Delta Mode (PRU\_ICSS\_GPCFG0[29-26] PR1\_PRU<n>\_GP\_MUX\_SEL = 3h).

- Configure clock sources, accumulator source, and sample size:
  - PRU\_ICSS\_PRU0\_SD\_CLK\_SELi[1-0] PRU0\_SD\_CLK\_SELi (where n = 0 or 1, i = 0 to 8) for clock source
  - PRU\_ICSS\_PRU0\_SD\_CLK\_SELi[2] PRU0\_SD\_CLK\_INVi (where n = 0 or 1, i = 0 to 8) for clock polarity
  - PRU\_ICSS\_PRU0\_SD\_CLK\_SELi[5-4] PRU0\_SD\_ACC\_SELi (where n = 0 or 1, i = 0 to 8) - for accumulator source (acc1/acc2/acc3)
  - PRU\_ICSS\_PRUSS\_SD\_PRU0\_SAMPLE\_SIZEi[7-0] PRU0\_SD\_SAMPLE\_SIZE for sample size
- Reinitialize all channels whose sample size was configured
  - Select channel by writing to channel\_select (r30[29-26])
  - Delay at least 1 PRU cycle before executing re\_int in step 2c.
  - Reinitialize selected channel by writing to re\_init (r31[23])
  - Repeat steps 2a & 2b for all configured channels
- Enable all channels by writing '1' to channel\_en (r30[25])
- Select channel by writing to channel\_select (r30[29-26])

- a. Poll shadow\_update\_flag (r31[28]) to detect when acc1/acc2/acc3 shadow register copy data is ready to be read
  - b. Delay at least 1 PRU cycle before polling shadow\_update\_flag in Step 4c.
  - c. Read data\_out[27-0] (r31[27-0])
  - d. Clear shadow\_update\_flag by writing '1' to r31[24]
5. Repeat step 4 for new channel

#### 7.4.4.2.3.6 Three Channel Peripheral Interface

The 3 channel Peripheral Interface supports functionality for operations utilizing the EnDat 2.2 and BiSS protocols. The 3 channel Peripheral Interface supports both 2 wire and 4 wire serial RS-485 communication. The following table shows the supported encoder protocols for the PRU-ICSS.

**Table 7-51. Three Channel Peripheral Interface Supported Encoder Protocols**

| Encoder Protocol | Number of wire in RS-485 Communication |
|------------------|----------------------------------------|
| EnDat 2.2        | 4 wire                                 |
| BiSS             | 4 wire                                 |
| HDSL             | 2 wire                                 |
| Tamagawa         | 2 wire                                 |

This module supports the following features:

- 3 channels with baud range from 100 kHz to 16 MHz
- PRU\_ICSS\_UART\_CLK (default) or PRU\_ICSS\_ICLK controller clock is an input to independent div16fr clock dividers to produce a 1X clock (PERIF<m>\_CLK) and oversampling clock
- Half-duplex (TX and RX are not supported concurrently)
- TX FIFO size of 32 bits
- RX FIFO size of 4 bits
- Configurable shift size/oversampling on RX
- Optional RX frame size auto shut off
- Programmable HW delay 1 (wire delay, controlling when the clock signal is first driven low) and delay 2 (tst delay, controlling when the clock signal is first driven high) on TX operation
- Optional programmable TX termination
- Individual TX channel start trigger (tx\_channel\_go) or simultaneous TX start trigger for all channels (tx\_global\_go)
- Flexible HW assisted clock output generation to allow free running, stop high and stop low (after last RX data), or stop high (after last TX data) operation with optional software clock override feature
- Optional SW direct snoop of data input
- RX Start Bit of '1' or '0'

#### 7.4.4.2.3.6.1 Peripheral Interface Block Diagram and Signal Configuration

The Peripheral Interface's I/Os are multiplexed with the PRU GPI/GPO signals, as shown in Table 7-52. The PR1\_PRU<n>\_GP\_MUX\_SEL bitfield in the PRU\_ICSS\_GPCFG0 register (PRU0 or PRU1) must be set to 1h for configure the GPI/GPO signals for Peripheral I/F mode.

**Table 7-52. PRU GPI/GPO Signals and Configurations for Peripheral I/F<sup>(1)</sup>**

| Pad Names at Device Level <sup>(2)</sup> <sup>(3)</sup> | Peripheral I/F<br>Mode (PRU_ICSS_GPCFG0[29-26])<br>PR1_PRU0_GP_MUX_SEL = 1h |
|---------------------------------------------------------|-----------------------------------------------------------------------------|
| PR<k>_PRU<n>_GPIO                                       |                                                                             |
| PR<k>_PRU<n>_GPIO1                                      |                                                                             |
| PR<k>_PRU<n>_GPIO2                                      |                                                                             |
| PR<k>_PRU<n>_GPIO3                                      |                                                                             |
| PR<k>_PRU<n>_GPIO4                                      |                                                                             |
| PR<k>_PRU<n>_GPIO5                                      |                                                                             |
| PR<k>_PRU<n>_GPIO6                                      |                                                                             |

**Table 7-52. PRU GPIO Signals and Configurations for Peripheral I/F<sup>(1)</sup>  
(continued)**

| Pad Names at Device Level <sup>(2) (3)</sup> | Peripheral I/F<br>Mode (PRU_ICSS_GPCFG0[29-26]<br>PR1_PRU0_GP_MUX_SEL = 1h) |
|----------------------------------------------|-----------------------------------------------------------------------------|
| PR<k>_PRU<n>_GPI7                            |                                                                             |
| PR<k>_PRU<n>_GPI8                            |                                                                             |
| PR<k>_PRU<n>_GPI9                            | PERIF0_IN                                                                   |
| PR<k>_PRU<n>_GPI10                           | PERIF1_IN                                                                   |
| PR<k>_PRU<n>_GPI11                           | PERIF2_IN                                                                   |
| PR<k>_PRU<n>_GPI12                           |                                                                             |
| PR<k>_PRU<n>_GPI13                           |                                                                             |
| PR<k>_PRU<n>_GPI14                           |                                                                             |
| PR<k>_PRU<n>_GPI15                           |                                                                             |
| PR<k>_PRU<n>_GPI16                           |                                                                             |
| PR<k>_PRU<n>_GPI17                           |                                                                             |
| PR<k>_PRU<n>_GPI18                           |                                                                             |
| PR<k>_PRU<n>_GPI19                           |                                                                             |
| PR<k>_PRU<n>_GPO0                            | PERIF0_CLK                                                                  |
| PR<k>_PRU<n>_GPO1                            | PERIF0_OUT                                                                  |
| PR<k>_PRU<n>_GPO2                            | PERIF0_OUT_EN                                                               |
| PR<k>_PRU<n>_GPO3                            | PERIF1_CLK                                                                  |
| PR<k>_PRU<n>_GPO4                            | PERIF1_OUT                                                                  |
| PR<k>_PRU<n>_GPO5                            | PERIF1_OUT_EN                                                               |
| PR<k>_PRU<n>_GPO6                            | PERIF2_CLK                                                                  |
| PR<k>_PRU<n>_GPO7                            | PERIF2_OUT                                                                  |
| PR<k>_PRU<n>_GPO8                            | PERIF2_OUT_EN                                                               |
| PR<k>_PRU<n>_GPO9                            |                                                                             |
| PR<k>_PRU<n>_GPO10                           |                                                                             |
| PR<k>_PRU<n>_GPO11                           |                                                                             |
| PR<k>_PRU<n>_GPO12                           |                                                                             |
| PR<k>_PRU<n>_GPO13                           |                                                                             |
| PR<k>_PRU<n>_GPO14                           |                                                                             |
| PR<k>_PRU<n>_GPO15                           |                                                                             |
| PR<k>_PRU<n>_GPO16                           |                                                                             |
| PR<k>_PRU<n>_GPO17                           |                                                                             |
| PR<k>_PRU<n>_GPO18                           |                                                                             |
| PR<k>_PRU<n>_GPO19                           |                                                                             |

(1) Usage of the Peripheral Interface signals are not restricted to only ENDAT interfaces.

(2) Note: These signals are shared with the GP, MII and Sigma Delta modes. To configure for Peripheral I/F, PRU\_ICSS\_GPCFG0[29-26] PR1\_PRU0\_GP\_MUX\_SEL needs to be set to 1h.

(3) Some devices may not pin out all 29 bits of R31 and all 32 bits of R30. For which pins are available on this device, see *PRUSS Environment*. See the device-specific Datasheet for device pin mapping.

A block diagram for the Peripheral I/F is included in [Figure 7-31](#). As shown, each channel is composed of four I/Os:

- PERIF<m>\_IN - RX input data
- PERIF<m>\_CLK - Clock (CLK\_OUT) generated by the 1x (or TX) clock. The default value is 1.

- PERIF< m >\_OUT - TX output data. The default value is 0.
- PERIF< m >\_OUT\_EN - TX enable output (1 = TX mode, 0 = RX mode). The default value is 0. Note: This signal is auto controlled by hardware.

**Figure 7-31. Peripheral I/F Block Diagram**

#### 7.4.4.2.2.3.6.2 PRU R30 and R31 Interface

The PRU uses the R30 and R31 registers to interface with the Peripheral I/F. [Table 7-53](#) shows the R31 and R30 interface for the Peripheral I/F RX mode, and [Table 7-54](#) shows the comparable interface for the TX mode.

**Table 7-53. Peripheral I/F RX**

| Register | Bits  | Field name   | Description                                                                                                                                                |
|----------|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R31      | 31-30 | Reserved     | PRU Host Interrupts 1/0 from local INTC                                                                                                                    |
|          | 29    | ovf2         | Overflow Flag for Channel 2. Write 1 to clear.                                                                                                             |
|          | 28    | ovf1         | Overflow Flag for Channel 1. Write 1 to clear.                                                                                                             |
|          | 27    | ovf0         | Overflow Flag for Channel 0. Write 1 to clear.                                                                                                             |
|          | 26    | val2         | Valid Flag for Channel 2. Write 1 to clear.                                                                                                                |
|          | 25    | val1         | Valid Flag for Channel 1. Write 1 to clear.                                                                                                                |
|          | 24    | val0         | Valid Flag for Channel 0. Write 1 to clear.                                                                                                                |
|          | 23-16 | rx_data_out2 | Oversampled Data Output for Channel 2. Note: These bits are shared with the TX Interface. When TX_FIFO has stopped transmission, RX data will be selected. |
|          | 15-8  | rx_data_out1 | Oversampled Data Output for Channel 1. Note: These bits are shared with the TX Interface. When TX_FIFO has stopped transmission, RX data will be selected. |
|          | 7:0   | rx_data_out0 | Oversampled Data Output for Channel 0. Note: These bits are shared with the TX Interface. When TX_FIFO has stopped transmission, RX data will be selected. |
| R30      | 31-27 | Reserved     |                                                                                                                                                            |
|          | 26    | rx_en2       | RX Enable for Channel 2.<br>0h: Channel not enabled, all counters/flags will get reset<br>1h: Channel is enabled                                           |
|          | 25    | rx_en1       | RX Enable for Channel 1.<br>0h: Channel not enabled, all counters/flags will get reset<br>1h: Channel is enabled                                           |
|          | 24    | rx_en0       | RX Enable for Channel 0.<br>0h: Channel not enabled, all counters/flags will get reset<br>1h: Channel is enabled                                           |
|          | 23-0  | Reserved     |                                                                                                                                                            |

**Table 7-54. Peripheral I/F TX**

| Register | Bits  | Field name                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|-------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R31      | 31-30 | Reserved                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|          | 29-22 | Reserved                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|          | 21    | tx_global_reinit_ac<br>tive/ busy2 | Tx_global_reinit action has some latency due to clocking. This status shows if action is completed.<br>1h: Active<br>0h: Done<br>For non reinit case, this bit states that last bit is on tx wire. It does not mean the clock is off.<br>1h: Last bit is not done<br>0h: Last bit on tx wire<br>Note that by using rx auto arm feature, the observation is lost at rx enable. This can be used to determine when to enable rx during non-auto arm case. |
|          | 20    | tx_global_go                       | TX global start of all channels.<br>Note: FIFO must not be empty. If empty, transmit will not start.                                                                                                                                                                                                                                                                                                                                                    |
|          | 19    | tx_global_reinit                   | Reinit all channels into default mode. This clears all flags and state machines for all channels.<br>Note: Sequence should be assert tx_global_reinit then de-assert rx_en. This will ensure TX and RX are in reset/default state. User must assert this after the frame has been sent and TX is not busy.                                                                                                                                              |

**Table 7-54. Peripheral I/F TX (continued)**

| Register | Bits  | Field name                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|-------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 18    | tx_channel_go                  | TX start the channel transmit (selected by tx_ch_sel).<br>Note: FIFO must not be empty.                                                                                                                                                                                                                                                                                                                                                                |
|          | 17    | unr2                           | Under Run Flag for Channel 2. This flag is only set when the tx_frame_count is nonzero and FIFO is empty at time to send data.                                                                                                                                                                                                                                                                                                                         |
|          | 16    | ovr2                           | Over Run Flag for Channel 2                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | 15-14 | Reserved                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|          | 13    | tx_global_reinit_active/ busy1 | Tx_global_reinit action has some latency do to clocking. This status shows if action is completed.<br>1h: Active<br>0h: Done<br>For non reinit case, this bit states that last bit is on tx wire. It does not mean the clock is off.<br>1h: Last bit is not done<br>0h: Last bit on tx wire<br>Note that by using rx auto arm feature, the observation is lost at rx enable. This can be used to determine when to enable rx during non-auto arm case. |
|          | 12-10 | tx_fifo_sts1                   | TX FIFO occupancy status for Channel 1.<br>0 :0 Empty<br>1h: 1 word<br>2h: 2 words<br>3h: 3 words<br>4h: Full<br>5h-7h: Reserved                                                                                                                                                                                                                                                                                                                       |
|          | 9     | unr1                           | Under Run Flag for Channel 1. This flag is only set when the tx_frame_count is nonzero and FIFO is empty at time to send data.                                                                                                                                                                                                                                                                                                                         |
|          | 8     | ovr1                           | Over Run Flag for Channel 1                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | 7-6   | Reserved                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|          | 5     | tx_global_reinit_active/ busy0 | Tx_global_reinit action has some latency do to clocking. This status shows if action is completed.<br>1h: Active<br>0h: Done<br>For non reinit case, this bit states that last bit is on tx wire. It does not mean the clock is off.<br>1h: Last bit is not done<br>0h: Last bit on tx wire<br>Note that by using rx auto arm feature, the observation is lost at rx enable. This can be used to determine when to enable rx during non-auto arm case. |
|          | 4-2   | tx_fifo_sts0                   | TX FIFO occupancy status for Channel 0.<br>0h: Empty<br>1h: 1 word<br>2h: 2 words<br>3h: 3 words<br>4h: Full<br>5h-7h: Reserved                                                                                                                                                                                                                                                                                                                        |
|          | 1     | unr0                           | Under Run Flag for Channel 0. This flag is only set when the tx_frame_count is nonzero and FIFO is empty at time to send data.                                                                                                                                                                                                                                                                                                                         |
|          | 0     | ovr0                           | Over Run Flag for Channel 0                                                                                                                                                                                                                                                                                                                                                                                                                            |
| R30      | 31-21 | Reserved                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**Table 7-54. Peripheral I/F TX (continued)**

| Register | Bits      | Field name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|-----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 20-19     | clk_mode   | CLK_OUT mode.<br>0h: Free-running/stop-low.<br>Clock will remain free-running until the receive module has received the number of bits indicated in rx_frame_counter and then the clock will stop low.<br>1h: Free-running/stop-high (default).<br>Clock will remain free-running until the receive module has received the number of bits indicated in rx_frame_counter and then the clock will stop high. Note: This is the default/reset state, and a hardware reset or reinit will return clk_mode to this state. Note: The initial state of the clock will be high, but the clock will not start until TX GO event.<br>2h: Free-run.<br>NOTE: You must do a reinit to get out of this clock mode then you can update clk_mode to a different mode. Also if you do multiple TX GO, the 2nd go should have tst_delay and wire_delay zero since the clock is free running after the first go.<br>3h: Stop high after transmit. Clock will run until the last TX bit is sent and stops high. |
| 18       | Reserved  |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17-16    | tx_ch_sel |            | TX channel select.<br>0h: Channel 0<br>1h: Channel 1<br>2h: Channel 2<br>3h: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15-9     | Reserved  |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7-0      | tx_data   |            | TX data for FIFO.<br>Notes: FIFO transmits MSB first and is 32-bits deep. TX_FIFO_SWAP_BITS bit in the PRUSS CFG register space can be used to flip the load order of bits.<br>The FIFO has 2 modes of operation:<br>1. Preload and Go. This should be done for EnDAT and frames less than 32-bits.<br>2. Continuous mode. This should be done for frames bigger than 32-bits. In continuous mode, software needs to keep up with the line rate and ensure that the FIFO is never empty. When the FIFO is at 2 byte level, software needs to load the next 2 bytes. If software waits till the end of the empty state, it is possible to get the TX into a bad state. The FIFO state can be recovered via re-init.                                                                                                                                                                                                                                                                            |

---

### Note

The PRUSS CFG register space has additional registers for controlling the Peripheral I/F module.

---

#### 7.4.4.2.2.3.6.3 Clock Generation

##### 7.4.4.2.2.3.6.3.1 Configuration

The Peripheral I/F module has two source clock options, PRU\_ICSS\_UART\_CLK (default) and PRU\_ICSS\_ICLK. There are two independent clock dividers (div16) for the 1x and oversampling (OS) clocks, and each clock divider is configurable by two cascading dividers:

- [31-16] PRU0\_ED\_TX\_DIV\_FACTOR and [15] PRU0\_ED\_TX\_DIV\_FACTOR\_FRAC for the 1x clock
- [31-16] PRU0\_ED\_RX\_DIV\_FACTOR and [15] PRU0\_ED\_RX\_DIV\_FACTOR\_FRAC for the OS clock

The 1x clock is output on the PERIF<m>\_CLK signal. In TX mode, the output data is read from the TX FIFO at this 1x clock rate. The default value of this clock is high and the start and stop conditions for this clock are described in [Section 4.4.2.2.3.6.3.2 Clock Output Start Conditions](#) and [Section 4.4.2.2.3.6.3.3 Stop Conditions](#).

In RX mode, the input data is sampled at the OS clock rate. Note: The OS clock rate divided by the 1x clock rate must equal [2-0] PRU0\_ED\_RX\_SAMPLE\_SIZE.

Example clock rates and divisor values relative to the 192-MHz PRU\_ICSS\_UART\_CLK source are shown in [Table 7-55](#).

**Table 7-55. Clock Rate Examples for 192-MHz PRUSSn\_UART\_GFCLK Clock Source**

| TX_DIV_FACTOR | 1x Clock | RX_DIV_FACTOR | RX_DIV_FACTOR_FRAC | OS Clock | Oversample Factor |
|---------------|----------|---------------|--------------------|----------|-------------------|
| 12            | 16 MHz   | 1             | 1.5                | 128 MHz  | 8x                |

**Table 7-55. Clock Rate Examples for 192-MHz PRUSSn\_UART\_GFCLK Clock Source (continued)**

| TX_DIV_FACTOR | 1x Clock | RX_DIV_FACTOR | RX_DIV_FACTOR_FRAC | OS Clock | Oversample Factor |
|---------------|----------|---------------|--------------------|----------|-------------------|
| 16            | 12 MHz   | 2             | 1                  | 96 MHz   | 8x                |
| 24            | 8 MHz    | 3             | 1                  | 64 MHz   | 8x                |
| 32            | 6 MHz    | 4             | 1                  | 48 MHz   | 8x                |
| 48            | 4 MHz    | 6             | 1                  | 32 MHz   | 8x                |
| 96            | 2 MHz    | 12            | 1                  | 16 MHz   | 8x                |
| 192           | 1 MHz    | 24            | 1                  | 8 MHz    | 8x                |

#### 7.4.4.2.2.3.6.3.2.2 Clock Output Start Conditions

This section describes the configurable start conditions for the PERIF<m>\_CLK. The software can completely control via PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0 when bit [29] PRU0\_ED\_CLK\_OUT\_OVR\_ENm = 1h (where n = 0 or 1 and m = 0 to 2). By default however, the PRU hardware will control the clocks as described in the following sections.

##### 7.4.4.2.2.3.6.3.2.1 TX Mode (RX\_EN = 0)

In TX mode, the PERIF<m>\_CLK begins after the firmware loads the TX FIFO and sets either r31[20] (tx\_global\_go) or r30[17-16] (tx\_channel\_go) to 1h. After the “go” bit is set, the delay1 (wire delay) compensation counter for each channel begins. After delay1 is complete, PERIF<m>\_CLK is driven low and then the delay2 (tst) counter begins. After the delay2 counter expires, the PERIF<m>\_CLK starts running (first low and then high). Therefore, first rising edge of PERIF<m>\_CLK (measured from the go bit) = delay1 (tx wire delay) + delay2 (tst\_counter delay) + half of the 1x clock frequency (since the clock starts low).

Figure 7-32 shows the start condition for TX mode. As shown in the figure, the default value of clock is high. The PRUSS CFG register space has additional registers for controlling the TX start timing delay values:

- Delay 1: PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[10-0] PRU0\_ED\_TX\_WDLYm (where n = 0 or 1 and m = 0 to 2)
- Delay 2: PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[15-0] PRU0\_ED\_TST\_DELAY\_COUNTERm (where n = 0 or 1 and m = 0 to 2)

**Figure 7-32. TX Mode Start Condition**

##### 7.4.4.2.2.3.6.3.2.2 RX Mode (RX\_EN = 1)

In RX mode, the PERIF<m>\_CLK will start running whenever the RX\_EN is set. Note that the PRU firmware in this mode is responsible for any delay conditions.

The hardware can also auto-enable RX mode at the end of a TX transaction. The PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[31-16] PRU0\_ED\_RX\_EN\_COUNTERm (where n = 0 or 1 and m = 0 to 2) is used to program a delay between the last TX bit sent and when the RX\_EN is set.

#### 7.4.4.2.2.3.6.3.3 Stop Conditions

The r30[20-19] (clk\_mode[1:0]) value determines the stop condition for PERIF<m>\_CLK. There are 4 options available:

| clk_mode_value | Description                |
|----------------|----------------------------|
| 0              | Stop low on last RX frame  |
| 1              | Stop high on last RX frame |
| 2              | Run continuously           |
| 3              | Stop high on last TX bit   |

The last RX frame is configured by PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[27-16] PRU0\_ED\_RX\_FRAME\_SIZE $m$ , and the last TX bit is configured by PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[15-11] PRU0\_ED\_TX\_FRAME\_SIZE $m$  (where  $n = 0$  or  $1$  and  $m = 0$  to  $2$ ). Each stop condition is shown in [Figure 7-33](#) through [Figure 7-36](#).



**Figure 7-33. PERIF<math>m</math>\_CLK Stop High on Last RX Frame**



**Figure 7-34. PERIF< m >\_CLK Stop Low on Last RX Frame**



**Figure 7-35. PERIF<m>\_CLK Run Continuously**



**Figure 7-36. PERIF<m>\_CLK Stop High on Last TX Bit**

#### 7.4.4.2.2.3.6.4 Three Peripheral Mode Basic Programming Model

The following programming models assume that the PRU is configured for 3 Peripheral Mode (PRU\_ICSS\_GPCFG0[29-26] PR1\_PRU0\_GP\_MUX\_SEL = 1h).

##### 7.4.4.2.2.3.6.4.1 Clock Generation

Follow these steps to configure Peripheral I/F clocks using the HW control of the clock:

1. Select TX and RX clock sources:
  - a. PRU\_ICSS\_PRU0\_ED\_TX\_CFG\_REG[4] PRU0\_ED\_TX\_CLK\_SEL for the TX clock source
  - b. PRU\_ICSS\_PRU0\_ED\_RX\_CFG\_REG[4] PRU0\_ED\_RX\_CLK\_SEL for the RX clock source
2. Configure the 1x (TX) clock frequency:
  - a. Write Division Factor to PRU\_ICSS\_PRU0\_ED\_TX\_CFG\_REG[31-16] PRU0\_ED\_TX\_DIV\_FACTOR
  - b. Write Fraction division factor to PRU\_ICSS\_PRU0\_ED\_TX\_CFG\_REGISTER[15] PRU0\_ED\_TX\_DIV\_FACTOR\_FRAC
3. Configure the oversampling (RX) frequency and oversample size:
  - a. Write Division Factor to PRU\_ICSS\_PRU0\_ED\_RX\_CFG\_REG[31-16] PRU0\_ED\_RX\_DIV\_FACTOR
  - b. Write Fraction division factor to PRU\_ICSS\_PRU0\_ED\_RX\_CFG\_REG[15] PRU0\_ED\_RX\_DIV\_FACTOR\_FRAC
  - c. Write RX oversample size to PRU\_ICSS\_PRU0\_ED\_RX\_CFG\_REG[2-0] PRU0\_ED\_RX\_SAMPLE\_SIZE
4. Select the clk\_mode to configure how the PERIF<m>\_CLK signal ends after TX/RX:
  - a. Write to r30[20-19] (clk\_mode). Note: The clk\_mode setting can also be changed per transaction.
5. Configure the wire, tst, and rx\_en\_counter delay values:
  - a. PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[10-0] PRU0\_ED\_TX\_WDLYm for wire delay (where n = 0 or 1 and m = 0 to 2)

- b. PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[15-0] PRU0\_ED\_TST\_DELAY\_COUNTERm for tst delay (where n = 0 or 1 and m = 0 to 2)
- c. PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[31-16] PRU0\_ED\_RX\_EN\_COUNTER for auto-delay between TX and RX (where n = 0 or 1 and m = 0 to 2)

#### 7.4.4.2.2.3.6.4.2 TX - Single Shot

Follow these steps to configure the Peripheral I/F channel(s) for a single shot transmission:

1. (Optional) Configure TX FIFO for MSB (default) or LSB:
  - a. PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[31] PRU0\_ED\_TX\_FIFO\_SWAP\_BITSm (where n = 0 or 1 and m = 0 to 2)
2. Pre-load TX FIFO:
  - a. Select TX channel by writing the desired channel number to R30[17-16] (tx\_ch\_sel)
  - b. Write 1-4 bytes of data to r30[7-0] (tx\_data). At each r30[7-0] write, data will be pushed into the FIFO.
  - c. Repeat Steps 2a and 2b for all desired channels.
3. Configure TX frame size if less than 4 full bytes loaded into FIFO:
  - a. PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[15-11] PRU0\_ED\_TX\_FRAME\_SIZEm (where n = 0 or 1 and m = 0 to 2)
4. Push TX FIFO data to PERIF<m>\_OUT (see [Section 4.4.2.2.3.6.3.2](#) for the PERIF<m>\_CLK and PERIF<m>\_OUT start time relationship):
  - a. To start TX on all channels, set r31[20] = 1 (tx\_global\_go).
  - b. To start TX on individual channel:
    - i. Select TX channel by writing the desired channel number to R30[17-16] (tx\_ch\_sel)
    - ii. Set R31[18] = 1 (tx\_channel\_go)
5. If PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[31-16] PRU0\_ED\_RX\_EN\_COUNTERm > 0 (where n = 0 or 1 and m = 0 to 2), then the channel will automatically switch into RX mode. See [Section 4.4.2.2.3.6.4.4](#) for an example of how to program and configure RX content.
6. If PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[31-16] PRU0\_ED\_RX\_EN\_COUNTERm = 0, poll either r31[21, 13, or 5] (tx\_global\_reinit\_active/busy[2,1,0]) or PRU\_ICSS\_PRU0\_ED\_TX\_CFG\_REG[7, 6, or 5] PRU0\_ED\_BUSY\_m (where m = 0 to 2, indicates channel number) for when TX is complete

---

#### Note

The PERIF<m>\_CLK Peripheral I/F requires that PERIF<m>\_CLK be in a high state at the beginning of a new transaction. If the clock ended the single shot transmission in low state, then the clock needs to be reset before sending more data. The steps to reset PERIF<m>\_CLK are:

1. Set R31[19] = 1 (tx\_global\_reinit) to reset clock high
  2. Wait until PRU0\_ED\_BUSY\_m bit is cleared
  3. Re-configure R30[20-19] (clk\_mode), since reinit will reset the clk\_mode to "Free-running/stop-high" mode
- 

#### 7.4.4.2.2.3.6.4.3 TX - Continuous FIFO Loading

Follow these steps to configure the Peripheral I/F channel(s) for a continuous loading transmission:

1. (Optional) Configure TX FIFO for MSB (default) or LSB:
  - a. PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[31] PRU0\_ED\_TX\_FIFO\_SWAP\_BITSm
2. Pre-load TX FIFO:
  - a. Select TX channel by writing the desired channel number to r30[17-16] (tx\_ch\_sel)
  - b. Write 1-4 bytes of data to r30[7-0] (tx\_data). At each r30[7-0] write, data will be pushed into the FIFO.
  - c. Repeat Steps 2a and 2b for all desired channels.
3. Configure TX frame size to continuously transmit the TX FIFO until empty:
  - a. Set PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[15-11] PRU0\_ED\_TX\_FRAME\_SIZEm = 0h
4. Push TX FIFO data to PERIF<m>\_OUT (see [Section 4.4.2.2.3.6.3.2](#) for the PERIF<m>\_CLK and PERIF<m>\_OUT start time relationship):

- a. To start TX on all channels, set r31[20] = 1 (tx\_global\_go).
- b. To start TX on individual channel:
  - i. Select TX channel by writing the desired channel number to r30[17-16] (tx\_ch\_sel)
  - ii. Set r31[18] = 1 (tx\_channel\_go)
5. Monitor line rate and reload FIFO:
  - a. Polling r31[xx, 12-10, 4-2] (tx\_fifo\_sts<m>)
  - b. When FIFO level is at 2 bytes, load next 2 bytes of data (see Step 2). Do not let the FIFO get close to 0. Once the FIFO runs empty, the hardware will assume the PRU has reached end of the last transmit. Any new writes to the FIFO will NOT be sent until the software sends another tx\_channel\_go bit. Note: There are also underrun and overrun error flags that can be monitored.
6. To end TX operation, do not send any new data to FIFO.
  - a. If PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[31-16] PRU0\_ED\_RX\_EN\_COUNTERm > 0 (where n = 0 or 1 and m = 0 to 2), then the channel will automatically switch into RX mode. See [Section 4.4.2.2.3.6.4.4](#) for an example of how to program and configure RX content.
  - b. If PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[31-16] PRU0\_ED\_RX\_EN\_COUNTERm = 0, poll either r31[21, 13, or 5] (tx\_global\_reinit\_active/busy[2,1,0]) or PRU\_ICSS\_PRU0\_ED\_TX\_CFG\_REG[7, 6, or 5] PRU0\_ED\_BUSY\_m (where m = 0 to 2, indicates channel number) for when TX is complete

#### Note

The PERIF<m>\_CLK Peripheral I/F requires that PERIF<m>\_CLK be in a high state at the beginning of a new transaction. If the clock ended the continuous loading transmission in low state, then the clock needs to be reset before sending more data. The steps to reset PERIF<m>\_CLK are:

1. Set R31[19] = 1 (tx\_global\_reinit) to reset clock high
2. Wait until PRU0\_ED\_BUSY\_m is cleared
3. Re-configure R30[20-19] (clk\_mode), since reinit will reset the clk\_mode to "Free-running/stop-high" mode

#### 7.4.4.2.2.3.6.4.4 RX - Auto Arm or Non-Auto Arm

Follow these steps to configure the Peripheral I/F channel(s) to receive data:

1. Configure RX and frame size:
  - a. PRU\_ICSS\_PRU0\_ED\_CHm\_CFG0\_REG[27-16] PRU0\_ED\_RX\_FRAME\_SIZEm (where n = 0 or 1 and m = 0 to 2)
2. Configure start bit polarity:
  - a. PRU\_ICSS\_PRU0\_ED\_RX\_CFG\_REG[3] RX\_SB\_POL (PRU0 or PRU1)
  - b. For the non-auto arm use case, set r30[26, 25, 24] = 1 (rx\_en<m>)
  - c. For the auto arm use case, rx\_en<m> will be automatically enabled at the end of a TX operation when PRU\_ICSS\_PRU0\_ED\_CHm\_CFG1\_REG[31-16] PRU0\_ED\_RX\_EN\_COUNTERm > 0 (where n = 0 or 1 and m = 0 to 2)
3. RX FIFO will start filling on the first start bit (PERIF<m>\_IN = 1). The data will be captured on the positive edge of the PERIF<m>\_CLK and shifted into the LSB position of the 8-bit shadow register.
4. Poll for r31[26, 25, 24] (val<m>) assertion. The valid flag will be asserted when n bits of data (determined by PRU\_ICSS\_PRU0\_ED\_RX\_CFG\_REG[2-0] PRU0\_ED\_RX\_SAMPLE\_SIZE) have been collected.
5. Fetch data by reading r31[23-16, 15-8, 7-0] (rx\_data\_out<m>). The data will remain constant for one data frame, and PRU must read data and clear valid flag within this time. Otherwise, an overflow will occur – r31[29, 28, 27] (ovf<m>) = 1 - indicating that val<m> has been continuously asserted for longer than one data frame.
6. The clock will be stopped based on the r30[20-19] (clk\_mode) configured before the start of the RX operation.
7. Clear r30[26, 25, 24] (rx\_en<m>) to disable RX mode. All counters and flags will be reset.

#### 7.4.4.3 PRUSS RAM Index Allocation

The PRUSS module includes integrated ECC Aggregator module to test ECC functionality.

**Table 7-56** shows the mapping of the RAM IDs to the ECC RAMs serviced by the ECC Aggregator.

**Table 7-56. Mapping of the RAM IDs to the ECC RAMs**

| RAM Index | ECC RAM Prefix  | Description                    |
|-----------|-----------------|--------------------------------|
| 0         | pr<k>_dram0     | Data RAM0 (8KB)                |
| 1         | pr<k>_dram1     | Data RAM1 (8KB)                |
| 2         | pr<k>_pru0_iram | PRU0 Instruction Memory (16KB) |
| 3         | pr<k>_pru1_iram | PRU1 Instruction Memory (16KB) |
| 4         | pr<k>_ram       | Shared Data RAM2 (32KB)        |

## 7.4.5 PRUSS Broadside Accelerators

### 7.4.5.1 PRUSS Broadside Accelerators Overview

The PRUSS supports a broadside interface, which uses the XFR (XIN, XOUT, or XCHG) instruction to transfer the contents of PRU $n$  (where  $n = 0$  or  $1$ ) registers to or from accelerators. This interface enables up to 31 registers (R0-R30, or 124 bytes) to be transferred in a single instruction. This section details the various accelerators that are available to the PRU $n$  through the broadside interface.

Each of those functions have a unique XIN ID to determine which operation will occur. For more information see [Table 7-32](#).

### 7.4.5.2 PRUSS Data Processing Accelerators Functional

#### 7.4.5.2.1 PRU Multiplier with Accumulation (MPY/MAC)

This section describes the MAC (multiplier with accumulation) module integrated to PRU0/PRU1 cores.

Each of the two PRU cores (PRU0/PRU1) has a designated unsigned multiplier with accumulation (MPY/MAC). The MAC supports two modes of operation: Multiply Only and Multiply and Accumulate.

The MAC is directly connected with the PRU internal registers R25-R29 and uses the broadside load/store PRU interface and XFR instructions to both control and mode of the MAC and import the multiplication results into the PRU.

The PRU MPY/MAC features are:

- Configurable Multiply Only and Multiply and Accumulate functionality via PRU register R25
- 32-bit operands with direct connection to PRU registers R28 and R29
- 64-bit result (with carry flag) with direct connection to PRU registers R26 and R27
- One clock cycle per operation
- PRU broadside interface and XFR instructions (XIN, XOUT) allow for importing multiplication results and initiating accumulate function

#### 7.4.5.2.1.1 PRU MAC Operations

##### 7.4.5.2.1.1.1 PRU versus MAC Interface

The MAC directly connects with the PRU internal registers R25-R29 through use of the PRU broadside interface and XFR instructions. [Figure 7-37](#) shows the functionality of each register.



icss-022

**Figure 7-37. Integration of the PRU and MPY/MAC**

The XFR instructions (XIN and XOUT) are used to load/store register contents between the PRU core and the MAC. These instructions define the start, size, direction of the operation, and device ID. The device ID number corresponding to the MPY/MAC is shown in [Table 7-57](#).

**Table 7-57. MPY/MAC XFR ID**

| Device ID | Function        |
|-----------|-----------------|
| 0         | Selects MPY/MAC |

The PRU register R25 is mapped to the MAC\_CTRL\_STATUS register ([Table 7-58](#)). The MAC's current status (MAC\_MODE and ACC\_CARRY states) is loaded into R25 using the XIN command on R25. The PRU sets the MAC's mode and clears the ACC\_CARRY using the XOUT command on R25.

**Table 7-58. MAC\_CTRL\_STATUS Register (R25) Field Descriptions**

| Bit | Field     | Description                                                                                                                                                         |
|-----|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-2 | RESERVED  | Reserved                                                                                                                                                            |
| 1   | ACC_CARRY | Write 1 to clear.<br>It is sticky.<br>It is set 0 cycles after the event.<br>0h: 64-bit accumulator carry has not occurred<br>1h: 64-bit accumulator carry occurred |
| 0   | MAC_MODE  | 0h: Accumulation mode disabled and accumulator is cleared<br>1h: Accumulation mode enabled                                                                          |

The two 32-bit operands for the multiplication are loaded into R28 and R29. These registers have a direction connection with the MAC. Therefore, XOUT is not required to load the MAC. In multiply mode, the MAC samples these registers every clock cycle. In multiply and accumulate mode, the MAC samples these registers every XOUT R25[7-0] transaction when MAC\_MODE = 1.

The product from the MAC is linked to R26 (lower 32 bits) and R27 (upper 32 bits). The product is loaded into register R26 and R27 using XIN.

#### 7.4.5.2.1.1.2 Multiply only mode(default state), MAC\_MODE = 0

The Figure 7-38 summarizes the MAC operation in "Multiply-only" mode, in which the MAC multiplies the contents of R28 and R29 on every clock cycle.



icss-023

**Figure 7-38. MAC Multiply-only Mode- Functional Diagram**

#### 7.4.5.2.1.1.2.1 Programming PRU MAC in "Multiply-ONLY" mode

The following steps are performed by the PRU firmware for multiply-only mode:

1. 1. Enable multiply only MAC\_MODE.
  - a. (a) Clear R25[0] for multiply only mode.
  - b. (b) Store MAC\_MODE to MAC using XOUT instruction with the following parameters:
    - Device ID = 0
    - Base register = R25
    - Size = 1
2. 2. Load operands into R28 and R29.
3. 3. Delay at least 1 PRU cycle before executing XIN in step 4.
4. 4. Load product into PRU using XIN instruction on R26, R27.

Repeat steps 2 and 4 for each new operand.

#### 7.4.5.2.1.1.3 Multiply and Accumulate Mode, MAC\_MODE = 1

The Figure 7-39 summarizes the MAC operation in "Multiply and Accumulate" mode. On every XOUT R25\_REG[7-0] transaction, the MAC multiplies the contents of R28 and R29, adds the product to its accumulated result, and sets ACC\_CARRY if an accumulation overflow occurs.



icss-024

**Figure 7-39. MAC Multiply and Accumulate Mode Functional Diagram**

#### 7.4.5.2.1.1.3.1 Programming PRU MAC in Multiply and Accumulate Mode

The following steps are performed by the PRU firmware for multiply and accumulate mode:

1. Enable multiply and accumulate MAC\_MODE.

- (a) Set R25[1-0] = 1 for accumulate mode.
  - (b) Store MAC\_MODE to MAC using XOUT instruction with the following parameters:
    - Device ID = 0
    - Base register = R25
    - Size = 1
2. Clear accumulator and carry flag.
- (a) Set R25[1-0] = 3 to clear accumulator (R25[1]=1) and preserve accumulate mode (R25[0]=1).
  - (b) Store accumulator to MAC using XOUT instruction on R25.
3. Load operands into R28 and R29.
4. Multiply and accumulate, XOUT R25[1-0] = 1
- Repeat step 4 for each multiply and accumulate using same operands.
- Repeat step 3 and 4 for each multiply and accumulate for new operands.
5. Load the accumulated product into R26, R27, and the ACC\_CARRY status into R25 using the XIN instruction.

---

**Note**

Steps one and two are required to set the accumulator mode and clear the accumulator and carry flag.

---

#### 7.4.5.2.2 PRU CRC16/32 Module

Each of the PRU0/PRU1 cores have a designated CRC16/32 module.

In general, CRC adds error detection capability to communication systems. The CRC encoder appends redundant bits (or CRC bits) to the systematic data message. During reception of the data message, the received data is also encoded with the same CRC encoder. The 2 sets of CRC bits are compared together. If they match, there were no transmission errors; and if they don't match, a transmission error has been detected.

CRC16/32 supports the following features:

- Supports CRC32:
  - $x^{32}+x^{26}+x^{23}+x^{22}+x^{16}+x^{12}+x^{11}+x^{10}+x^8+x^7+x^5+x^4+x^2+x+1$
- Supports CRC16:
  - $x^{16}+x^{15}+x^2+1$
- Supports CRC16 - CCITT:
  - $x^{16}+x^{12}+x^5+1$
- PRU broadside interface and XFR instructions (XIN, XOUT) allow for importing CRC results and executing accumulate function

#### 7.4.5.2.2.1 PRU and CRC16/32 Interface

The CRC16/32 module directly connects with the PRU internal registers R25-R29 through use of the PRU broadside interface and XFR instructions. [Table 7-59](#) shows the functionality of each register.

The XFR instructions (XIN/XOUT/XCHG) are used to load/store register contents between the PRU core and the CRC16/32 module. These instructions define the start, size, direction of the operation, and device ID. The XFR device ID number corresponding to the CRC16/32 module is 1.

**Table 7-59. CRC Register to PRU Port Mapping**

| CRC Register     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PRU Mapping |
|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| CRC_CFG          | W   | <p>Always write all 4 bytes.</p> <p>bit [0] CRC32_ENABLE:<br/>0: CRC16 mode is selected. Hardware will auto-set init state of CRC_SEED to 0000_0000h. However, for CRC16-CCITT software will need to write the init state of FFFF_FFFFh to CRC_SEED. Note: The CRC16 result value is only 16-bits.</p> <p>1: CRC32 mode is selected. Hardware will auto-set init state of CRC_SEED will be FFFF_FFFFh.</p> <p>bit [1] CRC_32B_NOT_EMPTY:<br/>0: CRC 32Byte buffer is empty<br/>1: CRC 32Byte buffer is not empty</p> <p>bit [2] CRC16_MOD_ENABLE:<br/>0: CRC16 (<math>x^{16}+x^{15}+x^2+1</math>)<br/>1: CRC16-CCITT (<math>x^{16}+x^{12}+x^5+1</math>) - Note: CRC32_ENABLE field must = 0.</p> | R25         |
| CRC_DATA_8_BFLIP | R   | <p>8-bit flip of CRC_DATA. CRC_DATA_8_BFLIP has the same byte order as CRC_DATA[31-0], but each byte has all bits flipped.</p> <p>CRC_DATA_32_FLIP[7-0] = CRC_DATA[0-7]<br/>CRC_DATA_32_FLIP[15-8] = CRC_DATA[8-15]<br/>CRC_DATA_32_FLIP[23-16] = CRC_DATA[16-23]<br/>CRC_DATA_32_FLIP[31-24] = CRC_DATA[24-31]</p> <p>For CRC16, only CRC_DATA_8_BFLIP[15-0] are valid. No auto reset on CRC_DATA_8_BFLIP read.</p>                                                                                                                                                                                                                                                                             | R27         |
| CRC_SEED         | W   | <p>CRC SEED value.</p> <p>Hardware will auto-initialize the CRC_SEED value to 0000_0000h for CRC16 and FFFF_FFFFh for CRC32. Software only needs to initialize CRC_SEED if a different default value is required. For CRC16-CCITT, software needs to update initial CRC_SEED value to FFFF_FFFFh.</p> <p>Always write 4 bytes.</p> <p>Note: Reading the CRC_DATA register will reset the CRC value to the CRC_SEED state.</p>                                                                                                                                                                                                                                                                    | R28         |

**Table 7-59. CRC Register to PRU Port Mapping (continued)**

| CRC Register      | R/W | Description                                                                                                                                                                                                                                                                                                                                                                      | PRU Mapping |
|-------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| CRC_DATA_32_BFLIP | R   | Full 32-bit flip of CRC_DATA<br>CRC_DATA_32_BFLIP[0] = CRC_DATA[31] ...<br>CRC_DATA_32_BFLIP[31] = CRC_DATA[0]<br>For CRC16, only CRC_DATA_32_BFLIP[31-16] are valid.<br>No auto reset on CRC_DATA_32_BFLIP read.                                                                                                                                                                | R28         |
| CRC_DATA          | RW  | For Write, must use a fixed width throughout the session. The CRC module supports lower 8-bit, or lower 16-bit, or full 32-bit data widths.<br>For Read, LSB or CRC_DATA[0] is first bit on the wire.<br>For Read, reset the CRC_DATA back to CRC_SEED state.<br>Note: Firmware must add 1 to 2 NOPs after the last XOUT to the XIN.<br>For CRC16, only CRC_DATA[15-0] is valid. | R29         |

#### 7.4.5.2.2.2 CRC Programming Model

The following steps are performed by the PRU firmware to use the CRC module:

##### Step1: Configuration (optional)

1. Configure CRC type:  
For CRC32 operation, set CRC32\_ENABLE using XOUT instruction with the following parameters:
  - Device ID = 1
  - Base register = R25
  - Size = 1
2. Update CRC\_SEED, if required using XOUT with the following parameters:
  - Device ID = 1
  - Base register = R28
  - Size = 1 to 4

##### Step 2:

1. Load new CRC data into R29
2. Push CRC data to the CRC16/32 module using XOUT with the following parameters:
  - Device ID = 1
  - Base register = R29
  - Size = 1 to 4
3. 1 or 2 NOPs
4. Load the accumulated CRC result into the PRU using the XIN instruction with the following parameters:
  - Device ID = 1
  - Base register = R29
  - Size = 4

Repeat Step 2, numbers 1 and 2 for each new CRC data.

---

##### Note

When a session starts, the PRU firmware must use the same write data width throughout the session.

---

#### 7.4.5.2.2.3 PRU and CRC16/32 Interface (R9:R2)

The PRUSS system implements a new wide 32-Bytes data path. The firmware can perform one XOUT of 32-Bytes, the hardware will feed the CRC16/32 4-Bytes at a time. This will take 20 clock cycles for CRC16 and 12 clock cycles for CRC32 for a 32-Bytes XOUT.

**Table 7-60. PRU Register to XFR Mapping**

| PRU Register | XFR ID | Domain/Function | Description                             |
|--------------|--------|-----------------|-----------------------------------------|
| R9:R2 Data   | 1      | Data            | XOUT Only<br>1-Byte to 32-Bytes in size |

**Table 7-60. PRU Register to XFR Mapping (continued)**

| PRU Register | XFR ID | Domain/Function | Description                                                                                                                                               |
|--------------|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |        |                 | LSB packed and no gaps, for example:<br>32-Bytes push R9:R2<br>16-Bytes push R5:R2<br>4-Bytes push R2<br>7-Bytes push R3(b2.b0):R2<br>1-Bytes push R2(b0) |

#### 7.4.5.2.3 PRUSS Scratch Pad Memory

The PRUSS supports a scratch pad with up to four independent banks accessible by the PRU cores. The PRU cores interact with the scratch pad through broadside load/store PRU interface and XFR instructions. The scratch pad can be used as a temporary place holder for the register contents of the PRU.

##### 7.4.5.2.3.1 PRU0/1 Scratch Pad Overview

The PRUSS scratch pad supports the following features:

- PRU0 and PRU1 cores have three Scratch Pad banks of 30, 32-bit registers (R29 to R0)
- Flexible load/store options:
  - Load/store one byte of R<n> or load/store (R29 to R0) to Bank0, Bank1, Bank2 or Bank3
  - User-defined start byte and length of the transfer
  - Length of transfer ranges from one byte of a register to the entire register content (R29 to R0)
  - Simultaneous transaction supported between PRU0 <-> Bank<n> and PRU1 <-> Bank<m>
- XFR (XIN/XOUT/XCHG) instructions operate in one clock cycle
- Optional XIN/XOUT shift functionality allows remapping of registers (R<n> -> R<m>) during load store operation

Figure 7-40 shows a simplified model of the Scratch Pad and PRU cores integration.



icss-025

**Figure 7-40. Scratch Pad and PRU Integration**

##### 7.4.5.2.3.2 PRU0 /1 Scratch Pad Operations

XFR instructions are used to load/store register contents between the PRU cores and the scratch pad banks. These instructions define the start, size, direction of the operation, and device ID. The device ID corresponds to the external source or destination (either a scratch pad bank or the other PRU core). The device ID numbers are shown in Table 7-61.

**Table 7-61. Scratch Pad XFR ID**

| Device ID | Function/Operation |
|-----------|--------------------|
| 10        | Selects Bank0      |
| 11        | Selects Bank1      |

**Table 7-61. Scratch Pad XFR ID (continued)**

| Device ID | Function/Operation |
|-----------|--------------------|
| 12        | Selects Bank2      |

A collision occurs when two XOUT commands simultaneously access the same asset or device ID. [Table 7-62](#) shows the priority assigned to each operation when a collision occurs.

**Table 7-62. Scratch Pad XFR Collision and Stall Conditions**

| Operation                | Collision and Stall Handling                                                                                                                   |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| PRU<n> XOUT (->) bank[j] | If both PRU cores access the same bank simultaneously, PRU0 is given priority. PRU1 will temporarily stall until the PRU0 operation completes. |

#### 7.4.5.2.3.2.1 Optional XIN/XOUT Shift

The optional XIN/XOUT shift functionality allows register contents to be remapped or shifted within the destination's register space. For example, the contents of PRU0 R6-R8 could be remapped to Bank1 R10-12.

The shift feature is enabled or disabled through the PRU subsystem level register PRU\_ICSS\_SPP\_REG[1] XFR\_SHIFT\_EN bit. When enabled, R0[4-0] (internal to the PRU) defines the number of 32-bit registers in which content is shifted in the scratch pad bank. Note that scratch pad banks do not have registers R30 or R31.

#### 7.4.5.2.3.2.2 Scratch Pad Operations Examples

The following PRU firmware examples demonstrate the shift functionality. Note: These assume the XFR\_SHIFT\_EN bit of the PRU\_ICSS\_SPP\_REG register of the PRUSS CFG register space has been set.

##### XOUT Shift By 4 Registers

Store R4:R7 to R8:R11 in Bank0:

- Load 4 into R0.b0
- XOUT using the following parameters:
  - Device ID = 10
  - Base register = R4
  - Size = 16

##### XOUT Shift By 9 Registers, With Wrap Around

Store R25:R29 to R4:R9 in Bank1:

- Load 9 into R0.b0
- XOUT using the following parameters:
  - Device ID = 11
  - Base register = R25
  - Size = 20

##### XIN Shift By 10 Registers

Load R14:R16 from Bank2 to R4:R6:

- Load 10 into R0.b0
- XIN using the following parameters:
  - Device ID = 12
  - Base register = R4
  - Size = 12

#### 7.4.5.3 PRUSS Data Movement Accelerators Functional

##### 7.4.5.3.1 PRUSS XFR2VBUS Hardware Accelerator

The PRU core can write and read data packets to and from port queues, located in the MSMC SRAM into PRU core registers via XFR2VBUS hardware accelerator. Each of the PRUSS Slices has implemented two RX XFR2VBUS hardware accelerators.



1. n represents a valid instance of PRU in a domain.

**Figure 7-41. XFR2VBUS Hardware Accelerator**

Supported features:

- 2 x XFR2VBUS RX threads

XFR2VBUS RX buffer features:

- 1 x 64 Byte deep RX/Read buffer
  - 4 Byte, 32 Byte, or 64 Byte read size per RD (read) command
  - Optional automatic read command with incrementing address on pop of read data
  - 32 Byte optimization mode available

The ownership of commands and data is flexible. The XFR2VBUS accelerator is shared between PRU cores. Status is available to both cores.

Note: The ownership should be preplanned and static per use model.

The XFR2VBUS is a simple hardware accelerator which is used to get the lowest read round trip latency from MSMC and to decouple the latency seen by the PRU. Each XFR2VBUS instance is connected to the CBASS0.

The PRUSS system has a total of 2 XFR2VBUS RX hardware accelerators.

##### 7.4.5.3.1.1 Blocking Conditions

The only blocking condition is caused when the VBUSM command/data FIFO is full. It is required that the external bandwidth is very high. All egress commands and data should get sent without head of line blocking. Based on arbitration some delay is possible.

##### 7.4.5.3.1.2 Read Operation with Auto Disabled

The XFR2VBUS supports 1 command in its command FIFO, 1 XOUT to define the address and size (4 Byte, 32 Byte, 64 Byte, aligned). This will cause the VBUSP read command to be issued. Only 1 read command can be in flight. The read address defines the offset of the 64 Byte of read data. The read size defines the size of the transfer, 4 Byte, 32 Byte, 64 Byte, aligned. Offset + size must be aligned to 32 Byte width of the bus. 1 XIN, the software can see the status of command FIFO and read data FIFO.

Note: XIN of the read data will fully pop the data, independent of XIN size.

#### 7.4.5.3.1.3 Read Operation with Auto Enabled

The same features as Auto Disabled are valid with the following exceptions:

64 Byte mode:

- Address needs to be MOD 0x40/64 Byte aligned
- Size needs to be 64 Byte
- 1 XOUT to define the start address, which needs to be MOD 0x40/64 Byte aligned
- The XFR2VBUS will issue 1 new command every time this is 64 Bytes available in the read data FIFO
- 1 XIN of read data will cause a new command to be issued since, 64 Bytes are available
- To stop the issuing new read commands, disable auto mode

32 Byte mode:

- Size needs to be 32 Byte
- 1 XOUT to define the start address, which needs to be MOD 0x20/32 Byte aligned
- The XFR2VBUS will issue 1 new command every time this is 32 Bytes available in the read data FIFO
- 1 XIN of read data will cause a new command to be issued since, 32 Bytes are available
- To stop the issuing of new read command, disable auto mode

Note: XIN of the read data will fully pop the data, independent of XIN size.

#### 7.4.5.3.1.4 Write Operation with Auto Disabled

The XFR2VBUS supports 1 command in the command FIFO.

- 1 XOUT to define the address, data and size (on the fly). 1 Byte, 4 Byte, 32 Byte, 64 Byte and must be aligned.
- Only 1 write command can be in flight since this is VBUSP
- 1 XIN the software can see the status of write command FIFO and write data FIFO

#### 7.4.5.3.1.5 PRU to XFR2VBUS Interface

RD\_ID0 = 0x60

RD\_ID1 = 0x61

Table 7-63. Read Commands

| PRU Register | BS ID    | Access Type | Register | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|----------|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R17-R2       | RD_ID1/0 | XIN         | RD_DATA  | Read Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| R18[0]       | RD_ID1/0 | XOUT        | RD_AUTO  | Read Auto Mode<br>If 0 -> 1, must write RD_ADDR<br>If 1 -> 0, must not write RD_ADDR,<br>must drain RD_DATA/RD_CMD<br>If 0 -> 0, must write RD_ADDR<br>When set, every RD_DATA pop<br>will cause a new read command<br>and read address to increment by<br>0x20 for the next read command<br>if size is set to 32 Bytes<br>0x40 for the next read command<br>if size is set to 64 Bytes<br>In this case, user must set the<br>address to be either mod 0x20 or<br>0x40.<br>4 Byte mode is not supported. |
| R18[2-1]     | RD_ID1/0 | XOUT        | RD_SIZE  | Read Size<br>0h: 4 Bytes<br>1h: Reserved<br>2h: 32 Bytes<br>3h: 64 Bytes                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**Table 7-63. Read Commands (continued)**

| PRU Register | BS ID    | Access Type | Register   | Notes                                                                                                                                                                                                                                                                              |
|--------------|----------|-------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R18[0]       | RD_ID1/0 | XIN         | RD_BUSY    | Read Busy Status<br>0h: Idle<br>1h: Active<br>(RD CMD FIFO LEVEL !=0) or<br>(RD DATA FIFO LEVEL !=0)                                                                                                                                                                               |
| R18[1]       | RD_ID1/0 | XIN         | RD_CMD_FL  | Read command FIFO Level<br>0h: Empty<br>1h: Occupied<br>Note: It only pop the read command FIFO after the read data has arrived                                                                                                                                                    |
| R18[2]       | RD_ID1/0 | XIN         | RD_DATA_FL | Read data FIFO Level<br>0h: Empty<br>1h: Occupied 32 byte or 64 byte<br>Note: In 64 byte mode, the user must wait for RD_MST_REQ = 0h before reading the FIFO.                                                                                                                     |
| R18[3]       | RD_ID1/0 | XIN         | RD_MST_REQ | RD MST RED<br>0h = Last data has been latched<br>1h = Last data is still in flight<br>Note: In Auto mode, the user must insure that this bit is 0h and wait an additional NOP before user disables Auto mode to prevent a race condition.                                          |
| R20:R19      | RD_ID1/0 | XOUT        | RD_ADDR    | Read address 48-bits<br>0x20 for the next read command if size is set to 32 Bytes<br>0x40 for the next read command if size is set to 64 Bytes<br>The address can be the full 48-bits or just the lower 32-bits of the address, it will use the current state of the upper 16-bits |

#### 7.4.5.3.1.6 XFR2VBUS Programming Model

Read:

- Wait RD\_BUSY = 0h
- XOUT R18 (configure RD\_AUTO/ RD\_SIZE); R19 (RD\_ADDR)
- Wait WR\_BUSY = 0h OR RD\_DATA\_FL = 1h
- XIN RD\_DATA (Repeat if RD\_AUTO is enabled and need new RD\_DATA, must always check RD\_DATA\_FL before XIN RD\_DATA)

### 7.4.6 PRUSS Local INTC

The PRUSS interrupt controller (INTC) maps interrupts coming from different parts of the device (mapped to PRU-ICSS) to a reduced set of PRUSS interrupt channels.

The interrupt controller has the following features:

- Capturing up to 64 System Events (inputs):
- Supports up to 10 output interrupt channels.
- Generation of 10 Host Interrupts
  - 2 Host Interrupts shared between the PRUs (PRU0 and PRU1).
  - 8 Host Interrupts exported from the PRUSS internal INTC for signaling the device level interrupt controllers (pulse and level provided).
- Each event can be enabled and disabled.
- Each host event can be enabled and disabled.
- Hardware prioritization of events.

#### 7.4.6.1 PRUSS Interrupt Controller Functional Description

The PRUSS INTC supports up to 64 interrupts from different peripherals and PRUs. The INTC maps these events to 10 channels inside the INTC (see [Figure 7-42](#)). Interrupts from these 10 channels are further mapped to 10 Host Interrupts.

- Any of the 64 internal interrupts can be mapped to any of the 10 channels.
- Multiple interrupts can be mapped to a single channel.
- An interrupt should not be mapped to more than one channel.
- Any of the 10 channels can be mapped to any of the 10 host interrupts. It is recommended to map channel “x” to host interrupt “x”, where x is from 0 to 9.
- A channel should not be mapped to more than one host interrupt
- For channels mapping to the same host interrupt, lower number channels have higher priority.
- For interrupts on same channel, priority is determined by the hardware interrupt number. The lower the interrupt number, the higher the priority.
- Host Interrupt 0 is connected to bit 30 in register 31 (R31) of PRU0 and PRU1 in parallel.
- Host Interrupt 1 is connected to bit 31 in register 31 (R31) for PRU0 and PRU1 in parallel.
- Host Interrupts 2 through 9 exported from PRUSS and mapped to device level interrupt controllers.



Figure 7-42. PRUSS Interrupt Controller Block Diagram

#### 7.4.6.1.1 PRUSS Interrupt Controller Events

All PRUSS system events are interrupt inputs. System events 32 through 63 are external and generated from different peripherals. System events 0 through 31 are internal for PRUSS sources.

#### 7.4.6.1.2 PRUSS Interrupt Controller System Events Flow

The ICSS\_INTC module controls the event mapping to the host interrupt interface. Events are generated by the device peripherals or PRUs. The INTC receives the internal interrupts and maps them to internal channels. The channels are used to group interrupts together and to prioritize them. These channels are then mapped onto the host interrupts. Interrupts from the system side are active high in polarity.

The INTC encompasses many functions to process the system interrupts and prepare them for the host interface. These functions are: processing, enabling, status, channel mapping, host interrupt mapping, prioritization, and host interfacing. [Figure 7-43](#) illustrates the flow of interrupts through the functions to the host. The following subsections describe each part of the flow.



**Figure 7-43. Flow of System Interrupts to Host**

#### 7.4.6.1.2.1 PRUSS Interrupt Processing

This block does following tasks:

- Synchronization of slower and asynchronous interrupts
  - Conversion of polarity to active high
  - Conversion of interrupt type to pulse interrupts

After the processing block, all interrupts will be active high pulses.

#### 7.4.6.1.2.1.1 PRUSS Interrupt Enabling

The next stage of INTC is to enable interrupts based on programmed settings. The following sequence has to be followed to enable interrupts:

- Enable required interrupts: System interrupts that are required to get propagated to host are to be enabled individually by writing to [9-0] ENABLE\_SET\_INDEX bit field in the interrupt enable indexed set register (ICSS\_INTC\_ENABLE\_SET\_INDEX\_REG). The interrupt to enable is the index value written. This sets the Enable Register bit of the given index.
  - Enable required host interrupts: By writing 1h to the appropriate bit of the [9-0] HINT\_ENABLE\_SET\_INDEX bit field in the host interrupt enable indexed set register (ICSS\_INTC\_HINT\_ENABLE\_SET\_INDEX\_REG), enable the required host interrupts. The host interrupt to enable is the index value written. This enables the host interrupt output or triggers the output again if that host interrupt is already enabled.
  - Enable all host interrupts: By setting the [0] ENABLE\_HINT\_ANY bit in the global enable register (ICSS\_INTC\_GLOBAL\_ENABLE\_HINT\_REG) to 1h, all host interrupts will be enabled. Individual host interrupts are still enabled or disabled from their individual enables and are not overridden by the global enable.

#### 7.4.6.1.2.2 PRUSS Interrupt Status Checking

The next stage is to capture which interrupts are pending. There are two kinds of pending status: raw status and enabled status. Raw status is the pending status of the interrupt without regards to the enable bit for the interrupt. Enabled status is the pending status of the interrupts with the enable bits active. When the enable bit is inactive, the enabled status will always be inactive. The enabled status of interrupts is captured in interrupt status enabled/clear registers (ICSS\_INTC\_ENA\_STATUS\_REG0 to ICSS\_INTC\_ENA\_STATUS\_REG4).

Status of interrupt 'N' is indicated by the N-th bit of ICSS\_INTC\_ENA\_STATUS\_REG0 to ICSS\_INTC\_ENA\_STATUS\_REG4. Since there are 160 interrupts, five 32-bit registers are used to capture the enabled status of interrupts. The pending status reflects whether the interrupt occurred since the last time the status register bit was cleared. Each bit in the status register can be individually cleared.

#### 7.4.6.1.2.3 PRUSS Interrupt Channel Mapping

The INTC has 10 internal channels to which enabled interrupts can be mapped. Channel 0 has highest priority and channel 9 has the lowest priority. Channels are used to group the interrupts into a smaller number of priorities that can be given to a host interface with a very small number of interrupt inputs.

When multiple interrupts are mapped to the same channel their interrupts are ORed together so that when either is active the output is active. The channel map registers (ICSS\_INTC\_CH\_MAP\_REGi) define the channel for each interrupt. There is one register per 4 interrupts; therefore, there are 16 channel map registers for a of 64 interrupts. The channel for each interrupt can be set using these registers.

##### 7.4.6.1.2.3.1 PRUSS Host Interrupt Mapping

The hosts can be the local PRU processors (PRU0 and PRU1) as well as device processors located outside PRUSS such as ARM, etc. The 10 channels from the INTC can be mapped to any of the 10 Host interrupts. The Host map registers (ICSS\_INTC\_HINT\_MAP\_REG0 to ICSS\_INTC\_HINT\_MAP\_REG4) define the channel for each interrupt. There is one register per 4 channels; therefore, there are 3 host map registers for 10 channels. When multiple channels are mapped to the same host interrupt, then prioritization is done to select which interrupt is in the highest-priority channel and which should be sent first to the host.

##### 7.4.6.1.2.3.2 PRUSS Interrupt Prioritization

The next stage of the INTC is prioritization. Since multiple interrupts can feed into a single channel and multiple channels can feed into a single host interrupt, it is necessary to read the status of all interrupts to determine the highest priority interrupt that is pending. The INTC provides hardware to perform this prioritization with a given scheme so that software does not have to do this. There are two levels of prioritizations:

- The first level of prioritization is between the active channels for a host interrupt. Channel 0 has the highest priority and channel 9 has the lowest. So the first level of prioritization picks the lowest numbered active channel.
- The second level of prioritization is between the active interrupts for the prioritized channel. The interrupt in position 0 has the highest priority and interrupt 159 has the lowest priority. So the second level of prioritization picks the lowest position active interrupt.

This is the final prioritized interrupt for the host interrupt and is stored in the global prioritized interrupt register (ICSS\_INTC\_GLB\_PRI\_INTR\_REG). The highest priority pending interrupt with respect to each host interrupts can be obtained using the host interrupt prioritized interrupt registers (ICSS\_INTC\_PRI\_HINT\_REGj where j = 0 to 19).

##### 7.4.6.1.2.4 PRUSS Interrupt Nesting

The INTC can also perform a nesting function in its prioritization. Nesting is a method of disabling certain interrupts (usually lower-priority interrupts) when an interrupt is taken so that only those desired interrupts can trigger to the host while it is servicing the current interrupt. The typical usage is to nest on the current interrupt and disable all interrupts of the same or lower priority (or channel). Then the host will only be interrupted from a higher priority interrupt.

The nesting is done in one of three methods:

1. Nesting for all host interrupts, based on channel priority: When an interrupt is taken, the nesting level is set to its channel priority. From then, that channel priority and all lower priority channels will be disabled from generating host interrupts and only higher priority channels are allowed. When the interrupt is completely serviced, the nesting level is returned to its original value. When there is no interrupt being serviced, there are no channels disabled due to nesting. The global nesting level register (ICSS\_INTC\_GLB\_NEST\_LEVEL\_REG) allows the checking and setting of the global nesting level across all host interrupts. The nesting level is the channel (and all of lower priority channels) that are nested out because of a current interrupt.
2. Nesting for individual host interrupts, based on channel priority: Always nest based on channel priority for each host interrupt individually. When an interrupt is taken on a host interrupt, then, the nesting level is set to its channel priority for just that host interrupt, and other host interrupts do not have their nesting affected. Then for that host interrupt, equal or lower priority channels will not interrupt the host but may on other host interrupts if programmed. When the interrupt is completely serviced the nesting level for the host interrupt is returned to its original value. The host interrupt nesting level registers (ICSS\_INTC\_NEST\_LEVEL\_REGj where j = 0 to 19) display and control the nesting level for each host interrupt. The nesting level controls which channel and lower priority channels are nested. There is one register per host interrupt.
3. Software manually performs the nesting of interrupts. When an interrupt is taken, the software will disable all the host interrupts, manually update the enables for any or all the interrupts, and then re-enables all the host interrupts. This now allows only the interrupts that are still enabled to trigger to the host. When the interrupt is completely serviced the software must reverse the changes to re-enable the nested out interrupts. This method requires the most software interaction but gives the most flexibility if simple channel based nesting mechanisms are not adequate.

#### **7.4.6.1.2.5 PRUSS Interrupt Status Clearing**

After servicing the interrupt (after execution of the ISR), interrupt status is to be cleared. If a interrupt status is not cleared, then another host interrupt may not be triggered or another host interrupt may be triggered incorrectly. It is also essential to clear all interrupts before the PRU is halted as the PRU does not power down unless all the interrupt status are cleared. For clearing the status of an interrupt, whose interrupt number is N, write a 1h to the Nth bit position in the interrupt status enabled/clear registers (ICSS\_INTC\_ENA\_STATUS\_REG0 to ICSS\_INTC\_ENA\_STATUS\_REG4). Interrupt N can also be cleared by writing the value N into the interrupt status indexed clear register (ICSS\_INTC\_STATUS\_CLR\_INDEX\_REG).

#### **7.4.6.1.3 PRUSS Interrupt Disabling**

At any time, if any interrupt is not to be propagated to the host, then that interrupt should be disabled. For disabling an interrupt whose interrupt number is N, write a 1h to the Nth bit in the interrupt enable clear registers (ICSS\_INTC\_ENABLE\_CLR\_REG0 to ICSS\_INTC\_ENABLE\_CLR\_REG4). Interrupt N can also be disabled by writing the value N in the interrupt enable clear index register (ICSS\_INTC\_ENABLE\_CLR\_INDEX\_REG).

#### **7.4.6.2 PRUSS Interrupt Controller Basic Programming Model**

Follow these steps to configure the interrupt controller.

1. Set polarity and type of event through the Interrupt Polarity Registers (ICSS\_INTC\_POLARITY\_REG0 to ICSS\_INTC\_POLARITY\_REG4) and the Interrupt Type Registers (ICSS\_INTC\_POLARITY\_REG0 to ICSS\_INTC\_POLARITY\_REG4). Polarity of all interrupts is always high. Type of all interrupts is always pulse (after the processing block).
2. Map event to INTC channel through ICSS\_INTC\_CH\_MAP\_REGi (where i=0 to 39) channel mapping registers.
3. Map channel to host interrupt through ICSS\_INTC\_HINT\_MAP\_REG0 to ICSS\_INTC\_HINT\_MAP\_REG4 registers. Recommended channel “x” to be mapped to host interrupt “x”.
4. Clear interrupt by writing 1h to ICSS\_INTC\_ENA\_STATUS\_REG0 to ICSS\_INTC\_ENA\_STATUS\_REG4 registers.
5. Enable host interrupt by writing index value to ICSS\_INTC\_HINT\_ENABLE\_SET\_INDEX\_REG register.
6. Enable interrupt nesting if desired.
7. Globally enable all interrupts through register ICSS\_INTC\_GLOBAL\_ENABLE\_HINT\_REG[0] ENABLE\_HINT\_ANY bit.

#### 7.4.6.3 PRUSS Interrupt Requests Mapping

The PRU-ICSS Interrupt Controller lines 0 through 31 are mapped to internal events which are generated by PRUSS integrated modules. Lines 32 to 63 are external and generated from different peripherals. [Table 7-64](#) shows mapping of the different PRUSS internally sourced IRQ events to PRUSS INTC interrupt lines 0 through 63.

**Table 7-64. PRUSS IP Internal Interrupts**

| Event Number                                                                     | Source                                       |
|----------------------------------------------------------------------------------|----------------------------------------------|
| MII_RT_REG.MII_RT_EVENT_EN =1 mode (default) MII_RT_REG .MII_RT_EVENT_EN =0 mode |                                              |
| PRUSS INTC                                                                       |                                              |
| 63                                                                               | pr0_slv_intr[31]_intr_pend(external)         |
| 62                                                                               | pr0_slv_intr[30]_intr_pend(external)         |
| 61                                                                               | pr0_slv_intr[29]_intr_pend(external)         |
| 60                                                                               | pr0_slv_intr[28]_intr_pend(external)         |
| 59                                                                               | pr0_slv_intr[27]_intr_pend(external)         |
| 58                                                                               | pr0_slv_intr[26]_intr_pend(external)         |
| 57                                                                               | pr0_slv_intr[25]_intr_pend(external)         |
| 56                                                                               | pr0_slv_intr[24]_intr_pend(external)         |
| 55                                                                               | pr0_mii1_col and<br>pr0_mii1_txen (external) |
| 54                                                                               | PRU1_RX_EOF                                  |
| 53                                                                               | MDIO_MII_LINK[1]                             |
| 52                                                                               | PORT1_TX_OVERFLOW                            |
| 51                                                                               | PORT1_TX_UNDERFLOW                           |
| 50                                                                               | PRU1_RX_OVERFLOW                             |
| 49                                                                               | PRU1_RX_NIBBLE_ODD                           |
| 48                                                                               | PRU1_RX_CRC                                  |
| 47                                                                               | PRU1_RX_SOF                                  |
| 46                                                                               | PRU1_RX_SFD                                  |
| 45                                                                               | PRU1_RX_ERR32                                |
| 44                                                                               | PRU1_RX_ERR                                  |
| 43                                                                               | pr0_mii0_col and<br>pr0_mii0_txen (external) |
| 42                                                                               | PRU0_RX_EOF                                  |
| 41                                                                               | MDIO_MII_LINK[0]                             |
| 40                                                                               | PORT0_TX_OVERFLOW                            |
| 39                                                                               | PORT0_TX_UNDERFLOW                           |
| 38                                                                               | PRU0_RX_OVERFLOW                             |
| 37                                                                               | PRU0_RX_NIBBLE_ODD                           |
| 36                                                                               | PRU0_RX_CRC                                  |
| 35                                                                               | PRU0_RX_SOF                                  |
| 34                                                                               | PRU0_RX_SFD                                  |
| 33                                                                               | PRU0_RX_ERR32                                |
| 32                                                                               | PRU0_RX_ERR                                  |
| 31                                                                               | pr0_pru_mst_intr[15]_intr_req                |
| 30                                                                               | pr0_pru_mst_intr[14]_intr_req                |
| 29                                                                               | pr0_pru_mst_intr[13]_intr_req                |
| 28                                                                               | pr0_pru_mst_intr[12]_intr_req                |

**Table 7-64. PRUSS IP Internal Interrupts (continued)**

| Event Number                                                                            | Source                         |
|-----------------------------------------------------------------------------------------|--------------------------------|
| <b>MII_RT_REG.MII_RT_EVENT_EN =1 mode (default) MII_RT_REG .MII_RT_EVENT_EN =0 mode</b> |                                |
| 27                                                                                      | pr0_pru_mst_intr[11]_intr_req  |
| 26                                                                                      | pr0_pru_mst_intr[10]_intr_req  |
| 25                                                                                      | pr0_pru_mst_intr[9]_intr_req   |
| 24                                                                                      | pr0_pru_mst_intr[8]_intr_req   |
| 23                                                                                      | pr0_pru_mst_intr[7]_intr_req   |
| 22                                                                                      | pr0_pru_mst_intr[6]_intr_req   |
| 21                                                                                      | pr0_pru_mst_intr[5]_intr_req   |
| 20                                                                                      | pr0_pru_mst_intr[4]_intr_req   |
| 19                                                                                      | pr0_pru_mst_intr[3]_intr_req   |
| 18                                                                                      | pr0_pru_mst_intr[2]_intr_req   |
| 17                                                                                      | pr0_pru_mst_intr[1]_intr_req   |
| 16                                                                                      | pr0_pru_mst_intr[0]_intr_req   |
| 15                                                                                      | pr0_ecap_intr_req              |
| 14                                                                                      | pr0_sync0_out_pend             |
| 13                                                                                      | pr0_sync1_out_pend             |
| 12                                                                                      | pr0_latch0_in (input to PRUSS) |
| 11                                                                                      | pr0_latch1_in (input to PRUSS) |
| 10                                                                                      | pr0_pdi_wd_exp_pend            |
| 9                                                                                       | pr0_pd_wd_exp_pend             |
| 8                                                                                       | pr0_digio_event_req            |
| 7                                                                                       | pr0_iep_tim_cap_cmp_pend       |
| 6                                                                                       | pr0_uart0_uint_intr_req        |
| 5                                                                                       | pr0_uart0_utxevt_intr_req      |
| 4                                                                                       | pr0_uart0_urxevt_intr_req      |
| 3                                                                                       | reset_iso_req                  |
| 2                                                                                       | pr0_pru1_r31_status_cnt16      |
| 1                                                                                       | pr0_pru0_r31_status_cnt16      |
| 0                                                                                       | pr0_ecc_err_intr               |

### 7.4.7 PRUSS UART Module

This section describes an Universal Asynchronous Receive and Transmit (UART) module integrated into the PRUSS subsystem. Hereinafter the module will be referred as PRUSS UART0.

#### 7.4.7.1 PRUSS UART Overview

The PRUSS UART0 peripheral is based on the industry standard TL16C550 asynchronous communications element, which in turn is a functional upgrade of the TL16C450. The information in this chapter assumes that user is familiar with these standards.

Functionally similar to the TL16C450 on power up (single character or TL16C450 mode), the PRUSS UART0 can be placed in an alternate FIFO (TL16C550) mode. This relieves the CPU of excessive software overhead by buffering received and transmitted characters. The receiver and transmitter FIFOs store up to 16 bytes including three additional bits of error status per byte for the receiver FIFO.

The PRUSS UART0 performs serial-to-parallel conversions on data received from a peripheral device and parallel-to-serial conversion on data received from the CPU. The CPU can read the PRUSS UART0 status at any time. The PRUSS UART0 includes control capability and a processor interrupt system that can be tailored to minimize software management of the communications link.

The PRUSS UART0 includes a programmable baud generator capable of dividing the PRUSS UART0 input clock by divisors from 1 to 65535 and producing a 16 $\times$  reference clock or a 13 $\times$  reference clock for the internal transmitter and receiver logic.

#### 7.4.7.2 PRUSS UART Environment

This section describes the PRUSS UART0 module interface to the device environment.

##### 7.4.7.2.1 PRUSS UART Pin Multiplexing

Pin multiplexing is controlled using a combination of hardware configuration at device reset and software programmable register settings. For more information on the PRUSS UART0 pin multiplexing, refer to

##### 7.4.7.2.2 PRUSS UART Signal Descriptions

The PRUSS UART0 utilize a minimal number of signal connections to interface with external devices. The PRUSS UART0 signal descriptions are described in [Table 7-65](#).

**Table 7-65. PRUSS\_UART0 Signal Descriptions**

| Signal Name | Signal Type | Function                           |
|-------------|-------------|------------------------------------|
| UART0_TXD   | Output      | Serial data transmit               |
| UART0_RXD   | Input       | Serial data receive                |
| UART0_CTS   | Input       | Clear-to-Send handshaking signal   |
| UART0_RTS   | Output      | Request-to-Send handshaking signal |

##### 7.4.7.2.3 PRUSS UART Protocol Description and Data Format

###### 7.4.7.2.3.1 PRUSS UART Transmission Protocol

The PRUSS UART0 transmitter section includes a transmitter hold register (THR), memory mapped in the register `UART_RBR[17-8] TBR_DATA` bitfield and a transmitter shift register (TSR), which is NOT memory mapped. When the PRUSS UART0 is in the FIFO mode, THR is a 16-byte FIFO. Transmitter section control is a function of the PRUSS UART0 line control register `UART_LCTR`. Based on the settings chosen in this register, the PRUSS UART0 transmitter sends the following to the receiving device:

- 1 START bit
- 5, 6, 7, or 8 data bits
- 1 PARITY bit (optional)
- 1, 1.5, or 2 STOP bits

THR receives data from the internal data bus, and when TSR (transmitter shift register) is ready, the PRUSS UART0 moves the data from THR to TSR. The PRUSS UART0 serializes the data in TSR and transmits the data on the UART0\_TXD pin.

In the non-FIFO mode, if THR is empty and the Transmitter Holding Register Empty interrupt (THRE) is enabled in the interrupt enable register (UART\_INT\_EN[1] ETBEI), an interrupt is generated. This interrupt is cleared when a character is loaded into THR or the interrupt identification register UART\_INT\_FIFO bitfield [3-1] IIR\_INTID is read. In the FIFO mode, the interrupt is generated when the transmitter FIFO is empty, and it is cleared when at least one byte is loaded into the FIFO or UART\_INT\_FIFO[3-1] IIR\_INTID bitfield is read.

#### 7.4.7.2.3.2 PRUSS UART Reception Protocol

The PRUSS UART0 receiver section includes a receiver shift register (RSR), that is not memory mapped, and a receiver buffer register (RBR), memory mapped as the register UART\_RBR\_TBR[7-0] RBR\_DATA bitfield. When the PRUSS UART0 is in the FIFO mode, RBR is a 16-byte FIFO. Receiver section control is a function of the PRUSS UART0 line control register - UART\_LCTR. Based on the settings chosen in this register, the PRUSS UART0 receiver accepts the following from the transmitting device:

- 1 START bit
- 5, 6, 7, or 8 data bits
- 1 PARITY bit (optional)
- 1 STOP bit (any other STOP bits transferred with the above data are not detected)

RSR receives the data bits from the UART0\_RXD pin. Then RSR concatenates the data bits and moves the resulting value into RBR (or the receiver FIFO), accessible in the RBR\_TBR[7-0] RBR\_DATA register bitfield. The PRUSS UART0 also stores three bits of error status information next to each received character, to record a parity error, framing error, or break.

In the non-FIFO mode, when a character is placed in RBR and the receiver data available interrupt is enabled in the interrupt enable register - UART\_INT\_EN[0] ERBI, an interrupt is generated. This interrupt is cleared when the character is read from RBR. In the FIFO mode, the interrupt is generated when the FIFO is filled to the trigger level selected in the FIFO control MSB part of the register UART\_INT\_FIFO, and it is cleared when the FIFO contents drop below the trigger level.

#### 7.4.7.2.3.3 PRUSS UART Data Format

The PRUSS UART0 transmits in the following format:

1 START bit + data bits (5, 6, 7, 8) + 1 PARITY bit (optional) + STOP bit (1, 1.5, 2)

It transmits 1 START bit; 5, 6, 7, or 8 data bits, depending on the data width selection; 1 PARITY bit, if parity is selected; and 1, 1.5, or 2 STOP bits, depending on the STOP bit selection.

The PRUSS UART0 receives in the following format:

1 START bit + data bits (5, 6, 7, 8) + 1 PARITY bit (optional) + 1 STOP bit

It receives 1 START bit; 5, 6, 7, or 8 data bits, depending on the data width selection; 1 PARITY bit, if parity is selected; and 1 STOP bit.

The protocol formats are shown in Figure 7-44.

**Figure 7-44. PRUSS UART Protocol Formats**

Transmit/Receive for 5-bit data, parity Enable, 1 STOP bit



Transmit/Receive for 6-bit data, parity Enable, 1 STOP bit



Transmit/Receive for 7-bit data, parity Enable, 1 STOP bit



Transmit/Receive for 8-bit data, parity Enable, 1 STOP bit



#### 7.4.7.2.3.3.1 Frame Formatting

Character length is specified using the **UART\_LCTR[0]** WLS0 and **UART\_LCTR[1]** WLS1 bits (see [Table 7-67](#)).

The number of stop-bits is specified using the **UART\_LCTR[2]** STB bit (see [Table 7-67](#)).

The parity bit is programmed using the **UART\_LCTR[5]** SP, **UART\_LCTR[4]** EPS, and **UART\_LCTR[3]** PEN bits (see [Table 7-66](#)).

**Table 7-66. Relationship Between SP, EPS, and PEN Bits in LCTR**

| SP Bit | EPS Bit | PEN Bit | Parity Option                                                             |
|--------|---------|---------|---------------------------------------------------------------------------|
| x      | x       | 0       | Parity disabled: No PARITY bit is transmitted or checked.                 |
| 0      | 0       | 1       | Odd parity selected: Odd number of logic 1s.                              |
| 0      | 1       | 1       | Even parity selected: Even number of logic 1s.                            |
| 1      | 0       | 1       | Stick parity selected with PARITY bit transmitted and checked as set.     |
| 1      | 1       | 1       | Stick parity selected with PARITY bit transmitted and checked as cleared. |

**Table 7-67. Number of STOP Bits Generated**

| STB Bit | WLS Bit | Word Length Selected with WLS Bits | Number of STOP Bits Generated | Baud Clock (BCLK) Cycles |
|---------|---------|------------------------------------|-------------------------------|--------------------------|
| 0       | x       | Any word length                    | 1                             | 16                       |
| 1       | 0h      | 5 bits                             | 1.5                           | 24                       |
| 1       | 1h      | 6 bits                             | 2                             | 32                       |
| 1       | 2h      | 7 bits                             | 2                             | 32                       |
| 1       | 3h      | 8 bits                             | 2                             | 32                       |

#### 7.4.7.2.4 PRUSS UART Clock Generation and Control

The PRUSS UART0 bit clock is derived from an input clock to the PRUSS UART0. See the device-specific Datasheet to check the maximum data rate supported by the PRUSS UART0.

[Figure 7-45](#) is a conceptual clock generation diagram for the PRUSS UART0. The processor clock generator receives a signal from an external clock source and produces a PRUSS UART0 input clock with a programmed frequency. The PRUSS UART0 contains a programmable baud generator that takes an input clock and divides it by a divisor in the range between 1 and  $(2^{16} - 1)$  to produce a baud clock (BCLK). The frequency of BCLK is sixteen times (16 $\times$ ) the baud rate (each received or transmitted bit lasts 16 BCLK cycles) or thirteen times (13 $\times$ ) the baud rate (each received or transmitted bit lasts 13 BCLK cycles). When the PRUSS UART0 is receiving, the bit is sampled in the 8th BCLK cycle for 16 $\times$  over sampling mode and on the 6th BCLK cycle for 13 $\times$  over-sampling mode. The 16 $\times$  or 13 $\times$  reference clock is selected by configuring the mode definition register: **UART\_MODE[0]** OSM\_SEL bit. The formula to calculate the divisor is:

$$\text{Divisor} = \frac{\text{UART input clock frequency}}{\text{Desired baud rate} \times 16} \quad [\text{MODE.OSM\_SEL} = 0h]$$

icss-13

$$\text{Divisor} = \frac{\text{UART input clock frequency}}{\text{Desired baud rate} \times 13} \quad [\text{MODE.OSM_SEL} = 1h]$$

icss-14

Two 8-bit register fields:

- `UART_DIVMSB[7-0]` DLH
- `UART_DIVLSB[7-0]` DLL,

called divisor latches, hold this 16-bit divisor. DLH holds the most significant bits of the divisor, and DLL holds the least significant bits of the divisor. For information about these register fields, see the PRUSS UART0 register descriptions in the *PRU\_UART\_UART0 Registers*. These divisor latches must be loaded during initialization of the PRUSS UART0 in order to ensure desired operation of the baud generator. Writing to the divisor latches results in two wait states being inserted during the write access while the baud generator is loaded with the new value.

[Figure 7-46](#) summarizes the relationship between the transferred data bit, BCLK, and the PRUSS UART0 input clock. Note that the timing relationship depicted in [Figure 7-46](#) shows that each bit lasts for 16 BCLK cycles. This is in case of 16x over-sampling mode. For 13x over-sampling mode each bit lasts for 13 BCLK cycles.

Example baud rates and divisor values relative to a 150 MHz PRUSS UART0 input clock and 16x over-sampling mode are shown in [Table 7-68](#).



**Figure 7-45. PRUSS UART Clock Generation Diagram**



**Figure 7-46. Relationships Between PRUSS UART Data Bit, BCLK, and Input Clock**

**Table 7-68. Baud Rate Examples for 192-MHZ PRUSS UART Input Clock and 16x Over-sampling Mode**

| Baud Rate | Divisor Value | Actual Baud Rate | Error (%) |
|-----------|---------------|------------------|-----------|
| 2400      | 5000          | 2400             | 0.00      |
| 4800      | 2500          | 4800             | 0.00      |
| 9600      | 1250          | 9600             | 0.00      |
| 19200     | 625           | 19200            | 0.00      |
| 38400     | 313           | 38338.658        | -0.16     |
| 56000     | 214           | 56074.766        | 0.13      |
| 115200    | 104           | 115384.6         | 0.16      |
| 128000    | 94            | 127659.574       | -0.27     |
| 3000000   | 4             | 3000000          | 0.00      |
| 6000000   | 2             | 3000000          | 0.00      |
| 12000000  | 1             | 12000000         | 12000000  |

**Table 7-69. Baud Rate Examples for 192-MHZ PRUSS UART Input Clock and 13x Over-sampling Mode**

| Baud Rate | Divisor Value | Actual Baud Rate | Error (%) |
|-----------|---------------|------------------|-----------|
| 2400      | 6154          | 2399.940         | -0.0025   |
| 4800      | 3077          | 4799.880         | -0.0025   |
| 9600      | 1538          | 9602.881         | 0.03      |
| 19200     | 769           | 19205.762        | 0.03      |
| 38400     | 385           | 38361.638        | -0.10     |
| 56000     | 264           | 55944.056        | -0.10     |
| 115200    | 128           | 115384.6         | 0.16      |

**Table 7-69. Baud Rate Examples for 192-MHZ PRUSS UART Input Clock and 13x Over-sampling Mode (continued)**

| Baud Rate | Divisor Value | Actual Baud Rate | Error (%) |
|-----------|---------------|------------------|-----------|
| 128000    | 115           | 128428.094       | 0.33      |

#### 7.4.7.3 PRUSS UART Functional Description

##### 7.4.7.3.1 PRUSS UART Functional Block Diagram

A functional block diagram of the PRUSS UART0 is shown in [Figure 7-47](#).



icss-017

NOTE: The value *n* indicates the applicable UART where there are multiple instances. For the PRUSS, there is only one instance and all UART signals should reflect this (e.g., **UART0\_TxD** instead of **UARTn\_TxD**).

**Figure 7-47. PRUSS UART Block Diagram**

#### 7.4.7.3.2 PRUSS UART Reset Considerations

##### 7.4.7.3.2.1 PRUSS UART Software Reset Considerations

Two bits in the power and emulation management register - **UART\_PWR**, control resetting the parts of the PRUSS UART0:

- The bit [14]UTRST controls resetting the transmitter only. If bit [14]UTRST = 1h, the transmitter is enabled and active; if bit [14]UTRST = 0h, the transmitter is disabled and in reset state.
- The bit [13]URRST controls resetting the receiver only. If [13]URRST = 1h, the receiver is enabled and active; if bit [13]URRST = 0h, the receiver is disabled and in reset state.

In each case, putting the receiver and/or transmitter in reset will reset the state machine of the affected portion but will not affect the PRUSS UART0 registers.

#### 7.4.7.3.2.2 PRUSS UART Hardware Reset Considerations

When the processor RESET pin is asserted, the entire processor is reset and is held in the reset state until the RESET pin is released. As part of a device reset, the PRUSS UART0 state machine is reset and the PRUSS UART0 registers are forced to their default states. The default states of the registers are shown in .

#### 7.4.7.3.3 PRUSS UART Power Management

The PRUSS UART0 peripheral can be placed in reduced-power modes to conserve power during periods of low activity. The power management of the PRUSS UART0 peripheral and other PRUSS peripherals is controlled by the device . The acts as a power management controller for all of the peripherals on the device. For more details on the power management procedures using the PSC, refer to the *Power Management* section.

#### 7.4.7.3.4 PRUSS UART Interrupt Support

##### 7.4.7.3.4.1 PRUSS UART Interrupt Events and Requests

The PRUSS UART0 generates the interrupt requests described in [Table 7-70](#). All requests are multiplexed through an arbiter to a single PRUSS UART0 interrupt request to the CPU, as shown in [Figure 7-48](#). Each of the interrupt requests has an enable bit in the interrupt enable register (IER) - UART\_INT\_EN and is recorded in [3-1]IIR\_INTID bitfield of UART\_INT\_FIFO register.

If an interrupt occurs and the corresponding enable bit is set to 1h, the interrupt request is recorded in corresponding UART\_INT\_FIFO[3-1] IIR\_INTID bitfield and is forwarded to the CPU. If an interrupt occurs and the corresponding enable bit is cleared to 0h, the interrupt request is blocked. The interrupt request is neither recorded in UART\_INT\_FIFO[3-1] IIR\_INTID, nor forwarded to the CPU.

##### 7.4.7.3.4.2 PRUSS UART Interrupt Multiplexing

The PRUSS UART0 have dedicated interrupt signals to the CPU and the interrupts are not multiplexed with any other interrupt source.

**Table 7-70. PRUSS UART Interrupt Requests Descriptions**

| PRUSS UART0<br>Interrupt Request | Interrupt Source                                                                                                                                                                                                    | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| THREINT                          | THR-empty condition: The transmitter holding register (THR) or the transmitter FIFO is empty. All of the data has been copied from THR, ( i.e. UART_RBR_TBR[7-0] RBR_DATA) to the transmitter shift register (TSR). | If THREINT is enabled in UART_INT_EN register by setting the [1]ETBEI bit, it is recorded in [3-1]IIR_INTID bitfield.<br>As an alternative to using THREINT, the CPU can poll the THRE bit in the line status register UART_LSR1.                                                                                                                                                                                                        |
| RDAINT                           | Receive data available in non-FIFO mode or trigger level reached in the FIFO mode.                                                                                                                                  | If RDAINT is enabled in UART_INT_EN register, by setting the [0]ERBI bit, it is recorded in INTID bitfield.<br>As an alternative to using RDAINT, the CPU can poll the [0]DR bit in the line status register UART_LSR1. In the FIFO mode, this is not a functionally equivalent alternative because the [0]DR bit does not respond to the FIFO trigger level. The [0]DR bit only indicates the presence or absence of unread characters. |

Table 7-70. PRUSS UART Interrupt Requests Descriptions (continued)

| PRUSS UART0<br>Interrupt Request | Interrupt Source                                                                                                                                                                                                                                          | Comment                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RTOINT                           | Receiver time-out condition (in the FIFO mode only): No characters have been removed from or input to the receiver FIFO during the last four character times (see Table 7-73), and there is at least one character in the receiver FIFO during this time. | The receiver time-out interrupt prevents the PRUSS UART0 from waiting indefinitely, in the case when the receiver FIFO level is below the trigger level and thus does not generate a receiver data-ready interrupt. If RTOINT is enabled in UART_INT_EN register, by setting the [0]ERBI bit, it is recorded in UART_INT_FIFO[3-1] IIR_INTID bitfield. There is no status bit to reflect the occurrence of a time-out condition. |
| RLSINT                           | Receiver line status condition: An overrun error, parity error, framing error, or break has occurred.                                                                                                                                                     | If RLSINT is enabled in INT_EN register, by setting the [2]ELSI bit, it is recorded in UART_INT_FIFO[3-1] IIR_INTID bitfield. As an alternative to using RLSINT, the CPU can poll the following bits in the line status register UART_LSR1: overrun error indicator (bit [1]OE), parity error indicator (bit [2]PE), framing error indicator ([3]FE), and break indicator ([4]BI).                                               |



icss-018

Figure 7-48. PRUSS UART Interrupt Request Enable Paths

**Table 7-71. Interrupt Identification and Interrupt Clearing Information**

| Priority Level | IIR Bits |   |   |   | Interrupt Type                     | Interrupt Source                                                                                                                                                                                   | Event That Clears Interrupt                                                                                                                                                                                                                                                                                               |
|----------------|----------|---|---|---|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 3        | 2 | 1 | 0 |                                    |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                           |
| None           | 0        | 0 | 0 | 1 | None                               | None                                                                                                                                                                                               | None                                                                                                                                                                                                                                                                                                                      |
| 1              | 0        | 1 | 1 | 0 | Receiver line status               | Overrun error, parity error, framing error, or break is detected.                                                                                                                                  | For an overrun error, reading the line status register <code>UART_LSR1</code> , clears the interrupt. For a parity error, framing error, or break, the interrupt is cleared only after all the erroneous data have been read.                                                                                             |
| 2              | 0        | 1 | 0 | 0 | Receiver data-ready                | Non-FIFO mode: Receiver data is ready.                                                                                                                                                             | Non-FIFO mode: The receiver buffer register (RBR) is read.                                                                                                                                                                                                                                                                |
|                |          |   |   |   |                                    | FIFO mode: Trigger level reached. If four character times pass with no access of the FIFO, the interrupt is asserted again.                                                                        | FIFO mode: The FIFO drops below the trigger level. <sup>(1)</sup>                                                                                                                                                                                                                                                         |
| 2              | 1        | 1 | 0 | 0 | Receiver time-out                  | FIFO mode only: No characters have been removed from or input to the receiver FIFO during the last four character times and there is at least one character in the receiver FIFO during this time. | One of the following events: <ul style="list-style-type: none"> <li>• A character is read from the receiver FIFO <sup>(1)</sup></li> <li>• A new character arrives in the receiver FIFO</li> <li>• The [13]URRST bit in the power and emulation management register (<code>UART_PWR</code>) is loaded with 0h.</li> </ul> |
| 3              | 0        | 0 | 1 | 0 | Transmitter holding register empty | Non-FIFO mode: Transmitter holding register (THR) is empty.<br>FIFO mode: Transmitter FIFO is empty.                                                                                               | A character is written to the transmitter holding register ( <code>UART_RBR_TBR</code> ) or the interrupt identification register ( <code>UART_INT_FIFO</code> ) is read.                                                                                                                                                 |

(1) In the FIFO mode, the receiver data-ready interrupt or receiver time-out interrupt is cleared by the CPU or by the DMA controller, whichever reads from the receiver FIFO first.

#### 7.4.7.3.5

**Table 7-72. Interrupt Identification and Interrupt Clearing Information**

| Priority Level | IIR Bits |   |   |   | Interrupt Type                     | Interrupt Source                                                                                                                                                                                   | Event That Clears Interrupt                                                                                                                                                                                                                                                                                               |
|----------------|----------|---|---|---|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 3        | 2 | 1 | 0 |                                    |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                           |
| None           | 0        | 0 | 0 | 1 | None                               | None                                                                                                                                                                                               | None                                                                                                                                                                                                                                                                                                                      |
| 1              | 0        | 1 | 1 | 0 | Receiver line status               | Overrun error, parity error, framing error, or break is detected.                                                                                                                                  | For an overrun error, reading the line status register <code>UART_LSR1</code> , clears the interrupt. For a parity error, framing error, or break, the interrupt is cleared only after all the erroneous data have been read.                                                                                             |
| 2              | 0        | 1 | 0 | 0 | Receiver data-ready                | Non-FIFO mode: Receiver data is ready.                                                                                                                                                             | Non-FIFO mode: The receiver buffer register (RBR) is read.                                                                                                                                                                                                                                                                |
|                |          |   |   |   |                                    | FIFO mode: Trigger level reached. If four character times pass with no access of the FIFO, the interrupt is asserted again.                                                                        | FIFO mode: The FIFO drops below the trigger level. <sup>(1)</sup>                                                                                                                                                                                                                                                         |
| 2              | 1        | 1 | 0 | 0 | Receiver time-out                  | FIFO mode only: No characters have been removed from or input to the receiver FIFO during the last four character times and there is at least one character in the receiver FIFO during this time. | One of the following events: <ul style="list-style-type: none"> <li>• A character is read from the receiver FIFO <sup>(1)</sup></li> <li>• A new character arrives in the receiver FIFO</li> <li>• The [13]URRST bit in the power and emulation management register (<code>UART_PWR</code>) is loaded with 0h.</li> </ul> |
| 3              | 0        | 0 | 1 | 0 | Transmitter holding register empty | Non-FIFO mode: Transmitter holding register (THR) is empty.                                                                                                                                        | A character is written to the transmitter holding register ( <code>UART_RBR_TBR</code> ) or the interrupt identification register ( <code>UART_INT_FIFO</code> ) is read.                                                                                                                                                 |
|                |          |   |   |   |                                    | FIFO mode: Transmitter FIFO is empty.                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                           |

(1) In the FIFO mode, the receiver data-ready interrupt or receiver time-out interrupt is cleared by the CPU or by the DMA controller, whichever reads from the receiver FIFO first.

#### 7.4.7.3.6 PRUSS UART DMA Event Support

In the FIFO mode, the PRUSS UART0 generates the following two DMA events:

- **Receive event (URXEV):** The trigger level for the receiver FIFO (1, 4, 8, or 14 characters) is set with the FIFO control `UART_INT_FIFO[7-6]` IIR\_FIFOEN bitfield. Every time the trigger level is reached or a receiver time-out occurs, the PRUSS UART0 sends a receive event to the UDMA controller. In response, the UDMA controller reads the data from the receiver FIFO by way of the receiver buffer register `UART_RBR_TBR[7-0]` `RBR_DATA`. Note that the receive event is not asserted if the data at the top of the receiver FIFO is erroneous even if the trigger level has been reached.
- **Transmit event (UTXEV):** When the transmitter FIFO is empty (when the last byte in the transmitter FIFO has been copied to the transmitter shift register), the PRUSS UART0 sends an UTXEV signal to the UDMA controller. In response, the UDMA controller refills the transmitter FIFO by way of the transmitter holding register (THR) - `UART_RBR_TBR[7-0]` `RBR_DATA`. The UTXEV signal is also sent to the UDMA controller when the PRUSS UART0 is taken out of reset using the [14]UTRST bit in the power and emulation management register (`UART_PWR`).

Activity in DMA channels can be synchronized to these events. In the non-FIFO mode, the PRUSS UART0 generates no DMA events. Any DMA channel synchronized to either of these events must be enabled at the time the PRUSS UART0 event is generated. Otherwise, the DMA channel will miss the event and, unless the PRUSS UART0 generates a new event, no data transfer will occur.

#### 7.4.7.3.7 PRUSS UART Operations

##### 7.4.7.3.7.1 PRUSS UART FIFO Modes

The following two modes can be used for servicing the receiver and transmitter FIFOs:

- FIFO interrupt mode. The FIFO is enabled and the associated interrupts are enabled. Interrupts are sent to the CPU to indicate when specific events occur.
- FIFO poll mode. The FIFO is enabled but the associated interrupts are disabled. The CPU polls status bits to detect specific events.

Because the receiver FIFO and the transmitter FIFO are controlled separately, either one or both can be placed into the interrupt mode or the poll mode.

#### 7.4.7.3.7.1.1 PRUSS UART FIFO Interrupt Mode

When the receiver FIFO is enabled in the FIFO control register (FCR), mapped in the MSB part of the register `UART_INT_FIFO`, and the receiver interrupts are enabled in the interrupt enable register `UART_INT_EN`, the interrupt mode is selected for the receiver FIFO. The following are important points about the receiver interrupts:

- The receiver data-ready interrupt is issued to the CPU when the FIFO has reached the trigger level that is programmed in FCR. It is cleared when the CPU or the DMA controller reads enough characters from the FIFO such that the FIFO drops below its programmed trigger level.
- The receiver line status interrupt is generated in response to an overrun error, a parity error, a framing error, or a break. This interrupt has higher priority than the receiver data-ready interrupt. For details, see [Section 7.4.7.3.4](#).
- The data-ready ([0]DR) bit in the line status register - `UART_LSR1`, indicates the presence or absence of characters in the receiver FIFO. The [0]DR bit is set when a character is transferred from the receiver shift register (RSR) to the empty receiver FIFO. The [0]DR bit remains set until the FIFO is empty again.
- A receiver time-out interrupt occurs if all of the following conditions exist:
  - At least one character is in the FIFO,
  - The most recent character was received more than four continuous character times ago. A character time is the time allotted for 1 START bit,  $n$  data bits, 1 PARITY bit, and 1 STOP bit, where  $n$  depends on the word length selected with the WLS0 and WLS1 bits of the line control register `UART_LCTR`. See [Table 7-73](#).
  - The most recent read of the FIFO has occurred more than four continuous character times before.
- Character times are calculated by using the baud rate.
- When a receiver time-out interrupt has occurred, it is cleared and the time-out timer is cleared when the CPU or the EDMA controller reads one character from the receiver FIFO. The interrupt is also cleared if a new character is received in the FIFO or if the URRST bit is cleared in the power and emulation management register - `PWM`.
- If a receiver time-out interrupt has not occurred, the time-out timer is cleared after a new character is received or after the CPU or EDMA reads the receiver FIFO.

When the transmitter FIFO is enabled in `UART_INT_FIFO[0] IIR_IPEND` bit and the transmitter holding register empty (THRE) interrupt is enabled in `UART_INT_EN[1] ETBEI` bit, the interrupt mode is selected for the transmitter FIFO. The THRE interrupt occurs when the transmitter FIFO is empty. It is cleared when the transmitter hold register (THR) `UART_RBR_TBR[7-0] RBR_DATA` bitfield is loaded (1 to 16 characters may be written to the transmitter FIFO while servicing this interrupt) or the [3-1]`IIR_INTID` bitfield is read in the interrupt identification register `UART_INT_FIFO`.

**Table 7-73. Character Time for Word Lengths**

| Word Length ( $n$ ) | Character Time   | Four Character Times |
|---------------------|------------------|----------------------|
| 5                   | Time for 8 bits  | Time for 32 bits     |
| 6                   | Time for 9 bits  | Time for 36 bits     |
| 7                   | Time for 10 bits | Time for 40 bits     |
| 8                   | Time for 11 bits | Time for 44 bits     |

#### 7.4.7.3.7.1.2 PRUSS UART FIFO Poll Mode

When the receiver FIFO is enabled in the FIFO control register (via setting the `UART_INT_FIFO[0] IIR_IPEND` to 1h) and the receiver interrupts are disabled in the interrupt enable register (`UART_INT_EN`), the poll mode is selected for the receiver FIFO. Similarly, when the transmitter FIFO is enabled via setting the same bit (`UART_INT_FIFO[0] IIR_IPEND` to 1h) and the transmitter interrupts are disabled, the transmitted FIFO is in the poll mode. In the poll mode, the CPU detects events by checking bits in the line status register - `UART_LSR1`:

- The `UART_LSR1[7] RXFIFOE` bit indicates whether there are any errors in the receiver FIFO.
- The `UART_LSR1[6] TEMT` bit indicates that both the transmitter holding register (THR) and the transmitter shift register (TSR) are empty.
- The `UART_LSR1[5] THRE` bit indicates when THR ( mapped in the `UART_RBR_TBR[7-0] RBR_DATA` bitfield ) is empty.

- The following line status register - **UART\_LSR1** bits specify which error or errors have occurred:
  - UART\_LSR1[4]** BI - Break Interrupt
  - UART\_LSR1[3]** FE – Framing Error
  - UART\_LSR1[2]** PE – Parity Error
  - UART\_LSR1[1]** OE – Overrun Error
- The **UART\_LSR1[0]** DR (data-ready) bit is set as long as there is at least one byte in the receiver FIFO.

Also, in the FIFO poll mode:

- The interrupt identification ([3-1] **IIR\_INTID**) bit field in register **UART\_INT\_FIFO** are not affected by any events because the interrupts are disabled.
- The PRUSS UART0 does not indicate when the receiver FIFO trigger level is reached or when a receiver time-out occurs.

#### 7.4.7.3.7.2 PRUSS UART Autoflow Control

The PRUSS UART0 can employ autoflow control by connecting the **UART0\_CTS** and **UART0\_RTS** signals. The **UART0\_CTS** input must be active before the transmitter FIFO can transmit data. The **UART0\_RTS** becomes active when the receiver needs more data and notifies the sending device. When **UART0\_RTS** is connected to **UART0\_CTS**, data transmission does not occur unless the receiver FIFO has space for the data. Therefore, when two UARTs are connected as shown in [Figure 7-49](#) with autoflow enabled (**UART\_MCTR[5]** **AFE** = 1h), overrun errors are eliminated.



Figure 7-49. UART Interface Using Autoflow Diagram

#### 7.4.7.3.7.2.1 PRUSS UART Signal **UART0\_RTS** Behavior

**UART0\_RTS** data flow control originates in the receiver block (see [Figure 7-47](#)). When the receiver FIFO level reaches a trigger level of 1, 4, 8, or 14 (see [Figure 7-50](#)), **UART0\_RTS** is deasserted. The sending UART may send an additional byte after the trigger level is reached (assuming the sending UART has another byte to send), because it may not recognize the deassertion of **UART0\_RTS** until after it has begun sending the additional byte. For trigger level 1, 4, and 8, **UART0\_RTS** is automatically reasserted once the receiver FIFO is emptied. For trigger level 14, **UART0\_RTS** is automatically reasserted once the receiver FIFO drops below the trigger level.



A. N = Receiver FIFO trigger level.

- B. The two blocks in dashed lines cover the case where an additional byte is sent.

**Figure 7-50. Autoflow Functional Timing Waveforms for UART0\_RTS**

#### 7.4.7.3.7.2.2 PRUSS UART Signal UART0\_CTS Behavior

The transmitter checks UART0\_CTS before sending the next data byte. If UART0\_CTS is active, the transmitter sends the next byte. To stop the transmitter from sending the following byte, UART0\_CTS must be released before the middle of the last STOP bit that is currently being sent (see Figure 7-51). When flow control is enabled, UART0\_CTS level changes do not trigger interrupts because the device automatically controls its own transmitter. Without autoflow control, the transmitter sends any data present in the transmitter FIFO and a receiver overrun error may result.



icss-021

- A. When UART0\_CTS is active (low), the transmitter keeps sending serial data out.
- B. When UART0\_CTS goes high before the middle of the last STOP bit of the current byte, the transmitter finishes sending the current byte but it does not send the next byte.
- C. When UART0\_CTS goes from high to low, the transmitter begins sending data again.

**Figure 7-51. Autoflow Functional Timing Waveforms for UART0\_CTS**

#### 7.4.7.3.7.3 PRUSS UART Loopback Control

The PRUSS UART0 can be placed in the diagnostic mode using the [4]LOOP bit in the modem control register - UART\_MCTR, which internally connects the PRUSS UART0 output back to the PRUSS UART0's input. In this mode, the transmit and receive data paths, the transmitter and receiver interrupts, and the modem control interrupts can be verified without connecting to another UART.

#### 7.4.7.3.8 PRUSS UART Emulation Considerations

The [0]FREE bit in the power and emulation management register (UART\_PWR) determines how the PRUSS UART0 responds to an emulation suspend event such as an emulator halt or breakpoint. If bit UART\_PWR[0] FREE = 0h and a transmission is in progress, the PRUSS UART0 halts after completing the one-word transmission; if bit UART\_PWR[0] FREE = 0h and a transmission is not in progress, the PRUSS UART0 halts immediately. If UART\_PWR[0] FREE = 1h, the PRUSS UART0 does not halt and continues operating normally.

Note also that most emulator accesses are transparent to PRUSS UART0 operation. Emulator read operations do not affect any register contents, status bits, or operating states, with the exception of the interrupt identification register (UART\_INT\_FIFO). Emulator writes, however, may affect register contents and may affect PRUSS UART0 operation, depending on what register is accessed and what value is written.

The PRUSS UART0 registers can be read from or written to during emulation suspend events, even if the PRUSS activity has stopped.

#### 7.4.7.3.9 PRUSS UART Exception Processing

##### 7.4.7.3.9.1 PRUSS UART Divisor Latch Not Programmed

Since the processor reset signal has no effect on the divisor latch, the divisor latch will have an unknown value after power up. If the divisor latch is not programmed after power up, the baud clock (BCLK) will not operate and will instead be set to a constant logic 1 state.

The divisor latch values should always be reinitialized following a processor reset.

#### **7.4.7.3.9.2 Changing Operating Mode During Busy Serial Communication of PRUSS UART**

Since the serial link characteristics are based on how the control registers are programmed, the PRUSS UART0 module will expect the control registers to be static while it is busy engaging in a serial communication. Therefore, changing the control registers while the module is still busy communicating with another serial device will most likely cause an error condition and should be avoided.

### 7.4.8 PRUSS ECAP Module

#### 7.4.8.1 PRUSS eCAP Overview

##### 7.4.8.1.1 Purpose of the PRUSS eCAP Peripheral

The device PRUSS integrated **enhanced capture (eCAP)** module targets:

- Sample rate measurements of audio inputs
- Speed measurements of rotating machinery (for example, toothed sprockets sensed via Hall sensors)
- Elapsed time measurements between position sensor pulses
- Period and duty cycle measurements of pulse train signals
- Decoding current or voltage amplitude derived from duty cycle encoded current/voltage sensors

##### 7.4.8.1.2 PRUSS eCAP Features

The device PRUSS integrated eCAP module (signified as PRUSS1\_eCAP\_0 throughout the *PRUSS eCAP Module* section) includes the following features:

- 32-bit time base counter
- 4-event time-stamp registers (each 32 bits)
- Edge polarity selection for up to four sequenced time-stamp capture events
- Interrupt on either of the four events
- Single shot capture of up to four event time-stamps
- Continuous mode capture of time-stamps in a four-deep circular buffer
- Absolute time-stamp capture
- Difference (Delta) mode time-stamp capture
- All above resources dedicated to a single input pin
- When not used in capture mode, the ECAP module can be configured as a single channel PWM output

#### 7.4.8.2 PRUSS ECAP Functional Description

For full description of the PRUSS ECAP0 module and functionality, refer to the *Enhanced Capture (eCAP) Module*.

##### 7.4.8.2.1 PRUSS Capture and APWM Operating Mode

The PRUSS1\_eCAP\_0 module resources can be used to implement a single-channel PWM generator (with 32 bit capabilities) when it is not being used for input captures. The counter operates in count-up mode, providing a time-base for asymmetrical pulse width modulation (PWM) waveforms. The PRUSS\_ECAP\_CAP1 and PRUSS\_ECAP\_CAP2 registers become the active period and compare registers, respectively, while PRUSS\_ECAP\_CAP3 and PRUSS\_ECAP\_CAP4 registers become the period and capture shadow registers, respectively. [Figure 7-52](#) is a high-level view of both the capture and auxiliary pulse-width modulator (APWM) modes of operation.

- A single pin is shared between CAP and APWM functions. In capture mode, it is an input; in APWM mode, it is an output.
- In APWM mode, writing any value to PRUSS\_ECAP\_CAP1/PRUSS\_ECAP\_CAP2 active registers also writes the same value to the corresponding shadow registers PRUSS\_ECAP\_CAP3/PRUSS\_ECAP\_CAP4. This emulates immediate mode. Writing to the shadow registers PRUSS\_ECAP\_CAP3/PRUSS\_ECAP\_CAP4 invokes the shadow mode.

**Figure 7-52. PRUSS Capture and APWM Modes of Operation**

### 7.4.9 PRUSS IEP

This section describes the Industrial Ethernet Peripheral (IEP) Module which is part of the PRUSS.

#### 7.4.9.1 PRUSS IEP Overview

The Industrial Ethernet Peripheral (IEP) performs hardware work required for Industrial Ethernet functions. The IEP module features an industrial ethernet timer with 16 compare events, industrial ethernet sync generator and latch capture, industrial ethernet watchdog timer, and a digital I/O port (DIGIO).

#### 7.4.9.2 PRUSS IEP Functional Description

This section provides the functional description of the IEP component. The PRUSS module implements one Industrial Ethernet Peripheral (IEP). The IEP functional block diagram is shown in [Figure 7-53](#).

**n = 0**

**Figure 7-53. IEP Functional Block Diagram**

#### 7.4.9.2.1 PRUSS IEP Clock Generation

The IEP has a selectable module input clock (PRU\_ICSS\_IEP\_CLK, see also *PRUSS in Module Integration*). The clock source is selected by the state of the CTRLMMR\_PRU\_ICSS\_CLKSEL[19-16] IEP\_CLKSEL bit within the CTRL\_MMR0 register space. Two clock sources are supported for the IEP input clock:

- PRU\_ICSS\_IEP\_CLK (where n = 0 or 1): The source clock for IEP module can be selected through IEP Clock Multiplexer (see also *PRUSS in Module Integration*). The default functional source clock for IEP is MAIN\_PLL3\_HSDIV1\_CLKOUT, derived from PLL3 HSDIV1. The IEP functional clock (PRU\_ICSS\_IEP\_CLK) runs at 200 or 250 MHz.
- PRU\_ICSS\_ICLK (where n = 0 or 1): The PRUSS interface clock is derived as divided version of the device PLLCTRL output clock (SYSCLK0/2).

Switching from PRU\_ICSS\_IEP\_CLK to PRU\_ICSS\_ICLK is done by writing 1h to the PRU\_ICSS\_IEPCLK\_REG/PRU\_ICSS0\_IEPCLK\_REG[0] IEP\_OCP\_CLK\_EN bit. This is a one time configuration step before enabling the IEP function. Switching back from PRU\_ICSS\_ICLK to PRU\_ICSS\_IEP\_CLK is only supported through a hardware reset of the PRUSS.

#### CAUTION

When software enables the clock (at PRUSS level) to the IEP module clock input via setting bit PRU\_ICSS\_IEPCLK\_REG/PRU\_ICSS0\_IEPCLK\_REG[0] IEP\_OCP\_CLK\_EN to 1h in the PRUSS\_CFG space, there must be NO in-flight transactions to the IEP block.

#### CAUTION

Switching from PRU\_ICSS\_IEP\_CLK (the IEP specific functional clock source) to the PRU\_ICSS\_CORE\_CLK source is supported ONLY in software. Switching back from PRU\_ICSS\_CORE\_CLK to PRU\_ICSS\_IEP\_CLK is ONLY supported via assertion of a hardware reset to the PRUSS.

#### 7.4.9.2.2 PRUSS IEP Timer

The IEP timer is a simple 64-bit timer. This timer is intended for use by industrial ethernet functions but can also be leveraged as a generic timer in other applications.

##### 7.4.9.2.2.1 PRUSS IEP Timer Features

The IEP timer supports the following features:

- One controller 64-bit count-up counter with an overflow status bit.
  - Runs on ICSS\_IEP\_CLK or ICSS\_ICLK clock.
  - Write 1h to clear status.

- Supports a programmable increment value from 1 to 16 (default 5).
- An optional compensation method allows the increment value to apply compensation increment value from 1 to 16 count up to  $2^{24}$  ICSS\_IEP\_CLK events with additional slow compensation mode.
- 10× 64-bit capture registers:
  - 8 capture inputs, with optional synchronous or asynchronous mode:
    - 6× rise capture registers: ICSS\_IEP\_CAPRI\_REG0/ IEP\_CAPRI\_REG1 (where i=0 to 5)
    - 2× rise and fall capture registers: IEP\_CAPR6\_REG0/ IEP\_CAPR6\_REG1 and IEP\_CAPR7\_REG0/ IEP\_CAPR7\_REG1, each combined with a fall capture - IEP\_CAPF6\_REG0/ IEP\_CAPF6\_REG1 and IEP\_CAPF7\_REG0/ IEP\_CAPF7\_REG1, respectively
    - One global event (any capture event) output for interrupt
  - 16 status bits, write 1h to clear
  - 16 individual event outputs
  - One global event output for interrupt generation triggered by any compare event
- 32 outputs, one high-level and one high-pulse for each compare hit event
- IEP\_CMP\_CFG\_REG[0] CMP0\_RST\_CNT\_EN, if enabled, resets the controller counter on the next ICSS\_IEP\_CLK/ ICSS\_ICLK cycle
- Controller counter reset-state is programmable
- Optional 32-bit shadow mode of operation, which can be configured through IEP\_CMP\_CFG\_REG[17] SHADOW\_EN bit

#### 7.4.9.2.3 32-Bit Shadow Mode

The IEP module can be configured in 32-bit shadow mode when IEP\_CMP\_CFG\_REG[17] SHADOW\_EN bit is set to 1h (default value is 0h, e.g. 64-bit mode of operation is enabled). In this mode, the controller counter will be in 32-bit mode of operation. This enables the shadow copy functionality of the compare registers.

##### Rules of operation:

1. Switching the state of the controller counter from 32-bit Shadow mode to 64-bit mode of operation, the counter should be disabled and bit IEP\_CMP\_CFG\_REG[17] SHADOW\_EN should be cleared to 0h (default value).
2. A new compare update (IEP\_CMP\_CFG\_REG[16-1] CMP\_EN = 1h - enables CMP[0:15] event, where [0]CMP\_EN maps to CMP0) should be set 4 cycle counts before the next rollover or reset of the counter and to insure the correct shadow copy to active update is correct.

##### Sequence of operation:

1. Disable counter trough IEP\_GLOBAL\_CFG\_REG[0] CNT\_ENABLE = 0h (default value).
2. Clear controller counter through IEP\_CMP\_CFG\_REG[17] SHADOW\_EN = 0h (64-bit mode of operation)
3. Enable 32-bit Shadow mode through IEP\_CMP\_CFG\_REG[17] SHADOW\_EN bit (value: 1h)
4. Program IEP\_CMPm\_REGn (where m = 0 to 15 and n = 0 to 1); use the upper 32-bits (IEP\_CMP0\_REG1[31-0] CMP0\_1) of the 64-bit CMP
  - a. The lower 32-bits are the active compare value (IEP\_CMPm\_REG0[31-0] CMPm\_0, where m = 0 to 15), software can only read this bits
  - b. The upper 32-bits are the shadow copy (IEP\_CMPm\_REG1[31-0] CMPm\_1, where m = 0 to 15), software can write and read this bits
5. Enable counter trough IEP\_GLOBAL\_CFG\_REG[0] CNT\_ENABLE = 1h

After the counter is enabled, then software can load a new set of CMP[0:15] without affecting the current active values of (IEP\_CMPm\_REG0[31-0] CMPm\_0, where m = 0 to 15). Only when the counter is reset to 32-bit Shadow mode (IEP\_CMP\_CFG\_REG[17] SHADOW\_EN = 1h), it will load the shadow copy of IEP\_CMPm\_REG1[31-0] CMPm\_1 into local copy.

Shadow compare value (IEP\_CMPm\_REG1[31-0] CMPm\_1) is loaded into active register IEP\_CMPm\_REG0[31-0] CMPm\_0 when the controller counter is configured in 32-bit Shadow mode. If

IEP\_CMP\_CFG\_REG[0] CMP0\_RST\_CNT\_EN bit is enabled (value 1h) to reset the counter, the next reset event will be defined by the last CMP0 update.

#### 7.4.9.2.4 PRUSS IEP Timer Basic Programming Sequence

Follow these basic steps to configure the IEP Timer.

##### Counter maintains/function:

1. Once enabled, the counter will count every PRU\_ICSS\_IEP\_CLK cycle, default rate of 200 MHz.
2. It is a free running counter with a sticky over flag status bit.
3. The counter over flow flag (IEP\_GLOBAL\_STATUS\_REG[0] CNT\_OVF) will get set when the counter switches/rollsover from 0xFFFF\_FFFF to 0x0000\_0000.
4. The counter will continue to count up. The software will need to read/clear the counter over flow flag and increment the MSB in software variable.

##### Compare function:

1. Initialize timer to known state (default values)
  - Disable counter (IEP\_GLOBAL\_CFG\_REG[0] CNT\_ENABLE = 0)
  - Reset Count Register (IEP\_COUNT\_REG0, IEP\_COUNT\_REG1) by writing FFFFFFFFh to clear
  - Clear overflow status register (IEP\_GLOBAL\_STATUS\_REG[0] CNT\_OVF = 1)
  - Clear compare status (IEP\_CMP\_STATUS\_REG[15-0] CMP\_STATUS) by writing FFFFFFFFh to clear
2. Set compare values IEP\_CMPj\_REG0, IEP\_CMPj\_REG1 (where j = 0 to 15)
3. Enable compare events (IEP\_CMP\_CFG\_REG[16-1] CMP\_EN = 1)
4. Set increment value (IEP\_GLOBAL\_CFG\_REG[7-4] DEFAULT\_INC)
5. Set compensation value (IEP\_COMPEN\_REG[22-0] COMPEN\_CNT)
6. Enable counter (IEP\_GLOBAL\_CFG\_REG[0] CNT\_ENABLE = 1)

##### Capture function:

1. Update/Enable the counter if required
2. Program the enable the desired capture event
3. Wait for global capture event
4. Read/Clear the capture status to determine which capture event occurred
5. Read the capture count

#### 7.4.9.2.5 Industrial Ethernet Mapping

Some of the capture inputs and compare registers are mapped to specific industrial Ethernet functions in hardware, shown in [Table 7-74](#). All capture inputs are mapped to industrial Ethernet functions, and these inputs are not available for any other application. The CMP1 and CMP2 compare registers also function as the start time triggers for SYNC0 and SYNC1, respectively.

**Table 7-74. IEP Timer Mode Mapping**

| Capture Input                             | IEP Line/Function                                                                                                                                      |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| IEP_CAPR0_REG0/ IEP_CAPR0_REG1, rise only | If EXT_CAP_EN[0] = 0h (Internal source is selected)/<br>PRU0_RX_SOF<br>If EXT_CAP_EN[0] = 1h (External source is selected)/<br>ICSS_IEP_CAP_INTR_REQ0  |
| IEP_CAPR1_REG0/ IEP_CAPR1_REG1, rise only | If EXT_CAP_EN[1] = 0h (Internal source is selected)/<br>PRU0_RX_SFD<br>If EXT_CAP_EN[1] = 1h (External source is selected)/<br>ICSS_IEP0_CAP_INTR_REQ1 |
| IEP_CAPR2_REG0/ IEP_CAPR2_REG1, rise only | If EXT_CAP_EN[2] = 0h (Internal source is selected)/<br>PRU1_RX_SOF<br>If EXT_CAP_EN[2] = 1h (External source is selected)/<br>ICSS_IEP_CAP_INTR_REQ2  |
| IEP_CAPR3_REG0/ IEP_CAPR3_REG1, rise only | If EXT_CAP_EN[3] = 0h (Internal source is selected)/<br>PRU1_RX_SFD<br>If EXT_CAP_EN[3] = 1h (External source is selected)/<br>ICSS_IEP_CAP_INTR_REQ3  |

**Table 7-74. IEP Timer Mode Mapping (continued)**

| Capture Input                                                                      | IEP Line/Function                                                                                                                                                                                                       |
|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IEP_CAPR4_REG0/ IEP_CAPR4_REG1, rise only                                          | If EXT_CAP_EN[4] = 0h (Internal source is selected)/<br>PORT0_TX_SOF; For MII mode uses loopback for lower jitter 40ns<br>versus 4ns.<br>If EXT_CAP_EN[4] = 1h (External source is selected)/<br>ICSS_IEP_CAP_INTR_REQ4 |
| IEP_CAPR5_REG0/ IEP_CAPR5_REG1, rise only                                          | If EXT_CAP_EN[5] = 0h (Internal source is selected)/<br>PORT1_TX_SOF<br>For MII mode uses loopback for lower jitter 40ns versus 4ns.<br>If EXT_CAP_EN[5] = 1h (External source is selected)/<br>ICSS_IEP_CAP_INTR_REQ5  |
| IEP_CAPR6_REG0/ IEP_CAPR6_REG1 - rise and<br>IEP_CAPF6_REG0/ IEP_CAPF6_REG1 - fall | PR_IEP_EDC_LATCH_IN0 (IO inputs at SoC level)                                                                                                                                                                           |
| IEP_CAPR7_REG0/ IEP_CAPR7_REG1 - rise and<br>IEP_CAPF7_REG0/ IEP_CAPF7_REG1 - fall | PR_IEP_EDC_LATCH_IN1 (IO inputs at SoC level)                                                                                                                                                                           |
| IEP_CMP1_REG0/ IEP_CMP1_REG1                                                       | For SYNC0 trigger of start time                                                                                                                                                                                         |
| IEP_CMP2_REG0/ IEP_CMP2_REG1                                                       | For SYNC1 trigger of start time; only valid in the SYNC2 independent mode                                                                                                                                               |
| IEP_CMP3_REG0/ IEP_CMP3_REG1                                                       | For MII TX0 start trigger, if MII register MII_RT_TXCFG0/1[2]<br>TX_EN_MODEn is enabled (where n = 0 or 1).                                                                                                             |
| IEP_CMP4_REG0/ IEP_CMP4_REG1                                                       | For MII TX1 start trigger, if MII register MII_RT_TXCFG0/1[2]<br>TX_EN_MODEn is enabled (where n = 0 or 1).                                                                                                             |

#### 7.4.9.2.6 PRUSS IEP Sync0/Sync1 Module

The industrial ethernet sync block supports the generation of two synchronization signals: SYNC0 and SYNC1. SYNC0 and SYNC1 can be directly mapped to output signals (pr<k>\_iep<n>\_edc\_sync\_out0 and pr<k>\_iep<n>\_edc\_sync\_out1) for external devices to use. They can also be used for internal synchronization within the PRUSS. These signals are also mapped as system events and can therefore be mapped to the Arm core's Host interrupts.

##### 7.4.9.2.6.1 PRUSS IEP Sync0/Sync1 Features

The industrial ethernet sync block supports the following features:

- Two synchronize generation signals (SYNC0, SYNC1)
  - Activation time synchronized with IEP Timer
- IEP\_CMP1\_REG0/ IEP\_CMP1\_REG1 triggers SYNC0 activation time
- IEP\_CMP2\_REG0/ IEP\_CMP2\_REG1 triggers SYNC1 activation time (only valid in the SYNC2 independent mode)
  - Pulse width defined by registers or acknowledge mode (remain asserted until software acknowledged)
  - Cyclic or single-shot operation
  - Option to enable or disable sync generation
- Programmable number of clock cycles between the start of SYNC0 to the start of SYNC1

##### 7.4.9.2.6.2 PRUSS IEP Sync0/Sync1 Generation Modes

There are four modes of operation for the sync signals: cyclic mode, single shot mode, cyclic with acknowledge mode, and single shot with acknowledge mode. [Figure 7-54](#) shows examples of these modes.

The start time is set by the IEP\_SYNC\_START\_REG[31-0] SYNC\_START bit field. The cycle time is configured by the IEP\_SYNC0\_PERIOD\_REG[31-0] SYNC0\_PERIOD bit field. The pulse length is defined by IEP\_SYNC\_PWIDTH\_REG[31-0] SYNC\_HPW bit field.



**Figure 7-54. PRUSS IEP SYNC0 Signal Generation Modes**

In SYNC1 dependent mode (IEP\_SYNC\_CTRL\_REG[8] SYNC1\_IND\_EN = 0h), SYNC1 depends on SYNC0 and the start time of the SYNC1 can be defined by the IEP\_SYNC1\_DELAY\_REG register. Figure 7-55 shows different examples when changing the value in the IEP\_SYNC1\_DELAY\_REG register. Note: If the SYNC1 delay time is 0, SYNC1 reflects SYNC0. Cyclic generation cannot be used for network time synchronized applications because only the CMP1/CMP2 hit occurs in the compensated time domain.



pruss-031

**Figure 7-55. Examples of the Dependent Mode of SYNC1**

#### 7.4.9.2.7 PRUSS IEP WatchDog

In industrial ethernet applications, the watchdog timer (WD) is used to monitor process data communication and to turn off the outputs of the digital input/output (DIGIO) functional block after a set time. The WD will thereby protect the system from errors or faults by timeout or expiration. The expiration is used to initiate corrective action in order to keep the system in a safe state and restore normal operation based on configuration. Therefore, if the system is stable, the watchdog timer should be regularly reset or cleared to avoid timeout or expiration.

The IEP watchdog timer supports the following features:

- One 16-bit pre-divider for generating a WD clock (default 100µs) based on PRU\_ICSS\_IPI\_CLK input

- Two 16-bit Watchdog Timers:
  - PDI\_WD for Sync Managers WD, used in conjunction with digital input/output (DIGIO)
  - PD\_WD for data link layer user WD, used in conjunction with data link layer or application layer interface actions

---

#### Note

For more details on the PRUSS Industrial Ethernet Watchdog timer, refer also to the Watchdog timer register descriptions covered in the ICSSM Registers,

---

#### 7.4.9.2.8 PRUSS IEP DIGIO

The IEP digital I/O (DIGIO) block provides dedicated I/Os for industrial ethernet protocols. The digital inputs can be sampled when specific events occur or continuously as a raw input. Likewise, driving the digital outputs can be triggered by specific events or controlled by software. The timing, delay cycle clocks, data sources, and data valid of the digital input and outputs are controlled by the IEP\_DIGIO\_CTRL\_REG and IEP\_DIGIO\_EXP\_REG registers. Additionally, the IEP DIGIO block can be used as generic I/Os in other applications.

##### 7.4.9.2.8.1 PRUSS IEP DIGIO Features

The IEP digital I/O supports the following features:

- Digital data output:
  - 4 channels (PR<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28])
  - Five event options for driving output data output:
    - End of frame event (PRU0/1\_RX\_EOF)
    - SYNC0 events
    - SYNC1 events
    - Watchdog trigger
    - Software enable
- Digital data out enable (optional tri-state control)
- Digital data input:
  - 4 channels (PR<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28])
  - IEP\_DIGIO\_DATA\_IN\_RAW\_REG supports direct sampling of PR<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28]
  - IEP\_DIGIO\_DATA\_IN\_REG supports four event options to trigger sampling of PR<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28]:
    - Start of frame event in start of frame (SOF) mode
    - pr<k>\_iep<n>\_edc\_latch\_in<0/1> event
    - SYNC0 events: pr<k>\_iep<n>\_edc\_sync\_out0
    - SYNC1 events: pr<k>\_iep<n>\_edc\_sync\_out1

The industrial digital I/Os supported by the PRUSS IEP peripheral are described in [Table 7-75](#).

**Table 7-75. PRUSS IEP Digital IOs**

| Direction | Port                                    | Mapped to Device I/Os            | Notes                                                                                   |
|-----------|-----------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------|
| output    | PR<k>_IEP0_EDIO_DATA_IN_OUT[0:31]<br>1] | PR0_IEP0_EDIO_DATA_IN_OUT[31:28] | Only PR<k>_IEP0_EDIO_DATA_IN_OUT[31:28] are exported to device pins as a bidirectional. |
| output    | PR<k>_EDIO_DATA_OUT_EN[0:31]            | No                               | Optional tri-state control for DATA_OUT                                                 |
| output    | PR<k>_IEP0_EDIO_OUTVALID                | PR0_IEP0_EDIO_OUTVALID           | Will pulse even same data                                                               |
| output    | PR<k>_EDIO_SOF                          | No                               | PRU<0/1>_RX_SOF defined by IEP_DIGIO_EXP_REG[12] SOF_SEL                                |
| input     | PR<k>_EDIO_OE_EXT                       | No                               |                                                                                         |
| output    | PR<k>_EDIO_WD_TRIG                      | No                               | Just export of IEP_WD_STATUS_REG[0] PD_WD_STAT                                          |

**Table 7-75. PRUSS IEP Digital IOs (continued)**

| Direction | Port                       | Mapped to Device I/Os    | Notes                 |
|-----------|----------------------------|--------------------------|-----------------------|
| output    | PR<k>_IEDIO_DATA_ENA       | No                       | Reserved. Driven low. |
| input     | PR<k>_IEP<n>_EDC_LATCH_IN0 | PR0_IEP<n>_EDC_LATCH_IN0 |                       |
| input     | PR<k>_IEP<n>_EDC_LATCH_IN1 | PR0_IEP<n>_EDC_LATCH_IN1 |                       |
| output    | PR<k>_IEP<n>_EDC_SYNC_OUT0 | PR0_IEP<n>_EDC_SYNC_OUT0 |                       |
| output    | PR<k>_IEP<n>_EDC_SYNC_OUT1 | PR0_IEP<n>_EDC_SYNC_OUT1 |                       |

#### 7.4.9.2.8.2

The industrial digital I/Os supported by the PRUSS IEP peripheral are described in the [Table 7-76](#):

**Table 7-76. PRUSS IEP Digital IOs**

| Direction | Port                               | Mapped to Device I/Os                                                  | Notes                                                                                    |
|-----------|------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| output    | PRG<k>_IEP0_EDIO_DATA_IN_OUT[0:31] | PRG0_IEP0_EDIO_DATA_IN_OUT[31:28]<br>PRG1_IEP0_EDIO_DATA_IN_OUT[31:28] | Only PRG<k>_IEP0_EDIO_DATA_IN_OUT[31:28] are exported to device pins as a bidirectional. |
| output    | PRG<k>_EDIO_DATA_OUT_EN[0:31]      | No                                                                     | Optional tri-state control for DATA_OUT                                                  |
| output    | PRG<k>_IEP0_EDIO_OUTVALID          | PRG0_IEP0_EDIO_OUTVALID<br>PRG1_IEP0_EDIO_OUTVALID                     | Will pulse even same data                                                                |
| output    | PRG<k>_EDIO_SOF                    | No                                                                     | PRU<0/1>_RX_SOF defined by IEP_DIGIO_EXP_REG[12] SOF_SEL                                 |
| input     | PRG<k>_EDIO_OE_EXT                 | No                                                                     |                                                                                          |
| output    | PRG<k>_EDIO_WD_TRIG                | No                                                                     | Just export of IEP_WD_STATUS_REG[0] PD_WD_STAT                                           |
| output    | PRG<k>_EDIO_DATA_ENA               | No                                                                     | Reserved. Driven low.                                                                    |
| input     | PRG<k>_IEP<n>_EDC_LATCH_IN0        | PRG0_IEP<n>_EDC_LATCH_IN0<br>PRG1_IEP<n>_EDC_LATCH_IN0                 |                                                                                          |
| input     | PRG<k>_IEP<n>_EDC_LATCH_IN1        | PRG0_IEP<n>_EDC_LATCH_IN1<br>PRG1_IEP<n>_EDC_LATCH_IN1                 |                                                                                          |
| output    | PRG<k>_IEP<n>_EDC_SYNC_OUT0        | PRG0_IEP<n>_EDC_SYNC_OUT0<br>PRG1_IEP<n>_EDC_SYNC_OUT0                 |                                                                                          |
| output    | PRG<k>_IEP<n>_EDC_SYNC_OUT1        | PRG0_IEP<n>_EDC_SYNC_OUT1<br>PRG1_IEP<n>_EDC_SYNC_OUT1                 |                                                                                          |

#### 7.4.9.2.8.3 PRUSS IEP DIGIO Block Diagrams

[Figure 7-56](#) shows the signals and registers for capturing the DIGIO data in. Note that bit field [5-4]IN\_MODE in the IEP\_DIGIO\_CTRL\_REG register must be set to 1h for data to be latched on the external PR<k>\_IEP<n>\_EDC\_LATCH\_IN0 signal. In PRU0/1\_RX\_SOF mode, the delay time of capturing PRG<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28] is programmable through the [11-8]SOF\_DLY bit of the IEP\_DIGIO\_EXP\_REG register.



Figure 7-56. IEP DIGIO Data In

Figure 7-57 shows the signals and registers for driving the DIGIO data out.

The PR<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28] is immediately forced to zero when IEP\_DIGIO\_CTRL\_REG[1] OUTVALID\_MODE = 1h, pr1\_edio\_oe\_ext = 1h, and pd\_wd\_exp = 1h, or the next update hardware post pd\_wd\_exp. Delay assertion of PR<k>\_IEP0\_EDIO\_OUTVALID from PR<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28] update events are controlled by software through IEP\_DIGIO\_EXP\_REG[2] SW\_OUTVALID.



Figure 7-57. IEP DIGIO Data Out

#### 7.4.9.2.8.4 PRUSS IEP Basic Programming Model

Follow these steps to configure and read the DIGIO Data Input:

1. Read IEP\_DIGIO\_DATA\_IN\_RAW\_REG for raw input data

or

1. Enable sampling of PR<k>\_IEP0\_EDIO\_DATA\_IN\_OUT[31:28] by setting IEP\_DIGIO\_CTRL\_REG[5-4] IN\_MODE = 1h.
2. Read IEP\_DIGIO\_DATA\_IN\_REG for data sampled upon PR<k>\_IEP<n>\_EDC\_LATCH\_IN0 posedge

Follow these steps to configure and write to the DIGIO Data Output:

1. Pre-configure DIGIO by setting IEP\_DIGIO\_EXP\_REG[1] OUTVALID\_OVR\_EN and IEP\_DIGIO\_EXP\_REG[0] SW\_DATA\_OUT\_UP
2. Write to IEP\_DIGIO\_DATA\_OUT\_REG to configure output data.
3. To HiZ output, set corresponding IEP\_DIGIO\_DATA\_OUT\_EN\_REG[31-0] DATA\_OUT\_EN bits to 1h (clear to 0h to drive value stored in IEP\_DIGIO\_DATA\_OUT\_REG).

Chapter 8  
**Interprocessor Communication (IPC)**

---



This chapter describes the interprocessor communication (IPC) modules in the device.

|                                                            |            |
|------------------------------------------------------------|------------|
| <b>8.1 Inter-processor Communication Scheme (IPC).....</b> | <b>787</b> |
|------------------------------------------------------------|------------|

## 8.1 Inter-processor Communication Scheme (IPC)

Device has multiple hardware mechanisms to provide inter-processor level communication.

## 8.1.1 Mailbox

This chapter describes the Mailbox module of the device.

### 8.1.1.1 Mailbox Overview

Mailbox module serves to facilitate the communication between the various on-chip processors of the device by providing a queued mailbox-interrupt mechanism.

The queued mailbox-interrupt mechanism allows the software to establish a communication channel between two processors (users) through a set of registers and associated interrupt signals.

#### 8.1.1.1.1 Mailbox Features

Each mailbox module supports the following features:

- Parameters configured at design time:
  - Number of mailbox clusters
    - Each mailbox cluster has the same configuration
    - Clusters are accessed via separate VBUS regions. Clusters can be treated as mailbox module instances.
  - Number of users
  - Number of mailbox message queues
  - Number of messages (FIFO depth) for each message queue
- 32-bit message width
- Partial writes do not advance the FIFO pointers
- Message reception and queue-not-full notification using interrupts
- Non-intrusive emulation

---

#### Note

Some features may not be available. See *Module Integration* for more information.

---

### 8.1.1.2 Mailbox Functional Description

The mailbox module provides a means of communication through message queues among the users. The individual mailbox modules, or FIFOs, can associate (or de-associate) with any of the processors using the MAILBOX\_IRQ\_ENABLE\_SET\_j (or MAILBOX\_IRQ\_ENABLE\_CLR\_j) register.

Each user has a dedicated interrupt signal from the corresponding mailbox module instance and dedicated interrupt enabling and status registers.

Each MAILBOX\_IRQ\_STATUS\_RAW\_j/MAILBOX\_IRQ\_STATUS\_CLR\_j interrupt status register corresponds to a particular user.

#### 8.1.1.2.1 Mailbox Block Diagram

Figure 8-1 shows the mailbox internal block diagram.



**Figure 8-1. Mailbox Block Diagram**

c = 0 to 11

j = 0 to 3

y = 0 to 15

#### 8.1.1.2.2 Mailbox Software Reset

The mailbox module supports a software reset through the MAILBOX\_SYSCONFIG[0] SOFTRESET bit. Setting this bit to 1 enables an active software reset that is functionally equivalent to a hardware reset. Reading the MAILBOX\_SYSCONFIG[0] SOFTRESET bit gives the status of the software reset:

- Read 1: the software reset is on-going.
- Read 0: the software reset is complete.

The software must ensure that the software reset completes before doing mailbox operations.

### 8.1.1.2.3 Mailbox Power Management

The clkstop\_idle will be asserted if all of the following are true:

- The VBUSP interface is inactive
- All mailboxes are empty
- There are no enabled events or outstanding interrupts

An enabled event means there is pending action required from one of the users, and it means one or more mailboxes still expect data.

### 8.1.1.2.4 Mailbox Interrupt Requests

An interrupt request allows the user of the mailbox to be notified when a message is received or when the message queue is not full. There is one interrupt per user.

Table 8-1 lists the event flags, and their mask, that can cause module interrupts.

**Table 8-1. Interrupt Events**

| Non-Maskable Event Flag <sup>(1)</sup>              | Maskable Event Flag                                 | Event Mask Bit                                      | Event Unmask Bit                                    | Description                          |
|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|--------------------------------------|
| MAILBOX_IRQ_STATUS_RAW_j[0+y*2]<br>NEWMSGSTATUSMBY  | MAILBOX_IRQ_STATUS_CLR_j[0+y*2]<br>NEWMSG_STATUSMBY | MAILBOX_IRQ_ENABLE_CLR_j[0+y*2]<br>NEWMSG_STATUSMBY | MAILBOX_IRQ_ENABLE_SET_j[0+y*2]<br>NEWMSG_STATUSMBY | Mailbox y receives a new message.    |
| MAILBOX_IRQ_STATUS_RAW_j[1+y*2]<br>NOTFULLSTATUSMBY | MAILBOX_IRQ_STATUS_CLR_j[1+y*2]<br>NOTFULLSTATUSMBY | MAILBOX_IRQ_ENABLE_CLR_j[1+y*2]<br>NOTFULLSTATUSMBY | MAILBOX_IRQ_ENABLE_SET_j[1+y*2]<br>NOTFULLSTATUSMBY | Mailbox y message queue is not full. |

(1) MAILBOX\_IRQ\_STATUS\_RAW\_j register is mostly used for debug purposes.

**CAUTION**

Once an event generating the interrupt request has been processed by the software, it must be cleared by writing a logical 1 in the corresponding bit of the MAILBOX\_IRQ\_STATUS\_CLR\_j register.

Writing a logical 1 in a bit of the MAILBOX\_IRQ\_STATUS\_CLR\_j register will also clear to 0 the corresponding bit in the appropriate MAILBOX\_IRQ\_STATUS\_RAW\_j register.

An event can generate an interrupt request when a logical 1 is written to the corresponding unmask bit in the MAILBOX\_IRQ\_ENABLE\_SET\_j register. Events are reported in the appropriate MAILBOX\_IRQ\_ENABLE\_CLR\_j and MAILBOX\_IRQ\_STATUS\_RAW\_j registers.

An event stops generating interrupt requests when a logical 1 is written to the corresponding mask bit in the MAILBOX\_IRQ\_ENABLE\_CLR\_j register. Events are only reported in the appropriate MAILBOX\_IRQ\_STATUS\_RAW\_j register.

In case of the MAILBOX\_IRQ\_STATUS\_RAW\_j register, the event is reported in the corresponding bit even if the interrupt request generation is disabled for this event.

### 8.1.1.2.5 Mailbox Assignment

#### 8.1.1.2.5.1 Description

To assign a receiver to a mailbox, set the new message interrupt enable bit corresponding to the desired mailbox in the MAILBOX\_IRQ\_ENABLE\_SET\_j register. The receiver reads the MAILBOX\_MESSAGE\_y register to retrieve a message from the mailbox.

An alternate method for the receiver that does not use the interrupts is to poll the MAILBOX\_FIFO\_STATUS\_y and/or MAILBOX\_MSG\_STATUS\_y registers to know when to send or retrieve a message to or from the mailbox. This method does not require assigning a receiver to a mailbox. Because this method does not include the explicit assignment of the mailbox, the software must avoid having multiple receivers use the same mailbox, which can result in incoherency.

To assign a sender to a mailbox, set the queue-not-full interrupt enable bit of the desired mailbox in the MAILBOX\_IRQ\_ENABLE\_SET<sub>j</sub> register, where  $j$  is the number of the sending user. However, direct allocation of a mailbox to a sender is not recommended because it can cause the sending processor to be constantly interrupted.

It is recommended that register polling be used to:

- Check the status of either the MAILBOX\_FIFO\_STATUS<sub>y</sub> or MAILBOX\_MSG\_STATUS<sub>y</sub> registers
- Write the message to the corresponding MAILBOX\_MESSAGE<sub>y</sub> register, if space is available.

The sender might use the queue-not-full interrupt when the initial mailbox status check indicates the mailbox is full. In this case, the sender can enable the queue-not-full interrupt for its mailbox in the appropriate MAILBOX\_IRQ\_ENABLE\_SET<sub>j</sub> register. This allows the sender to be notified by interrupt only when a FIFO queue has at least one available entry.

Reading the MAILBOX\_IRQ\_STATUS\_CLR<sub>j</sub> register determines the status of the new message and the queue-not-full interrupts for a particular user. Writing 1 to the corresponding bit in the MAILBOX\_IRQ\_STATUS\_CLR<sub>j</sub> register acknowledges, and subsequently clears, an interrupt.

**CAUTION**

Assigning multiple senders or multiple receivers to the same mailbox is not recommended.

#### **8.1.1.2.6 Sending and Receiving Messages**

##### **8.1.1.2.6.1 Description**

When a 32-bit message is written to the MAILBOX\_MESSAGE<sub>y</sub> register, the message is appended into the FIFO queue. This queue holds four messages. If the queue is full, the message is discarded.

Queue overflow can be avoided by first reading the MAILBOX\_FIFO\_STATUS<sub>y</sub> register to check that the mailbox message queue is not full before writing a new message to it.

Reading the MAILBOX\_MESSAGE<sub>y</sub> register returns the message at the beginning of the FIFO queue and removes it from the queue. If the FIFO queue is empty when the MAILBOX\_MESSAGE<sub>y</sub> register is read, the value 0 is returned.

The new message interrupt is asserted when at least one message is in the mailbox message FIFO queue. To determine the number of messages in the mailbox message FIFO queue, read the MAILBOX\_MSG\_STATUS<sub>y</sub> register.

### 8.1.1.2.7 Example of Communication

Figure 8-2 shows an example of communication between two processors.



**Figure 8-2. Example of Communication**

mailbox-008

### 8.1.1.3 Mailbox Programming Guide

#### 8.1.1.3.1 Mailbox Low-level Programming Models

This section covers the low-level hardware programming sequences for configuration and usage of the mailbox module.

##### 8.1.1.3.1.1 Global Initialization

###### 8.1.1.3.1.1.1 Surrounding Modules Global Initialization

This section identifies the requirements of initializing the surrounding modules when the mailbox module is to be used for the first time after a device reset. This initialization of surrounding modules is based on the integration of the mailbox.

See *Mailbox Integration*, for further information.

**Table 8-2. Global Initialization of Surrounding Modules for MAILBOX**

| Surrounding Modules   | Comments                                                                                                 |
|-----------------------|----------------------------------------------------------------------------------------------------------|
| LPSC                  | The MAILBOX functional and interface clock must be enabled.                                              |
| Interrupt Controllers | Processor's (user's) interrupt controller must be configured to enable the interrupt request generation. |

###### 8.1.1.3.1.1.2 Mailbox Global Initialization

###### 8.1.1.3.1.1.2.1 Main Sequence - Mailbox Global Initialization

This procedure initializes the mailbox module after a power-on or software reset.

**Table 8-3. Mailbox Global Initialization**

| Step                         | Register/Bit Field/Programming Model | Value |
|------------------------------|--------------------------------------|-------|
| Perform a software reset     | MAILBOX_SYSCONFIG[0] SOFT_RESET      | 0x1   |
| Wait until reset is complete | MAILBOX_SYSCONFIG[0] SOFT_RESET      | =0x0  |

###### 8.1.1.3.1.2 Mailbox Operational Modes Configuration

###### 8.1.1.3.1.2.1 Mailbox Processing modes

###### 8.1.1.3.1.2.1.1 Main Sequence - Sending a Message (Polling Method)

**Table 8-4. Sending a Message (Polling Method)**

| Step                                              | Register/Bit Field/Programming Model | Value |
|---------------------------------------------------|--------------------------------------|-------|
| IF: Is FIFO full?                                 | MAILBOX_FIFO_STATUS_y[0] FULL        | =0x1  |
| Wait until at least one message slot is available | MAILBOX_FIFO_STATUS_y[0] FULL        | =0x0  |
| <b>ELSE</b>                                       |                                      |       |
| Write message                                     | MAILBOX_MESSAGE_y[31:0] VALUE        | 0x-   |
| <b>ENDIF</b>                                      |                                      |       |

###### 8.1.1.3.1.2.1.2 Main Sequence - Sending a Message (Interrupt Method)

**Table 8-5. Sending a Message (Interrupt Method)**

| Step                   | Register/Bit Field/Programming Model | Value |
|------------------------|--------------------------------------|-------|
| IF: Is FIFO full?      | MAILBOX_FIFO_STATUS_y[0] FULL        | =0x1  |
| Enable interrupt event | MAILBOX_IRQ_ENABLE_SET_j[1+y*2]      | 0x1   |

User (processor) can perform another task until interrupt occurs

See [Section 8.1.1.3.1.3.1](#) for interrupt handling in sending mode

**ELSE**

**Table 8-5. Sending a Message (Interrupt Method) (continued)**

| Step          | Register/Bit Field/Programming Model | Value |
|---------------|--------------------------------------|-------|
| Write message | MAILBOX_MESSAGE_y[31:0] VALUE        | 0x-   |
| ENDIF         |                                      |       |

**8.1.1.3.1.2.1.3 Main Sequence - Receiving a Message (Polling Method)****Table 8-6. Receiving a Message (Polling Method)**

| Step                                     | Register/Bit Field/Programming Model   | Value |
|------------------------------------------|----------------------------------------|-------|
| IF: Number of messages is not equal to 0 | MAILBOX_MSG_STATUS_y[2:0] NUM_MESSAGES | ≠0x0  |
| Read message                             | MAILBOX_MESSAGE_y[31:0] VALUE          | 0x-   |
| ENDIF                                    |                                        |       |

**8.1.1.3.1.2.1.4 Main Sequence - Receiving a Message (Interrupt Method)****Table 8-7. Receiving a Message (Interrupt Method)**

| Step                                                                               | Register/Bit Field/Programming Model | Value |
|------------------------------------------------------------------------------------|--------------------------------------|-------|
| Enable interrupt event                                                             | MAILBOX_IRQ_ENABLE_SET_j[0 + y*2]    | 0x1   |
| User (processor) can perform another task until interrupt occurs                   |                                      |       |
| See <a href="#">Section 8.1.1.3.1.3.2</a> for interrupt handling in receiving mode |                                      |       |
|                                                                                    |                                      |       |

**8.1.1.3.1.3 Mailbox Events Servicing****8.1.1.3.1.3.1 Events Servicing in Sending Mode**

Table 8-8 describes the events servicing in sending mode.

**Table 8-8. Events Servicing in Sending Mode**

| Step                             | Register/Bit Field/Programming Model | Value |
|----------------------------------|--------------------------------------|-------|
| Read interrupt status bit        | MAILBOX_IRQ_STATUS_CLR_j[1 + y*2]    | 0x1   |
| Write message                    | MAILBOX_MESSAGE_y[31:0] VALUE        | 0x--  |
| Write 1 to acknowledge interrupt | MAILBOX_IRQ_STATUS_CLR_j[1 + y*2]    | 0x1   |

**8.1.1.3.1.3.2 Events Servicing in Receiving Mode**

Table 8-9 describes the events servicing in receiving mode.

**Table 8-9. Events Servicing in Receiving Mode**

| Step                                      | Register/Bit Field/Programming Model   | Value |
|-------------------------------------------|----------------------------------------|-------|
| Read interrupt status bit                 | MAILBOX_IRQ_STATUS_CLR_j[0 + y*2]      | 0x1   |
| IF: Number of messages is not equal to 0? | MAILBOX_MSG_STATUS_y[2:0] NUM_MESSAGES | ≠0x0  |
| Read message                              | MAILBOX_MESSAGE_y[31:0] VALUE          | 0x--  |
| ELSE                                      |                                        |       |
| Write 1 to acknowledge interrupt          | MAILBOX_IRQ_STATUS_CLR_j[0 + y*2]      | 0x1   |
| ENDIF                                     |                                        |       |

## 8.1.2 Spinlock

This chapter describes the Spinlock module of the device.

### 8.1.2.1 Spinlock Overview

The Spinlock module provides hardware assistance for synchronizing the processes running on multiple processors in the device.

The Spinlock module implements 256 spinlocks (or hardware semaphores), which provide an efficient way to perform a lock operation of a device resource using a single read-access, avoiding the need of a read-modify-write bus transfer that the programmable cores are not capable of.

Figure 8-3 shows an overview of the Spinlock module.



**Figure 8-3. Spinlock Overview**

#### Note

Some features may not be available. See *Module Integration* for more information.

### 8.1.2.2 Spinlock Functional Description

#### 8.1.2.2.1 Spinlock Software Reset

The Spinlock module can be reset by software through the SPINLOCK\_SYSConfig[1] SOFTRESET bit. Setting this bit to 1 enables an active software reset that is functionally equivalent to a hardware reset. The SPINLOCK\_SYSStatus[0] RESETDONE bit can be polled to check the reset status (reading 1 indicates that reset sequence is done; reading 0 indicates that reset sequence is in progress). The software must ensure that the software reset completes before doing Spinlock operations.

#### 8.1.2.2.2 Spinlock Power Management

The Spinlock module supports the Power Idle interface. Software must arrange to only power off the Spinlock module when no locks would be lost. In general, the steps to powering down the Spinlock module are:

1. Software must check that all controllers that may be using the Spinlock module are either:
  - a. Already powered off (all in-use flags are 0)
  - b. Notified that Spinlock is not available and the notification is acknowledged
2. If desired, check that no locks are currently held in the Spinlock module. The status of each bank of 32 locks can be read from the SPINLOCK\_SYSStatus register. If any locks are held, they are orphaned because they are not held by any controller that is still active. Alternatively, you may decide to wait a timeout period to allow any active controller to clean up its locks before powering down.

The Spinlock module may now be powered off.

#### 8.1.2.2.3 About Spinlocks

Spinlocks are present to solve the need for synchronization and mutual exclusion between heterogeneous processors and those not operating under a single, shared operating system. There is no alternative mechanism to accomplish these operations between processors in separate subsystems.

Spinlocks are not the best way to synchronize between tasks or threads on one CPU. Instead, spinlocks are for use in synchronization between different subsystems in the device that don't have any other means of hardware-based synchronization.

Spinlocks do not solve all system synchronization issues. They have limited applicability and should be used with care to implement higher level synchronization protocols.

A spinlock is appropriate for mutual exclusion for access to a shared data structure. It should be used only when:

1. The time to hold the lock is predictable and small (for example, a maximum hold time of less than 200 CPU cycles may be acceptable).
2. The locking task cannot be preempted, suspended, or interrupted while holding the lock (this would make the hold time large and unpredictable).
3. The lock is lightly contended, that is the chance of any other process (or processor) trying to acquire the lock while it is held is small.

If these conditions are met, then the locking code can retry a failed attempt to acquire the lock until success.

If the conditions are not met, then a spinlock is not a good candidate. One alternative is to use a spinlock for critical section control (engineered to meet the conditions) to implement a higher level semaphore that can support preemption, notification, timeout or other higher level properties.

#### 8.1.2.2.4 Spinlock Functional Operation

The Spinlock module supports 256 spinlocks. It accepts only a single command at a time and processes the command fully before accepting the next command. A lock is requested by reading the SPINLOCK\_LOCK\_REG\_i[0] TAKEN bit. There are two states: Taken (SPINLOCK\_LOCK\_REG\_y[0] TAKEN = 1) or Not Taken (SPINLOCK\_LOCK\_REG\_y[0] TAKEN = 0), where y = 0h to FFh.

When the status of lock y (where y = 0 to 255) is Not Taken (free), a read from the SPINLOCK\_LOCK\_REG\_y register returns 0 and sets the lock to Taken (locked). When the status of lock y is Taken, a read returns 1 and does not change the state of the lock.

A write to the SPINLOCK\_LOCK\_REG\_y register does not change the state of lock, unless when writing 0 when the lock is in Taken state. By doing this, the requester frees the lock.

Figure 8-4 shows the SPINLOCK\_LOCK\_REG\_y register state diagram.



Figure 8-4. Lock Register State Diagram

---

**Note**

- There is no support to ensure that a lock register is locked and unlocked by the same process. This must be ensured in software.
  - There is no support to check that the same initiator that acquired the lock is the one that is freeing the lock.
-

### 8.1.2.3 Spinlock Programming Guide

#### 8.1.2.3.1 Spinlock Low-level Programming Models

This section covers the low-level hardware programming sequences for configuration and usage of the module.

##### 8.1.2.3.1.1 Surrounding Modules Global Initialization

This procedure initializes the surrounding modules when the Spinlock module is used for the first time after a device reset.

**Table 8-10. Global Initialization of Surrounding Modules**

| Surrounding Modules | Comments                                                                                           |
|---------------------|----------------------------------------------------------------------------------------------------|
| LPSC                | Spinlock functional and interface clock must be enabled. For more information, see <i>Clocking</i> |

##### 8.1.2.3.1.2 Basic Spinlock Operations

The main Spinlock operations are:

- Clear all the Taken spinlocks (only after a system bug recovery)
- Take a spinlock
- Release spinlock

##### 8.1.2.3.1.2.1 Spinlocks Clearing After a System Bug Recovery

Module initialization (after reset) is not needed, except after system bug recovery. The following table presents the Spinlock initialization after a system bug recovery. Software should store 0 into each of the SPINLOCK\_LOCK\_REG\_y registers at system startup to insure that all locks are initialized to Not Taken.

**Table 8-11. Spinlock System Bug Recovery**

| Step                              | Register                                    | Value |
|-----------------------------------|---------------------------------------------|-------|
| IF: SPINLOCK_SYSTATUS[0] IU0 = 1? | SPINLOCK_SYSTATUS[0] IU0                    | =1    |
| Free the 256 locks                | SPINLOCK_LOCK_REG_y[0] TAKEN (y = 0 to 255) | 0x0   |
| END                               |                                             |       |

##### 8.1.2.3.1.2.2 Take and Release Spinlock

This procedure configures the take and release (free) operations for the Spinlock module. A spinlock should only be held with interrupts disabled. So, before attempting to obtain the spinlock, software must disable interrupts. Then it must read the SPINLOCK\_LOCK\_REG\_y[0] TAKEN bit to attempt to obtain the lock. If it succeeds, it must proceed directly through the critical section then unlock and re-enable interrupts. If the acquisition attempt fails, the acquisition must be reattempted. To prevent unknown interrupt disabled time, interrupts must be re-enabled and then disabled before reattempting to acquire the lock. [Figure 8-5](#) shows the described above procedure.



**Figure 8-5. Take and Release Spinlock**

**Table 8-12. Register Call Summary**

| Register Name                |
|------------------------------|
| SPINLOCK_LOCK_REG_y[0] TAKEN |

**Table 8-13. Subprocess Call Summary**

| Subprocess Name                | Description                                                                                                                                                                                                                            |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Disable (Mask) All Interrupts  | For information about disabling/enabling all interrupts in an Arm® processor, refer to Arm <i>Technical Reference Manual</i> , available at <a href="http://infocenter.arm.com/help/index.jsp">infocenter.arm.com/help/index.jsp</a> . |
| Enable (Unmask) All Interrupts | For information about disabling/enabling all interrupts in other processors, refer to the corresponding processor chapter.                                                                                                             |

### **8.1.3 Secure Proxy (SEC\_PROXY)**

The third IPC hardware mechanism is to use SEC\_PROXY, which provides an IPC mechanism which carries a large message for complex communications among processors. It allows processors to read and write a message in small chunks.

There are two sets of SEC\_PROXY in the device, one SEC\_PROXY is dedicated for IPC for HSM M4F, and the second SEC\_PROXY is for the rest. When the SEC\_PROXY generates events, an IPC message is received or sent, and events are sent to interrupt aggregators before those events are converted into interrupts to the processors. The utilization of SEC\_PROXY is user defined through memory map allocation. Each processor can be allocated with its own SEC\_PROXY region to receive and send IPC messages.

Chapter 9  
**Memory Controllers**

---



This chapter describes the memory controllers in the device.

|                                                               |            |
|---------------------------------------------------------------|------------|
| <b>9.1 DDR Subsystem (DDRSS).....</b>                         | <b>802</b> |
| <b>9.2 Region-based Address Translation (RAT) Module.....</b> | <b>817</b> |

## 9.1 DDR Subsystem (DDRSS)

This section describes the DDR Subsystem (DDRSS) for the device.

### 9.1.1 DDRSS Overview

The DDR subsystem in this device comprises DDR controller, DDR PHY and wrapper logic to integrate these blocks in the device. The DDR subsystem is referred to as DDRSS0 and is used to provide an interface to external SDRAM devices which can be utilized for storing program or data. DDRSS0 is accessed via CBASS0 interconnect.

Table 9-1 shows DDRSS allocation across device domains.

**Table 9-1. DDRSS Allocation Across Device Domains**

| Instance | Domain |      |
|----------|--------|------|
|          | MCU    | MAIN |
| DDRSS0   | -      | ✓    |

Figure 9-1 shows an overview of the DDRSS0 and its surrounding modules.



**Figure 9-1. DDRSS Overview**

The DDRSS0 supports:

- Memory Types:

- DDR4 up to 1600Mbps
- LPDDR4 up to 1600Mbps
- Memory Bus Features:
  - 16-bit width with in-line ECC
  - Up to 2 ranks
  - SDRAM address range up to 8 GB
- System Bus Interface:
  - 128-bit data width
  - Little endian only
  - Address aliasing prevention to block accesses to unpopulated SDRAM region
  - Clock asynchronous to DDR clock
- Configuration Bus Interface:
  - 32-bit data width
  - Linear incrementing addressing mode
  - 32-bit aligned accesses only
  - Little endian only
  - Clock asynchronous to DDR clock
- Key Features:
  - Full coherency across all commands
  - Bank interleaving
  - Priority based scheduling
  - Scheduling based on bank openness
  - Class of Service (CoS) - Three latency classes supported
  - Read/write scheduling to avoid turn-around time
  - Prioritized refresh scheduling
  - Dynamic change of refresh rate via software for extended temperatures
  - Statistical counters for performance management
- SDRAM ECC Features:
  - In-line ECC
  - 32-byte ECC calculated over 256-byte data
  - Read-modify-write ECC for sub-word writes
  - Support ECC cache to improve in-line ECC performance
  - Support 64 cache-lines each 512-byte wide
  - ECC address error logging
  - Statistical counters for counting ECC errors
- Low Power Features:
  - All power modes defined by JEDEC (clock stop for LPDDR4, self-refresh, power-down, etc.)
  - Self-refresh entry and exit via software or hardware clock stop request/acknowledge
  - System bus clock stop via hardware clock stop request/acknowledge when controller is idle
  - Automatic idle power saving mode when no or low activity is detected
  - DDR and system bus clock frequency change using self-refresh via software or hardware clock stop request/acknowledge
  - Turning off SoC power after DDR is put into self-refresh (DDR reset and CKE I/O retention)
  - Tri-stating of all DDR I/O cells via software while driving CKE and RESETn pins during self-refresh
  - LPDDR4 Frequency Set Point (FSP)
- Functional Safety Features:
  - VBUSM2AXI bridge AXI bus timeout
- DDR PHY Features:
  - Automatic and software controllable initialization and calibration (ZQ) for the DDR PHY and I/O cells
  - Automatic and software controllable delay line calibrations with Voltage and Temperature (VT) compensation
  - Automatic and software controllable write levelling with VT compensation

- Automatic read DQS gate training per rank with VT compensation
- Automatic and software controllable DQ/DQS eye training per rank
- Automatic and software controllable read and write data bit deskew
- Automatic and software controllable Command/Address (CA) levelling with VT compensation for LPDDR4
- Automatic and software controllable CA bit deskew for LPDDR4
- Refreshes to SDRAM during leveling and training
- No seeding requirement based on board topology for any of the leveling and training algorithms
- Dynamic/automatic I/O Receiver disable when read transfer is not on going
- Capability of disabling data macros and I/O cells when not in use

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

### **9.1.2 DDRSS Environment**

Please refer to the AM62x DDR Board Design and Layout Guidelines application note for detailed information on DDR interface connections to LPDDR4 and DDR4 memory devices

**Table 9-2** describes the DDRSS0 I/O signals used for connection to SDRAM devices.

**Table 9-2. DDRSS0 I/O signals**

| Module Pin | Device Level Signal | I/O <sup>(1)</sup> | Description                   |
|------------|---------------------|--------------------|-------------------------------|
| RESETN     | DDR0_RESET0_n       | O                  | SDRAM reset                   |
| CK         | DDR0_CK0            | O                  |                               |
| CKN        | DDR0_CK0_n          | O                  | SDRAM differential clock pair |
| ALERTN     | DDR0_ALERT_n        | IO                 | SDRAM parity error output     |
| A[13-0]    | DDR0_A[13-0]        | O                  | SDRAM address and command bus |
| WEN        | DDR0_WE_n           | O                  | SDRAM write enable            |
| CASN       | DDR0_CAS_n          | O                  | SDRAM column address strobe   |
| RASN       | DDR0_RAS_n          | O                  | SDRAM row address strobe      |
| ACTN       | DDR0_ACT_n          | O                  | SDRAM activate                |
| BA[1-0]    | DDR0_BA[1-0]        | O                  | SDRAM bank address            |
| BG[1-0]    | DDR0_BG[1-0]        | O                  | SDRAM bank group              |
| PAR        | DDR0_PAR            | O                  | SDRAM command parity          |
| CSN[1-0]   | DDR0_CS[1-0]_n      | O                  | SDRAM chip select             |
| ODT[1-0]   | DDR0_ODT[1-0]       | O                  | SDRAM on-die termination      |
| CKE[1-0]   | DDR0_CKE[1-0]       | O                  | SDRAM CKE                     |
| DQ[15-0]   | DDR0_DQ[15-0]       | IO                 | SDRAM data bus                |
| DM[1-0]    | DDR0_DM[1-0]        | IO                 | SDRAM data and mask/DBI       |
| DQS[1-0]   | DDR0_DQS[1-0]       | IO                 | SDRAM data strobe             |
| DQSN[1-0]  | DDR0_DQS[1-0]_n     | IO                 | SDRAM data strobe invert      |

(1) I = Input; O = Output

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

### 9.1.3 DDRSS Functional Description

#### 9.1.3.1 Class of Service (CoS)

Commands arriving to the DDRSS0 carry the VBUSM priority whereas the DDR controller uses AXI priority. The VBUSM2AXI bridge has the following registers for flexible mapping of the VBUSM priority to DDR controllers's priority:

- Range match registers:
  - DDRSS\_V2A\_R1\_MAT\_REG
  - DDRSS\_V2A\_R2\_MAT\_REG
  - DDRSS\_V2A\_R3\_MAT\_REG
- Priority map registers:
  - DDRSS\_V2A\_DEF\_PRI\_MAP\_REG
  - DDRSS\_V2A\_R1\_PRI\_MAP\_REG
  - DDRSS\_V2A\_R2\_PRI\_MAP\_REG
  - DDRSS\_V2A\_R3\_PRI\_MAP\_REG

This allows the system to essentially create different classes of service based on the initiator (Route ID) and the priority of the commands.

The priority map registers map the incoming priority to appropriate priority for the DDR controller as shown in [Figure 9-2](#).

---

#### Note

For information about Route ID, see [Section 3.1.4, Route ID in Chapter 3, System Interconnect](#).

---



**Figure 9-2. DDRSS CoS Mapping Diagram**

#### 9.1.3.2 AXI Write Data All-Strobes

The DDR controller data path is connected to the VBUSM2AXI bridge through AXI interface. To enable higher performance and lower latency, the bridge drives the AXI AWALLSTRB signal to a "1" when the AXI write data does not have any byte enable holes. This allows the DDR controller to accept and start processing the write command as soon as possible without waiting for all data. The AXI0\_ALL\_STROBES\_USED\_ENABLE bit in

the DDR Controller must be set to a 0x1 to utilize this feature. The controller ignores the AWALLSTRB signal if AXI0\_ALL\_STROBES\_USED\_ENABLE is set to 0x0.

#### 9.1.3.3 Inline ECC for SDRAM Data

For SDRAM data integrity, the VBUSM2AXI bridge supports inline ECC on the data written to or read from the SDRAM. ECC is enabled by programming the bits in the DDRSS\_ECC\_CTRL\_REG register. ECC is stored together with the data so that a dedicated SDRAM device for ECC is not required.

8-bit single error correction double error detection (SECDED) ECC is calculated over 64-bit data quanta. For every 256-byte data block 32 bytes of ECC is stored inline. Thus 1/9th of the total SDRAM space is used for ECC storage and the rest 8/9th is available for system use. From system point of view that 8/9th of the SDRAM data space are seen as consecutive byte addresses. Even if there are non-ECC protected regions the previously described 1/9th-8/9th rule still applies and consecutive byte addresses are seen from system point of view. Note that 8/9 of the total SDRAM space is available for system use regardless of the size of the ECC region(s). In other words, only 8/9 of the memory is available even in non-ECC regions when ECC is enabled.

The ECC is calculated for all accesses that are within the address ranges protected by ECC. The address ranges are specified through the following registers:

- DDRSS\_ECC\_R0\_STR\_ADDR\_REG
- DDRSS\_ECC\_R0\_END\_ADDR\_REG
- DDRSS\_ECC\_R1\_STR\_ADDR\_REG
- DDRSS\_ECC\_R1\_END\_ADDR\_REG
- DDRSS\_ECC\_R2\_STR\_ADDR\_REG
- DDRSS\_ECC\_R2\_END\_ADDR\_REG

Note that the addresses in these address range registers should be in terms of the DDRSS address space, not the SoC memory space. Even though the SoC memory space for DDR may be split into multiple regions, the DDRSS address space is continuous.

For example, if the beginning of DDR is in SoC memory space 0x8000\_0000 to 0xFFFF\_FFFF, this corresponds to DDRSS address space 0x00000000 to 0x7FFFFFFF. If the SoC has greater DDR address reach, even at a discontinuous address, the address range for these registers would be continuous (eg, if the next DDR address at the SoC level is 0x8800000000, the corresponding address would be continuous at 0x80000000)

Note that the value programmed in the ECC range start/end registers does not include the lower 16 bits of the address. For example, to represent an address of 0x40000000, the register contents would be 0x4000.

The ECC is read and verified during reads if both the DDRSS\_ECC\_CTRL\_REG[0] ECC\_EN and DDRSS\_ECC\_CTRL\_REG[2] ECC\_CK bits are set to 0x1. For 1-bit ECC error, the bridge corrects the data and returns it to the requestor. Although the error is corrected on the returned data, the SDRAM is not corrected. It is responsibility of the system software to correct the ECC error at that location.

It is also responsibility of the system software to pre-load the ECC protected region with known data before functional reads and writes are performed. This can be done by writing to the SDRAM with ECC enabled (DDRSS\_ECC\_CTRL\_REG[0] ECC\_EN = 0x1 and DDRSS\_ECC\_CTRL\_REG[1] RMW\_EN = 0x1) and ECC check disabled (DDRSS\_ECC\_CTRL\_REG[2] ECC\_CK = 0x0). Once the data is loaded in the SDRAM, ECC check must be enabled (DDRSS\_ECC\_CTRL\_REG[2] ECC\_CK = 0x1) before using the DDR interface.

#### 9.1.3.3.1 ECC Cache

The VBUSM2AXI bridge implements a 64-line deep ECC cache for improving inline ECC performance. Each cache line can be allocated to an initiator in the system based on its Route ID. The Route ID allocation to cache line can be done by writing to the DDRSS\_ECC\_RID\_INDX\_REG and DDRSS\_ECC\_RID\_VAL\_REG registers. Since the bridge uses unallocated cache lines for all read accesses without Route ID allocation, one or more locations in the cache should be kept unallocated for better performance. To ensure that at least one cache line remains unallocated, in the case all cache lines are allocated by software, the bridge automatically unallocates the 63rd cache line. Write accesses without Route ID allocation result in ECC and data writes to the SDRAM,

when the DDRSS\_ECC\_CTRL\_REG[4] WR\_ALLOC bit is set to 0x0. When DDRSS\_ECC\_CTRL\_REG[4] WR\_ALLOC is set to 0x1, an unassigned cache-line is allocated to write accesses without Route ID allocation.

#### 9.1.3.3.2 ECC Cache Flush

For low power modes, the bridge supports flushing the cache when DDRSS stop clock request is asserted. When a clock stop is requested, the bridge will start issuing writes to the DRAM until all dirty cache locations are written to the DRAM. Once the writes are complete, the bridge asserts an acknowledge signal to let the subsystem know that the operation is complete. The subsystem uses this acknowledge signal along with acknowledgments from other submodules to generate the final DDRSS stop clock acknowledge to the system.

#### 9.1.3.3.3 ECC Statistics

For 1-bit ECC error, the bridge logs the address location for the error in an internal 2-level deep FIFO. It stores the first two 1-bit ECC errors. The DDRSS\_ECC\_1B\_ERR\_ADR\_LOG\_REG register shows the address on top of the internal FIFO. Software should write 0x1 to the DDRSS\_ECC\_1B\_ERR\_ADR\_LOG\_REG[29-0] ECC\_1B\_ERR\_ADR field to pop the FIFO and display the next address stored. The FIFO is loaded with the address for the next 1-bit ECC error if it is not full. No address comparison will be performed, that is, if a single address is associated with more than one ECC error, that address is logged twice.

The number of 1-bit ECC errors can be counted using the DDRSS\_ECC\_1B\_ERR\_CNT\_REG register. The bridge also supports programming a threshold in the DDRSS\_ECC\_1B\_ERR\_THRSH\_REG register. When the 1-bit error count is equal to or greater than the programmed threshold, the bridge sets the DDRSS\_V2A\_INT\_RAW\_REG[3] ECC1BERR bit and also triggers the DDR0\_DDRSS\_DRAM\_ECC\_CORR\_ERR\_LVL\_0 interrupt. When servicing the interrupt, software needs to clear the error count otherwise further interrupts will not be triggered. For 2-bit ECC errors, the bridge sets the DDRSS\_V2A\_INT\_RAW\_REG[4] ECC2BERR bit and also triggers the DDR0\_DDRSS\_DRAM\_ECC\_UNCORR\_ERR\_LVL\_0 interrupt. The bridge does not correct the data for these uncorrectable errors. Along with generating the interrupt, the bridge also reports an error to the requesting initiator and sends all zeros for the data. The bridge also logs the address location for the error in the DDRSS\_ECC\_2B\_ERR\_ADR\_LOG\_REG register.

The bridge sets the DDRSS\_V2A\_INT\_RAW\_REG[5] ECCM1BERR bit and triggers the DDR0\_DDRSS\_DRAM\_ECC\_UNCORR\_ERR\_LVL\_0 interrupt whenever it receives multiple 1-bit errors in different data words of the same SDRAM burst. This is done because the probability of receiving multiple 1-bit errors in different data words of the same SDRAM burst is very low. If this occurs, the chances are that there were multi-bit errors in each data word. Therefore, for reliability, pessimistic approach is taken to report these as a fatal error. The threshold for the number of 1-bit errors that result in an uncorrected error, reporting can be set by writing to the DDRSS\_ECC\_CTRL\_REG[11-8] COR\_ECC\_THRESH field. For reliability, the threshold is always kept at 0/1 meaning 1-bit error in 2 or more data words is reported as a 2-bit error. For debug, the threshold can be changed to a higher value. Note that since these are multiple 1-bit errors, the statistic logging is done in the DDRSS\_ECC\_1B\_ERR\_CNT\_REG and DDRSS\_ECC\_1B\_ERR\_ADR\_LOG\_REG registers.

#### 9.1.3.4 Address Alias Prevention

The VBUSM2ZXi bridge checks the VBUSM address received against the valid SDRAM address space programmed in the DDRSS\_V2A\_CTL\_REG register. If the VBUSM address for an access falls outside the programmed range the bridge sets to 0x1 the DDRSS\_V2A\_INT\_RAW\_REG[1] AERR bit and also triggers the DDR0\_DDRSS\_V2A\_OTHER\_ERR\_LVL\_0 interrupt. The address and the Route ID for the command caused error are logged in the DDRSS\_V2A\_AERR\_LOG1\_REG and DDRSS\_V2A\_AERR\_LOG2\_REG registers.

The bridge fragments all incoming transactions into 32-byte accesses aligned at a 32-byte boundary. Therefore, for commands greater than 32 bytes with an address error, each fragment will report an error. This can cause multiple interrupts to be reported if software clears the error interrupt for the first fragment while other fragments are being executed. The address log register will always log the address for the fragment which caused the last interrupt. The valid address range can be programmed using the DDRSS\_V2A\_CTL\_REG[9-5] SDRAM\_IDX and DDRSS\_V2A\_CTL\_REG[4-0] REGION\_IDX fields.

Table 9-3 summarizes the scenarios for determining valid address range and interrupt generation.

**Table 9-3. REGION\_IDX and SDRAM\_IDX Scenarios**

| Condition              | Description                                                                                                                                                                                                                                                             |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REGION_IDX = SDRAM_IDX | DDR region size is equal to the connected SDRAM size. It is the SoC responsibility to ensure that the addresses received by the DDR subsystem do not fall outside the region size. No address error is generated if the address received falls outside the region size. |
| REGION_IDX < SDRAM_IDX | DDR region size is less than the connected SDRAM size. It is SoC responsibility to ensure that the addresses received by the DDR subsystem do not fall outside the region size. No address error is generated if the address received falls outside the region size.    |
| REGION_IDX > SDRAM_IDX | DDR region size is greater than the connected SDRAM size. Address error is generated if the address received falls outside the connected SDRAM size.                                                                                                                    |

A write access outside the programmed range is discarded. A write error associated status is sent back to the VBUSM interface.

A read access outside the programmed range is executed on the SDRAM interface as a normal read, but data will contain all zeroes before forwarding it to the VBUSM interface. A read error associated status is sent back to the VBUSM interface along with the read data containing all zeroes.

When inline ECC is enabled, the available SDRAM size is reduced by 1/9th of the size programmed in the SDRAM\_IDX field. Therefore, the bridge reports an error if an access falls outside the reduced SDRAM size when inline ECC is enabled. The reduced SDRAM size limit applies to all accesses, both to the protected and non-protected ECC regions.

#### 9.1.3.5 AXI Bus Timeout

The VBUSM2AXI bridge has a timeout counter that expires when no AXI transaction can be sent to the DDR controller or no AXI response is received from the controller for a programmed time interval. The counter only counts when there are pending commands in the bridge and the AXI bus is idle. Therefore, the bridge will not time out during low-power modes. The time interval can be programmed by writing to the DDRSS\_V2A\_BUS\_TO[23-0] BUS\_TIMER field.

Upon the expiry of the counter, the bridge terminates all pending commands in its internal FIFOs, returns error responses, sets the DDRSS\_V2A\_INT\_RAW\_REG[2] TOERR bit and triggers the DDR0\_DDRSS\_V2A\_OTHER\_ERR\_LVL\_0 interrupt.

After a timeout occurs, the bridge terminates any new commands received and returns error response. Writing a value of 0x0 to the DDRSS\_V2A\_BUS\_TO[23-0] BUS\_TIMER field exits the timeout mode. The other method to exit the timeout mode is to reset the DDRSS0, thus resetting the VBUSM2ZXi bridge, the DDR controller, and the DDR PHY.

#### 9.1.3.6 DDRSS Interrupts

The VBUSM2AXI bridge sets to 0x1 the DDRSS\_V2A\_INT\_RAW\_REG[1] AERR bit, if the VBUSM address for an access that falls outside the DDR space programmed in the DDRSS\_V2A\_CTL\_REG register.

The VBUSM2AXI bridge sets to 0x1 the DDRSS\_V2A\_INT\_RAW\_REG[2] TOERR bit, if it detects a hang on its interface to the DDR controller.

The VBUSM2AXI bridge sets to 0x1 the DDRSS\_V2A\_INT\_RAW\_REG[3] ECC1BERR bit, if the threshold for 1-bit ECC errors is met.

The VBUSM2AXI bridge sets to 0x1 the DDRSS\_V2A\_INT\_RAW\_REG[4] ECC2BERR bit, in case of 2-bit errors for a read access performed within the SDRAM address range protected by ECC.

The DDRSS0 asserts particular interrupt line only if the interrupts are enabled by writing 0x1 to the corresponding bit in the DDRSS\_V2A\_INT\_SET\_REG register. The interrupts can be disabled by writing 0x1 to the corresponding bit in the DDRSS\_V2A\_INT\_CLR\_REG register.

When interrupts are enabled, the corresponding bits in the DDRSS\_V2A\_INT\_STAT\_REG register are also set if an interrupt condition occurs. The interrupts can be cleared once serviced by writing 0x1 to the corresponding bit in the DDRSS\_V2A\_INT\_STAT\_REG register as well as writing to the DDRSS\_V2A\_EOI\_REG register.

The subsystem will send an interrupt pulse, if there are any bits set in the Interrupt Status register (DDRSS\_V2A\_INT\_STAT\_REG) when the End of Interrupt register (DDRSS\_V2A\_EOI\_REG) is written.

**VBUSM2AXI Bridge Events** shows the events that are generated by the VBUSM2AXI bridge.

**Table 9-4. VBUSM2AXI Bridge Events**

| Event Flag                                                              | Event Mask                                                                   | Description                                                                                                                                                     |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DDRSS_V2A_INT_RAW_REG[4] ECC2BERR<br>DDRSS_V2A_INT_STAT_REG[4] ECC2BERR | DDRSS_V2A_INT_SET_REG[4] ECC2BERR_EN<br>DDRSS_V2A_INT_CLR_REG[4] ECC2BERR_EN | Generated in case of 2-bit errors for a read access within the ECC protected SDRAM address range. For more information, see <a href="#">Section 9.1.3.3.3</a> . |
| DDRSS_V2A_INT_RAW_REG[3] ECC1BERR<br>DDRSS_V2A_INT_STAT_REG[3] ECC1BERR | DDRSS_V2A_INT_SET_REG[3] ECC1BERR_EN<br>DDRSS_V2A_INT_CLR_REG[3] ECC1BERR_EN | Generated in case of meeting the threshold for 1-bit ECC errors. For more information, see <a href="#">Section 9.1.3.3.3</a> .                                  |
| DDRSS_V2A_INT_RAW_REG[2] TOERR<br>DDRSS_V2A_INT_STAT_REG[2] TOERR       | DDRSS_V2A_INT_SET_REG[2] TOERR_EN<br>DDRSS_V2A_INT_CLR_REG[2] TOERR_EN       | Generated in case of a hang of the interface between the bridge and the DDR controller. For more information, see <a href="#">Section 9.1.3.5</a> .             |
| DDRSS_V2A_INT_RAW_REG[1] AERR<br>DDRSS_V2A_INT_STAT_REG[1] AERR         | DDRSS_V2A_INT_SET_REG[1] AERR_EN<br>DDRSS_V2A_INT_CLR_REG[1] AERR_EN         | Generated if the VBUSM address for an access falls outside the programmed range. For more information, see <a href="#">Section 9.1.3.4</a> .                    |

#### 9.1.3.7 DDRSS Memory Regions

**Table 9-5** shows all memory regions associated with the DDRSS0.

**Table 9-5. DDRSS0 Memory Regions**

| Region                               | Start Address | End Address | Region Size |
|--------------------------------------|---------------|-------------|-------------|
| DDRSS0 wrapper logic registers       | 0x00F300000   | 0x00F3001FF | 512 B       |
| DDR controller registers             | 0x00F308000   | 0x00F309FFF | 8 KB        |
| DDR PHY independent module registers | 0x00F30A000   | 0x00F30BFFF | 8 KB        |
| DDR PHY registers                    | 0x00F30C000   | 0x00F30FFFF | 16 KB       |
| External SDRAM data space            | 0x0800000000  | 0xFFFFFFFF  | 2 GB        |
|                                      | 0x8800000000  | 0x9FFFFFFF  | 6 GB        |

#### 9.1.3.8 DDRSS Dynamic Frequency Change Interface

This interface is used for handshaking between DDRSS0 and CTRL\_MMR0 to dynamically change DDR clock frequency to support LPDDR4 Frequency Set Point (FSP). The frequency change can be initiated either by a SoC processor or by the DDRSS0.

The associated CTRL\_MMR0 registers for processor initiated frequency change are:

- **CTRLMMR\_CHNG\_DDR4\_FSP\_REQ**
- **CTRLMMR\_CHNG\_DDR4\_FSP\_ACK**

The associated CTRL\_MMR0 registers for DDRSS0 initiated frequency change are:

- **CTRLMMR\_DDR4\_FSP\_CLKCHNG\_REQ**
- **CTRLMMR\_DDR4\_FSP\_CLKCHNG\_ACK**

The sequence for an SoC processor initiated frequency change is as follows:

1. The processor writes the desired frequency to the **CTRLMMR\_CHNG\_DDR4\_FSP\_REQ[1-0]** **REQ\_TYPE** field.

2. The processor sets to 0x1 the CTRLMMR\_CHNG\_DDR4\_FSP\_REQ[8] REQ bit to initiate frequency change.
3. The processor programs PLL12 according to the CTRLMMR\_CHNG\_DDR4\_FSP\_REQ[1-0] REQ\_TYPE value.
4. The processor polls the CTRLMMR\_CHNG\_DDR4\_FSP\_ACK[7] ACK and CTRLMMR\_CHNG\_DDR4\_FSP\_ACK[0] ERROR bits to check if the frequency change has been completed successfully.

The sequence for DDRSS0 initiated frequency change is as follows:

1. DDRSS0 requests frequency change by asserting the CTRLMMR\_DDR4\_FSP\_CLKCHNG\_REQ[7] REQ bit and the CTRLMMR\_DDR4\_FSP\_CLKCHNG\_REQ[1-0] REQ\_TYPE field. The REQ bit is also connected to the DDR0\_DDRSS\_PLL\_FREQ\_CHANGE\_REQ\_0 interrupt.
2. Software reads the CTRLMMR\_DDR4\_FSP\_CLKCHNG\_REQ[1-0] REQ\_TYPE value and programs PLL12 accordingly.
3. After the DDRSS0\_FCLK has been changed software should set to 0x1 the CTRLMMR\_DDR4\_FSP\_CLKCHNG\_ACK[0] ACK bit.

### 9.1.3.9 DDR Controller Functional Description

Figure 9-3 shows the DDR controller blocks along with the DDR PHY and VBUSM2AXI bridge.



**Figure 9-3. DDR Controller Functional Blocks**

#### 9.1.3.9.1 DDR PHY Interface (DFI)

The DDR controller and DDR PHY are connected via DDR PHY Interface (DFI) which is used for transferring control information and data between the PHY and the controller. For more information about DFI, see <http://www.ddr-phy.org/>.

#### **9.1.3.9.2 Command Queue**

The DDR controller contains a command queue which uses a placement algorithm to determine the order of commands to be placed into the command queue. The placement logic follows many rules to determine where new commands should be inserted into the queue, relative to the contents of the command queue at a time. Placement is determined by considering address collisions, source collisions, data collisions, command types and priorities. The placement logic also attempts to maximize efficiency of the DDR controller through command grouping and bank splitting.

#### **9.1.3.9.2.1 Placement Logic**

The placement logic is a 2-stage queue which determines the order of commands that run in the DDR controller. The placement logic follows rules for determining placement of new commands into the queue, relative to the contents of the command queue at that time. Placement is determined by considering coherency, address collisions, source collisions, data collisions, user assigned priority, latency, age, and command type to offer low latency for critical controllers while optimizing bandwidth for all controllers. A second reordering stage allows ready-to-run commands to start even if the head-of-queue command is not yet ready to run. In addition, the queue can be disabled completely, resulting in an in-line queue that services requests in the order that they arrive.

The DDR controller also has a full look-ahead facility that reduces the effect of page misses by pre-conditioning rows for upcoming requests by using “spare” cycles in preceding transactions.

#### **9.1.3.9.2.2 Command Selection Logic**

After a command is in the command queue, command selection logic determines the method of pulling commands from the queue for running. On each clock cycle, the selection logic scans the entries of the command queue for determining the command to run. Commands for running are based on bank readiness, availability of at least 1 burst of data (writes), availability of storage for at least 1 burst of data (reads), bus turnaround timing, and conflicts. Similar to the placement rules, a command does not run before a command that was placed ahead of it in the command queue if it conflicts with address, source ID, or bank commands. Lower priority commands can run ahead of higher priority commands if the higher priority commands are not ready to run, as long as they do not conflict with commands that are ahead in the command queue.

#### **9.1.3.9.3 Transaction Processing**

The transaction command processing logic is used to process the commands in the command queue. The logic organizes the commands to the memories in such a way that data throughput is maximized. Bank opening and closing cycles are used for data transfers. The logic reviews the entire command queue for look-ahead of which banks have to be accessed in the future and ensures that the programmed memory timing conditions are met. This flexibility allows the controller to be tuned to extract the maximum performance out of memories. During processing, the controller examines the commands and issues the appropriate set of signals to the memory.

#### **9.1.3.9.4 Paging Policy**

The DDR controller offers a flexible paging policy that allows open page operation, closed page operation, or an auto-precharge-per-command option that allows both modes simultaneously. Auto-precharge-per-command allows marking a particular controller or transaction (for example, a CPU cache) as a closed-page transaction. This type of transaction reduces power and improves latency for the next transaction to a different row in the same SDRAM bank. Other transactions can be marked as open page transactions. This type of transaction reduces power and improves latency and bandwidth to the next transaction to the same row in the same SDRAM bank.

#### **9.1.3.9.5 DDR Controller Initialization**

Once the power to the SDRAM and SoC is stable, the DDR controller must be initialized. It then automatically initializes the external memory. Please refer to the Processor SDK for the software drivers to initialize the DDR registers and memory

---

**Note**

To facilitate the programming of these registers, refer to the device-specific DDR Subsystem Register Configuration Tool available at <http://dev.ti.com/sysconfig>.

---

## 9.2 Region-based Address Translation (RAT) Module

This section describes the RAT functionality.

### 9.2.1 RAT Functional Description

#### 9.2.1.1 RAT Availability

lists the device modules and subsystems which have RAT module.

#### 9.2.1.2 RAT Operation

The RAT module performs a region based address translation. It translates a 32-bit input address into a 48-bit output address. Any input transaction that starts inside of a programmed region will have its address translated, if the region is enabled. Any disabled region is ignored from the translation lookup.

RAT has 16 regions, with each region having dedicated registers that define its attributes:

- Base address of the region, via the RAT\_BASE\_k register.
- Size of the region, via the RAT\_CTRL\_k register.
- Translated base address (48-bit). It is defined by 32-bit lower address via the RAT\_TRANS\_L\_k register, and 16-bit upper address via the RAT\_TRANS\_U\_k register.

The input addresses are compared against all the enabled regions in parallel. The region size defines how many of the lowest address bits are included in the region space, starting from a 1B space to a 4GB space. Then the upper bits not part of the region are used for the lookup and comparison, matching those bits of the input addresses against the region base address. The region matches when it is enabled and the compare matches. The first region that matches has the output address set with the region translated base address upper bits. The lower bits that are part of the region size are copied from the input address to the output address. If there are no region matches then the input address is copied to the output address entirely.

RAT does not automatically correct transactions that cross region boundaries, that is, start inside of a region and end outside of it, or start outside of a region and end inside of it. If a boundary crossing transaction is detected, then RAT annuls the transaction as illegal, generates an interrupt and logs an error, as explained in *RAT Error Logging*.

---

#### Note

The region base address and translated base address must be aligned to the defined region size. For example, if the defined region size is 64KB, then the two addresses must be 64KB aligned. This is software responsibility as RAT does not perform such alignment check. Regions that are not aligned have unpredictable results.

Moreover, multiple region definitions must not overlap in their covered address space. RAT does not check for this, so it is software responsibility to take care of it. Overlapping regions may lead to unpredictable results.

---

#### 9.2.1.3 RAT Error Logging

The error log consists of a series of registers that capture the details of the transaction, including the input address that caused the error. These registers are the following:

- RAT\_EXCEPTION\_LOGGING\_HEADER0 and RAT\_EXCEPTION\_LOGGING\_HEADER1
- RAT\_EXCEPTION\_LOGGING\_DATA0 through RAT\_EXCEPTION\_LOGGING\_DATA3

The RAT module can capture one error before it is cleared by software. The error logging is enabled by default, but can be disabled via the RAT\_EXCEPTION\_LOGGING\_CONTROL[0] DISABLE\_F bit. Upon error logging an interrupt is also generated. To clear the log, software must either read the final error logging register, or manually clear the RAT\_EXCEPTION\_PEND\_CLEAR[0] PEND\_CLR bit by setting it to 0x1. This will clear the error status, and not the actual log registers, but it does allow the next error to be captured into the log registers. If the status is not cleared and additional errors are detected, they are not logged.

After an error occurs and is cleared (whether by reading the final error logging register or by clearing the status bit), the RAT\_EOI\_REG register must be written to guarantee the next interrupt pulse will be produced.

shows the RAT source ID mapping which is associated with the RAT\_EXCEPTION\_LOGGING\_HEADER0[23-8] SRC\_ID field.

## Chapter 10 **Interrupts**

---



This chapter describes the details related to device interrupts.

|                                         |     |
|-----------------------------------------|-----|
| <b>10.1 Interrupt Architecture.....</b> | 820 |
|-----------------------------------------|-----|

## 10.1 Interrupt Architecture

AM62 Interrupt Architecture includes information on how to utilize various interrupts and events in the system and relationships between interrupts and events.

An interrupt is defined as a physical signal which can be routed to the interrupt controller of various processors, which can cause the Interrupt Service Routing (ISR). This physical signal can be either a pulse or level and the polarity can be either negative or positive. And an interrupt is correspondent to an individual wire.

An event is defined as information transported by the event bus or PSI\_L bus. Events are coded using an event index. The same event bus or PSI\_L bus is used to transport multiple events. An event can also be routed and multiplexed to different locations. Events can't trigger a processor's ISR directly. It has to go through the Interrupt Aggregator (IA) to convert the event into an interrupt line. For more information, see [Interrupt Aggregator \(INTAGGR\)](#), [Interrupt Aggregator \(INTAGGR\)](#)

The DMA transfer using BCDMA and PktDMA in AM62 can only be triggered using an event. The SoC level interrupt could be used as a BCDMA trigger using L2G logic. Interrupts in the SoC level can't be used to trigger a pktDMA transfer.

Each type of the processor has its unique interrupt controller. All A53 cores share a single Generic Interrupt Controller (GIC). Each M4F micro controller has its own dedicated interrupt controller, called Nested Vector Interrupt Controller (NVIC). Each R5 micro controller has its own dedicated interrupt controller, called Vectored Interrupt Manager (VIM). ICSSM uses an embedded local interrupt controller called INTC to manage its interrupts, refer to [Table 10-1](#). Please refer to the following sections for the detailed usage of [GICSS](#), [VIM](#), [INTC](#) and [MCUSS NVIC](#).

**Table 10-1. Interrupt Controllers**

| Processors            | Interrupt Controllers                                                   |
|-----------------------|-------------------------------------------------------------------------|
| A53 core 0            | All four A53 cores share the same GICSS                                 |
| A53 core 1            |                                                                         |
| A53 core 2            |                                                                         |
| A53 core 3            |                                                                         |
| R5 core inside R5FSS  | Dedicated VIM inside R5FSS                                              |
| M4F core inside MCUSS | Dedicated NVIC inside MCUSS                                             |
| TIFS                  | Dedicated NVIC for TIFS                                                 |
| HSM                   | Dedicated NVIC for HSM. HSM receives the same sets of interrupt as TIFS |
| ICSSM                 | INTC embedded inside ICSSM                                              |

AM62 also contains multiple SoC level interrupt routers. The main function of those SoC level interrupt routers is to provide flexibility to select interrupt sources from a large group of interrupt sources. There are multiple places which utilize this feature, such as GPIO interrupts and some time synchronization related interrupts.

AM62 contains two ESM modules. ESM is used to consolidate/monitor the error events in the device. In this document, ESM may also be referred to as ESM0.

AM62 also has some chip level glue logic to convert some miscellaneous signals used as interrupt sources. Those miscellaneous signals are normally self-clear signals and do not need to clear after the Interrupt Service Routing (ISP) like the normal interrupts generated by the peripherals.

[Figure 10-1](#) shows the high level interrupt architecture in AM62.



**Figure 10-1. AM62 Interrupt Architecture**

### 10.1.1 ESM Connectivity

AM62 contains two ESM modules to consolidate the error interrupts in SoC. One is in the Main domain and one is in the MCU domain. [Figure 10-2](#) shows how error interrupts are connected to these two ESM.



**Figure 10-2. ESM Connection**

The error interrupts from the Wkup\_DM domain are routed to both Main ESM and MCU ESM. Users can configure ESM to cause ESM generating interrupt output from the interrupt inputs. The interrupt outputs of the Main ESM are routed as interrupt inputs to the MCU ESM. The interrupt outputs of the MCU ESM are routed as the interrupt inputs to the Main ESM. This means that user can configure the device to use one ESM to monitor the error interrupts for the whole device. AM62 supports the following three use cases.

#### 10.1.1.1 Using MCU ESM to Monitor All Error Events in SoC

In this use case, the Main ESM is used to consolidate all the error interrupts in the Main domain and Wkup\_DM domain as main ESM's interrupt outputs, which are routed as interrupt inputs to the MCU ESM.



**Figure 10-3. Using MCU ESM for All Error Interrupts in SoC**

In this use case, the Main ESM should be configured to disable the interrupt inputs coming from the MCU ESM interrupts. If those interrupt inputs are not disabled by the Main ESM, the dependence loop will be formed as following:

1. Error interrupts in the Main domain are routed to Main ESM triggers interrupt outputs generated by the Main ESM
2. The error interrupt outputs from the Main ESM are routed to the MCU ESM as interrupt inputs
3. Those error interrupt inputs triggers the MCU ESM generating its error interrupts outputs
4. Those interrupt outputs from the MCU ESM are routed back to the Main ESM as interrupt inputs. If those interrupts are not disabled at the Main ESM, it will trigger Main ESM generating interrupt outputs in the Main ESM again. Going back to step 1 again.

In addition, since Wkup\_DM error events are already routed to the Main ESM, so the input events in the MCU ESM connecting to those error events from the Wkup\_DM domain shall be disabled, otherwise those events can trigger the interrupt in both the Main ESM as well as the MCU ESM

#### 10.1.1.2 Using MAIN ESM to Monitor All Error Interrupts in SoC

In this configuration, the MCU ESM is used to consolidate all the error interrupts from the MCU domain and the Wkup\_safe domain as interrupt outputs, and those interrupt outputs from the MCU ESM are routed as interrupt inputs to the Main ESM. In order to avoid the interrupt dependence loop, the MCU ESM shall disable the interrupt inputs from ESM0.



**Figure 10-4. Using MAIN ESM to Monitor All Error Interrupts in SoC**

#### 10.1.1.3 ESM Configuration During Deep Sleep Mode

When device is in deep sleep mode, only the components in the Wkup\_DM domain and the Wkup\_safe are available. The Main domain is powered off, so the Main ESM is no longer available. Since MCU ESM is located in the Wkup\_safe domain, the MCU ESM is monitoring all of the error events during the deep sleep mode and informs the device manager.



Figure 10-5. Deep Sleep Use Case

#### 10.1.1.4 ESM0\_INTERRUPT\_MAP

Table 10-2. ESM0\_INTERRUPT\_MAP Memory Map

| Interrupt Input Line     | Interrupt ID | Source Interrupt                                                |
|--------------------------|--------------|-----------------------------------------------------------------|
| ESM0_ESM_LVL_EVENT_IN_0  | 0            | CSI_RX_IF0_CSI_ERR_IRQ_0                                        |
| ESM0_ESM_LVL_EVENT_IN_1  | 1            | ECC_AGGR0_UNCORR_LEVEL_0                                        |
| ESM0_ESM_LVL_EVENT_IN_2  | 2            | ECC_AGGR0_CORR_LEVEL_0                                          |
| ESM0_ESM_LVL_EVENT_IN_3  | 3            | CPSW0_ECC_SEC_PEND_0                                            |
| ESM0_ESM_LVL_EVENT_IN_4  | 4            | SMS0_RAT_0_EXP_INTR_0                                           |
| ESM0_ESM_LVL_EVENT_IN_6  | 6            | DDR16SS0_DDRSS_DRAM_ECC_CORR_ERR_LVL_0                          |
| ESM0_ESM_LVL_EVENT_IN_7  | 7            | PLLFRACF_SSMOD17_LOCKLOSS_IPCFG_0                               |
| ESM0_ESM_LVL_EVENT_IN_8  | 8            | PLLFRACF_SSMOD16_LOCKLOSS_IPCFG_0                               |
| ESM0_ESM_LVL_EVENT_IN_9  | 9            | DMASS0_ECC_AGGR_0_ECC_CORRECTED_ERR_LEVEL_0                     |
| ESM0_ESM_LVL_EVENT_IN_10 | 10           | DMASS0_ECC_AGGR_0_ECC_UNCORRECTED_ERR_LEVEL_0                   |
| ESM0_ESM_LVL_EVENT_IN_11 | 11           | FSS0_OSPI_0_OSPI_ECC_CORR_LVL_INTR_0                            |
| ESM0_ESM_LVL_EVENT_IN_12 | 12           | GICSS0_ECC_AGGR_CORR_LEVEL_0                                    |
| ESM0_ESM_LVL_EVENT_IN_13 | 13           | ICSSM0_PR1_ECC_SEC_ERR_PEND_0                                   |
| ESM0_ESM_LVL_EVENT_IN_14 | 14           | SMS0_RAT_1_EXP_INTR_0                                           |
| ESM0_ESM_LVL_EVENT_IN_15 | 15           | PDMA0_ECC_SEC_PEND_0                                            |
| ESM0_ESM_LVL_EVENT_IN_16 | 16           | MCAN0_MCANSS_MSGMEM_WRAP_ECC_AGGR_MCANSS_ECC_C<br>ORR_LVL_INT_0 |
| ESM0_ESM_LVL_EVENT_IN_18 | 18           | PSRAMECC_16K0_ECC_CORR_LEVEL_0                                  |
| ESM0_ESM_LVL_EVENT_IN_20 | 20           | WKUP_ECC_AGGR0_CORR_LEVEL_0                                     |
| ESM0_ESM_LVL_EVENT_IN_21 | 21           | WKUP_ECC_AGGR0_UNCORR_LEVEL_0                                   |
| ESM0_ESM_LVL_EVENT_IN_22 | 22           | PSC0_ECC_AGGR_0_FW_CH_BR_ECC_AGGR_CORR_LEVEL_0                  |

**Table 10-2. ESM0\_INTERRUPT\_MAP Memory Map (continued)**

| Interrupt Input Line     | Interrupt ID | Source Interrupt                                                   |
|--------------------------|--------------|--------------------------------------------------------------------|
| ESM0_ESM_LVL_EVENT_IN_23 | 23           | PSC0_ECC_AGGR_0_FW_CH_BR_ECC_AGGR_UNCORR_LEVEL_0                   |
| ESM0_ESM_LVL_EVENT_IN_24 | 24           | COMPUTE_CLUSTER0_ECC_ECCAGGR0_CORRECTED_ERR_LEVEL_0                |
| ESM0_ESM_LVL_EVENT_IN_25 | 25           | COMPUTE_CLUSTER0_ECC_ECCAGGR1_CORRECTED_ERR_LEVEL_0                |
| ESM0_ESM_LVL_EVENT_IN_26 | 26           | COMPUTE_CLUSTER0_ECC_ECCAGGR_COREPAC_CORRECTED_ERR_LEVEL_0         |
| ESM0_ESM_LVL_EVENT_IN_28 | 28           | PDMA1_ECC_SEC_PEND_0                                               |
| ESM0_ESM_LVL_EVENT_IN_29 | 29           | PSRAMECC0_ECC_CORR_LEVEL_0                                         |
| ESM0_ESM_LVL_EVENT_IN_30 | 30           | R5FSS0_CORE0_ECC_CORRECTED_LEVEL_0                                 |
| ESM0_ESM_LVL_EVENT_IN_32 | 32           | USB0_HOST_SYSTEM_ERROR_0                                           |
| ESM0_ESM_LVL_EVENT_IN_33 | 33           | USB1_HOST_SYSTEM_ERROR_0                                           |
| ESM0_ESM_LVL_EVENT_IN_34 | 34           | MMCSD2_EMMCSD4SS_ECC_AGGR_RXMEM_EMMCSDSS_RXMEMORY_UNCORR_ERR_LVL_0 |
| ESM0_ESM_LVL_EVENT_IN_35 | 35           | USB0_A_ECC_AGGR_CORRECTED_ERR_LEVEL_0                              |
| ESM0_ESM_LVL_EVENT_IN_36 | 36           | MMCSD2_EMMCSD4SS_ECC_AGGR_RXMEM_EMMCSDSS_RXMEMORY_UNCORR_ERR_LVL_0 |
| ESM0_ESM_LVL_EVENT_IN_37 | 37           | WKUP_ESM0_ESM_INT_CFG_LVL_0                                        |
| ESM0_ESM_LVL_EVENT_IN_38 | 38           | WKUP_ESM0_ESM_INT_HI_LVL_0                                         |
| ESM0_ESM_LVL_EVENT_IN_39 | 39           | WKUP_ESM0_ESM_INT_LOW_LVL_0                                        |
| ESM0_ESM_LVL_EVENT_IN_40 | 40           | R5FSS0_COMMON0_ECC_DE_TO_ESM_0_0                                   |
| ESM0_ESM_LVL_EVENT_IN_42 | 42           | R5FSS0_COMMON0_ECC_SE_TO_ESM_0_0                                   |
| ESM0_ESM_LVL_EVENT_IN_44 | 44           | COMPUTE_CLUSTER0_DFT_PBIST_SAFETY_ERROR_0                          |
| ESM0_ESM_LVL_EVENT_IN_45 | 45           | COMPUTE_CLUSTER0_ECC_ECCAGGR2_CORRECTED_ERR_LEVEL_0                |
| ESM0_ESM_LVL_EVENT_IN_46 | 46           | COMPUTE_CLUSTER0_ECC_ECCAGGR2_UNCORRECTED_ERR_LEVEL_0              |
| ESM0_ESM_LVL_EVENT_IN_47 | 47           | COMPUTE_CLUSTER0_ECC_ECCAGGR3_CORRECTED_ERR_LEVEL_0                |
| ESM0_ESM_LVL_EVENT_IN_48 | 48           | COMPUTE_CLUSTER0_ECC_ECCAGGR3_UNCORRECTED_ERR_LEVEL_0              |
| ESM0_ESM_LVL_EVENT_IN_49 | 49           | MMCSD2_EMMCSD4SS_ECC_AGGR_TXMEM_EMMCSDSS_TXMEMORY_UNCORR_ERR_LVL_0 |
| ESM0_ESM_LVL_EVENT_IN_50 | 50           | SMS0_TIMER_0_INTR_PEND_0                                           |
| ESM0_ESM_LVL_EVENT_IN_51 | 51           | SMS0_TIMER_1_INTR_PEND_0                                           |
| ESM0_ESM_LVL_EVENT_IN_52 | 52           | SMS0_TIMER_2_INTR_PEND_0                                           |
| ESM0_ESM_LVL_EVENT_IN_53 | 53           | SMS0_TIMER_3_INTR_PEND_0                                           |
| ESM0_ESM_LVL_EVENT_IN_54 | 54           | MMCSD0_EMMCSDSS_RXMEM_CORR_ERR_LVL_0                               |
| ESM0_ESM_LVL_EVENT_IN_55 | 55           | MMCSD0_EMMCSDSS_RXMEM_UNCORR_ERR_LVL_0                             |
| ESM0_ESM_LVL_EVENT_IN_56 | 56           | MMCSD0_EMMCSDSS_TXMEM_CORR_ERR_LVL_0                               |
| ESM0_ESM_LVL_EVENT_IN_57 | 57           | MMCSD0_EMMCSDSS_TXMEM_UNCORR_ERR_LVL_0                             |
| ESM0_ESM_LVL_EVENT_IN_58 | 58           | MMCSD1_EMMCSD4SS_ECC_AGGR_RXMEM_EMMCSDSS_RXMEMORY_UNCORR_ERR_LVL_0 |
| ESM0_ESM_LVL_EVENT_IN_59 | 59           | MMCSD1_EMMCSD4SS_ECC_AGGR_RXMEM_EMMCSDSS_RXMEMORY_UNCORR_ERR_LVL_0 |
| ESM0_ESM_LVL_EVENT_IN_60 | 60           | MMCSD1_EMMCSD4SS_ECC_AGGR_TXMEM_EMMCSDSS_TXMEMORY_UNCORR_ERR_LVL_0 |
| ESM0_ESM_LVL_EVENT_IN_61 | 61           | MMCSD1_EMMCSD4SS_ECC_AGGR_TXMEM_EMMCSDSS_TXMEMORY_UNCORR_ERR_LVL_0 |

Table 10-2. ESM0\_INTERRUPT\_MAP Memory Map (continued)

| Interrupt Input Line      | Interrupt ID | Source Interrupt                                                |
|---------------------------|--------------|-----------------------------------------------------------------|
| ESM0_ESM_LVL_EVENT_IN_65  | 65           | MMCSD2_EMMCSD4SS_ECC_AGGR_TXMEM_EMMCSDSS_TXMEM_UNCORR_ERR_LVL_0 |
| ESM0_ESM_LVL_EVENT_IN_66  | 66           | CSI_RX_IF0_CORR_LEVEL_0                                         |
| ESM0_ESM_LVL_EVENT_IN_67  | 67           | CPSW0_ECCDED_PEND_0                                             |
| ESM0_ESM_LVL_EVENT_IN_68  | 68           | ICSSM0_PR1_EDIO0_WD_TRIIG_0                                     |
| ESM0_ESM_LVL_EVENT_IN_69  | 69           | DDR16SS0_DDRSS_DRAM_ECC_UNCORR_ERR_LVL_0                        |
| ESM0_ESM_LVL_EVENT_IN_70  | 70           | CSI_RX_IF0_CSI_FATAL_0                                          |
| ESM0_ESM_LVL_EVENT_IN_71  | 71           | CSI_RX_IF0_CSI_NONFATAL_0                                       |
| ESM0_ESM_LVL_EVENT_IN_72  | 72           | CSI_RX_IF0_CSI_LEVEL_0                                          |
| ESM0_ESM_LVL_EVENT_IN_74  | 74           | FSS0_OSPI0_OSPI_ECC_UNCORR_LVL_INTR_0                           |
| ESM0_ESM_LVL_EVENT_IN_75  | 75           | GICSS0_ECC_AGGR_UNCORR_LEVEL_0                                  |
| ESM0_ESM_LVL_EVENT_IN_76  | 76           | ICSSM0_PR1_ECCDED_ERR_PEND_0                                    |
| ESM0_ESM_LVL_EVENT_IN_77  | 77           | CSI_RX_IF0_UNCORR_LEVEL_0                                       |
| ESM0_ESM_LVL_EVENT_IN_78  | 78           | MCAN0_MCANSS_MSGMEM_WRAP_ECC_AGGR_MCANSS_ECC_UNCORR_LVL_INT_0   |
| ESM0_ESM_LVL_EVENT_IN_79  | 79           | DCC6_INTR_ERR_LEVEL_0                                           |
| ESM0_ESM_LVL_EVENT_IN_80  | 80           | PSRAMECC_16K0_ECC_UNCORR_LEVEL_0                                |
| ESM0_ESM_LVL_EVENT_IN_81  | 81           | SMS0_RTI1_WDG_INTR_0                                            |
| ESM0_ESM_LVL_EVENT_IN_82  | 82           | SMS0_RTI1_WDG_INTR_1                                            |
| ESM0_ESM_LVL_EVENT_IN_83  | 83           | SMS0_RTI1_WDG_INTR_2                                            |
| ESM0_ESM_LVL_EVENT_IN_84  | 84           | SMS0_RTI1_WDG_INTR_3                                            |
| ESM0_ESM_LVL_EVENT_IN_85  | 85           | SMS0_RTI1_WDG_INTR_4                                            |
| ESM0_ESM_LVL_EVENT_IN_87  | 87           | SMS0_RTI0_WDG_INTR_0                                            |
| ESM0_ESM_LVL_EVENT_IN_88  | 88           | PDMA0_ECCDED_PEND_0                                             |
| ESM0_ESM_LVL_EVENT_IN_89  | 89           | PDMA1_ECCDED_PEND_0                                             |
| ESM0_ESM_LVL_EVENT_IN_90  | 90           | PSRAMECC0_ECC_UNCORR_LEVEL_0                                    |
| ESM0_ESM_LVL_EVENT_IN_91  | 91           | R5FSS0_CORE0_ECC_UNCORRECTED_LEVEL_0                            |
| ESM0_ESM_LVL_EVENT_IN_92  | 92           | SMS0_RTI0_WDG_INTR_1                                            |
| ESM0_ESM_LVL_EVENT_IN_93  | 93           | COMPUTE_CLUSTER0_ECC_ECCAGGR1_UNCORRECTED_ERR_LEVEL_0           |
| ESM0_ESM_LVL_EVENT_IN_94  | 94           | COMPUTE_CLUSTER0_ECC_ECCAGGR0_UNCORRECTED_ERR_LEVEL_0           |
| ESM0_ESM_LVL_EVENT_IN_95  | 95           | COMPUTE_CLUSTER0_ECC_ECCAGGR_COREPAC_UNCORRECTED_ERR_LEVEL_0    |
| ESM0_ESM_LVL_EVENT_IN_96  | 96           | SMS0_RTI0_WDG_INTR_2                                            |
| ESM0_ESM_LVL_EVENT_IN_97  | 97           | SMS0_RTI0_WDG_INTR_3                                            |
| ESM0_ESM_LVL_EVENT_IN_98  | 98           | DFTSS0_DFT_SAFETY_123_0                                         |
| ESM0_ESM_LVL_EVENT_IN_99  | 99           | DFTSS0_DFT_SAFETY_MULTI_0                                       |
| ESM0_ESM_LVL_EVENT_IN_100 | 100          | DFTSS0_DFT_SAFETY_ONE_0                                         |
| ESM0_ESM_LVL_EVENT_IN_101 | 101          | MCU_MCU0_VDD_CORE_GLDTC_STAT_THRESH_HI_FLAG_IPCFG_0             |
| ESM0_ESM_LVL_EVENT_IN_102 | 102          | MCU_MCU0_VDD_CORE_GLDTC_STAT_THRESH_LOW_FLAG_IPCFG_0            |
| ESM0_ESM_LVL_EVENT_IN_103 | 103          | SMS0_RTI0_WDG_INTR_4                                            |
| ESM0_ESM_LVL_EVENT_IN_110 | 110          | DDR16SS0_DDRSS_V2A_OTHER_ERR_LVL_0                              |
| ESM0_ESM_LVL_EVENT_IN_111 | 111          | USB0_A_ECC_AGGR_UNCORRECTED_ERR_LEVEL_0                         |
| ESM0_ESM_LVL_EVENT_IN_112 | 112          | DCC0_INTR_ERR_LEVEL_0                                           |

**Table 10-2. ESM0\_INTERRUPT\_MAP Memory Map (continued)**

| Interrupt Input Line       | Interrupt ID | Source Interrupt                              |
|----------------------------|--------------|-----------------------------------------------|
| ESM0_ESM_LVL_EVENT_IN_113  | 113          | DCC1_INTR_ERR_LEVEL_0                         |
| ESM0_ESM_LVL_EVENT_IN_114  | 114          | DCC2_INTR_ERR_LEVEL_0                         |
| ESM0_ESM_LVL_EVENT_IN_115  | 115          | DCC3_INTR_ERR_LEVEL_0                         |
| ESM0_ESM_LVL_EVENT_IN_116  | 116          | DCC4_INTR_ERR_LEVEL_0                         |
| ESM0_ESM_LVL_EVENT_IN_117  | 117          | DCC5_INTR_ERR_LEVEL_0                         |
| ESM0_ESM_LVL_EVENT_IN_118  | 118          | SA3_SS0_DMSS_ECCAGGR_0_DMSS_ECC_DED_PEND_0    |
| ESM0_ESM_LVL_EVENT_IN_119  | 119          | SA3_SS0_DMSS_ECCAGGR_0_DMSS_ECC_SEC_PEND_0    |
| ESM0_ESM_LVL_EVENT_IN_120  | 120          | SA3_SS0_SA_UL_0_SA_UL_ECC_CORR_LEVEL_0        |
| ESM0_ESM_LVL_EVENT_IN_121  | 121          | SA3_SS0_SA_UL_0_SA_UL_ECC_UNCORR_LEVEL_0      |
| ESM0_ESM_LVL_EVENT_IN_124  | 124          | R5FSS0_CORE0_EXP_INTR_0                       |
| ESM0_ESM_LVL_EVENT_IN_128  | 128          | PLLFRACF_SSMOD0_LOCKLOSS_IPCFG_0              |
| ESM0_ESM_LVL_EVENT_IN_129  | 129          | PLLFRACF_SSMOD1_LOCKLOSS_IPCFG_0              |
| ESM0_ESM_LVL_EVENT_IN_130  | 130          | PLLFRACF_SSMOD2_LOCKLOSS_IPCFG_0              |
| ESM0_ESM_LVL_EVENT_IN_131  | 131          | PLLFRACF_SSMOD8_LOCKLOSS_IPCFG_0              |
| ESM0_ESM_LVL_EVENT_IN_132  | 132          | PLLFRACF_SSMOD12_LOCKLOSS_IPCFG_0             |
| ESM0_ESM_LVL_EVENT_IN_133  | 133          | PLLFRACF_SSMOD15_LOCKLOSS_IPCFG_0             |
| ESM0_ESM_LVL_EVENT_IN_134  | 134          | MCU_PLLFRACF_SSMOD0_LOCKLOSS_IPCFG_0          |
| ESM0_ESM_LVL_EVENT_IN_135  | 135          | HFOSC0_CLKLOSS_GLUE_REF_CLK_LOSS_DETECT_OUT_0 |
| ESM0_ESM_LVL_EVENT_IN_136  | 136          | WKUP_VTM0_COMMON_0_THERM_LVL_LT_TH0_INTR_0    |
| ESM0_ESM_LVL_EVENT_IN_137  | 137          | WKUP_VTM0_COMMON_0_THERM_LVL_GT_TH1_INTR_0    |
| ESM0_ESM_LVL_EVENT_IN_138  | 138          | WKUP_VTM0_COMMON_0_THERM_LVL_GT_TH2_INTR_0    |
| ESM0_ESM_LVL_EVENT_IN_139  | 139          | WKUP_VTM0_K3VTM_NC_ECCAGGR_CORR_LEVEL_0       |
| ESM0_ESM_LVL_EVENT_IN_140  | 140          | WKUP_VTM0_K3VTM_NC_ECCAGGR_UNCORR_LEVEL_0     |
| ESM0_ESM_LVL_EVENT_IN_141  | 141          | FSS0_FSAS_0_ECC_INTR_ERR_PEND_0               |
| ESM0_ESM_LVL_EVENT_IN_144  | 144          | COMPUTE_CLUSTER0_EXTERRIRQ_0                  |
| ESM0_ESM_LVL_EVENT_IN_145  | 145          | COMPUTE_CLUSTER0_INTERRIRQ_0                  |
| ESM0_ESM_LVL_EVENT_IN_146  | 146          | USB1_A_ECC_AGGR_CORRECTED_ERR_LEVEL_0         |
| ESM0_ESM_LVL_EVENT_IN_147  | 147          | USB1_A_ECC_AGGR_UNCORRECTED_ERR_LEVEL_0       |
| ESM0_ESM_LVL_EVENT_IN_150  | 150          | SMS0_ECC_AGGR_1_ECC_CORRECTED_LEVEL_0         |
| ESM0_ESM_LVL_EVENT_IN_151  | 151          | SMS0_ECC_AGGR_1_ECC_UNCORRECTED_LEVEL_0       |
| ESM0_ESM_LVL_EVENT_IN_153  | 153          | SMS0_ECC_AGGR_0_ECC_CORRECTED_LEVEL_0         |
| ESM0_ESM_LVL_EVENT_IN_154  | 154          | SMS0_ECC_AGGR_0_ECC_UNCORRECTED_LEVEL_0       |
| ESM0_ESM_LVL_EVENT_IN_156  | 156          | PBIST1_DFT_PBIST_SAFETY_ERROR_0               |
| ESM0_ESM_LVL_EVENT_IN_157  | 157          | PBIST0_DFT_PBIST_SAFETY_ERROR_0               |
| ESM0_ESM_LVL_EVENT_IN_158  | 158          | WKUP_PBIST0_DFT_PBIST_SAFETY_ERROR_0          |
| ESM0_ESM_PLS_EVENT0_IN_160 | 160          | RTI0_INTR_WWD_0                               |
| ESM0_ESM_PLS_EVENT1_IN_160 | 160          | RTI0_INTR_WWD_0                               |
| ESM0_ESM_PLS_EVENT2_IN_160 | 160          | RTI0_INTR_WWD_0                               |
| ESM0_ESM_PLS_EVENT0_IN_161 | 161          | RTI1_INTR_WWD_0                               |
| ESM0_ESM_PLS_EVENT1_IN_161 | 161          | RTI1_INTR_WWD_0                               |
| ESM0_ESM_PLS_EVENT2_IN_161 | 161          | RTI1_INTR_WWD_0                               |
| ESM0_ESM_PLS_EVENT0_IN_162 | 162          | RTI15_INTR_WWD_0                              |
| ESM0_ESM_PLS_EVENT1_IN_162 | 162          | RTI15_INTR_WWD_0                              |
| ESM0_ESM_PLS_EVENT2_IN_162 | 162          | RTI15_INTR_WWD_0                              |
| ESM0_ESM_PLS_EVENT0_IN_163 | 163          | WKUP_RTI0_INTR_WWD_0                          |

Table 10-2. ESM0\_INTERRUPT\_MAP Memory Map (continued)

| Interrupt Input Line       | Interrupt ID | Source Interrupt                 |
|----------------------------|--------------|----------------------------------|
| ESM0_ESM_PLS_EVENT1_IN_163 | 163          | WKUP_RTI0_INTR_WWD_0             |
| ESM0_ESM_PLS_EVENT2_IN_163 | 163          | WKUP_RTI0_INTR_WWD_0             |
| ESM0_ESM_PLS_EVENT0_IN_164 | 164          | PBIST0_DFT_PBIST_CPU_0           |
| ESM0_ESM_PLS_EVENT1_IN_164 | 164          | PBIST0_DFT_PBIST_CPU_0           |
| ESM0_ESM_PLS_EVENT2_IN_164 | 164          | PBIST0_DFT_PBIST_CPU_0           |
| ESM0_ESM_PLS_EVENT0_IN_165 | 165          | PBIST1_DFT_PBIST_CPU_0           |
| ESM0_ESM_PLS_EVENT1_IN_165 | 165          | PBIST1_DFT_PBIST_CPU_0           |
| ESM0_ESM_PLS_EVENT2_IN_165 | 165          | PBIST1_DFT_PBIST_CPU_0           |
| ESM0_ESM_PLS_EVENT0_IN_166 | 166          | GICSS0_AXIM_ERR_0                |
| ESM0_ESM_PLS_EVENT1_IN_166 | 166          | GICSS0_AXIM_ERR_0                |
| ESM0_ESM_PLS_EVENT2_IN_166 | 166          | GICSS0_AXIM_ERR_0                |
| ESM0_ESM_PLS_EVENT0_IN_167 | 167          | GICSS0_ECC_FATAL_0               |
| ESM0_ESM_PLS_EVENT1_IN_167 | 167          | GICSS0_ECC_FATAL_0               |
| ESM0_ESM_PLS_EVENT2_IN_167 | 167          | GICSS0_ECC_FATAL_0               |
| ESM0_ESM_PLS_EVENT0_IN_170 | 170          | WKUP_PBIST0_DFT_PBIST_CPU_0      |
| ESM0_ESM_PLS_EVENT1_IN_170 | 170          | WKUP_PBIST0_DFT_PBIST_CPU_0      |
| ESM0_ESM_PLS_EVENT2_IN_170 | 170          | WKUP_PBIST0_DFT_PBIST_CPU_0      |
| ESM0_ESM_PLS_EVENT0_IN_176 | 176          | COMPUTE_CLUSTER0_DFT_PBIST_CPU_0 |
| ESM0_ESM_PLS_EVENT1_IN_176 | 176          | COMPUTE_CLUSTER0_DFT_PBIST_CPU_0 |
| ESM0_ESM_PLS_EVENT2_IN_176 | 176          | COMPUTE_CLUSTER0_DFT_PBIST_CPU_0 |
| ESM0_ESM_PLS_EVENT0_IN_177 | 177          | RTI2_INTR_WWD_0                  |
| ESM0_ESM_PLS_EVENT1_IN_177 | 177          | RTI2_INTR_WWD_0                  |
| ESM0_ESM_PLS_EVENT2_IN_177 | 177          | RTI2_INTR_WWD_0                  |
| ESM0_ESM_PLS_EVENT0_IN_178 | 178          | RTI3_INTR_WWD_0                  |
| ESM0_ESM_PLS_EVENT1_IN_178 | 178          | RTI3_INTR_WWD_0                  |
| ESM0_ESM_PLS_EVENT2_IN_178 | 178          | RTI3_INTR_WWD_0                  |

#### 10.1.1.5 WKUP\_ESM0\_INTERRUPT\_MAP

Table 10-3. WKUP\_ESM0\_INTERRUPT\_MAP Memory Map

| Interrupt Input Line          | Interrupt ID | Source Interrupt                              |
|-------------------------------|--------------|-----------------------------------------------|
| WKUP_ESM0_ESM_LVL_EVENT_IN_0  | 0            | ESM0_ESM_INT_CFG_LVL_0                        |
| WKUP_ESM0_ESM_LVL_EVENT_IN_1  | 1            | ESM0_ESM_INT_HI_LVL_0                         |
| WKUP_ESM0_ESM_LVL_EVENT_IN_2  | 2            | ESM0_ESM_INT_LOW_LVL_0                        |
| WKUP_ESM0_ESM_LVL_EVENT_IN_3  | 3            | MCU_M4FSS0_RAT_EXP_0                          |
| WKUP_ESM0_ESM_LVL_EVENT_IN_4  | 4            | MCU_M4FSS0_ECC_AGGR_LVL_CORRECTED_ERR_0       |
| WKUP_ESM0_ESM_LVL_EVENT_IN_5  | 5            | MCU_M4FSS0_ECC_AGGR_LVL_UNCORRECTED_ERR_0     |
| WKUP_ESM0_ESM_LVL_EVENT_IN_6  | 6            | EFUSE_SCAN_GLUE_CRC_ERR_0                     |
| WKUP_ESM0_ESM_LVL_EVENT_IN_7  | 7            | PLLFRACF_SSMOD16_LOCKLOSS_IPCFG_0             |
| WKUP_ESM0_ESM_LVL_EVENT_IN_8  | 8            | WKUP_VTM0_COMMON_0_THERM_LVL_GT_TH1_INTR_0    |
| WKUP_ESM0_ESM_LVL_EVENT_IN_9  | 9            | WKUP_VTM0_COMMON_0_THERM_LVL_LT_TH0_INTR_0    |
| WKUP_ESM0_ESM_LVL_EVENT_IN_10 | 10           | WKUP_VTM0_COMMON_0_THERM_LVL_GT_TH2_INTR_0    |
| WKUP_ESM0_ESM_LVL_EVENT_IN_11 | 11           | WKUP_VTM0_K3VTM_NC_ECCAGGR_CORR_LEVEL_0       |
| WKUP_ESM0_ESM_LVL_EVENT_IN_12 | 12           | WKUP_VTM0_K3VTM_NC_ECCAGGR_UNCORR_LEVEL_0     |
| WKUP_ESM0_ESM_LVL_EVENT_IN_13 | 13           | HFOSC0_CLKLOSS_GLUE_REF_CLK_LOSS_DETECT_OUT_0 |

**Table 10-3. WKUP\_ESM0\_INTERRUPT\_MAP Memory Map (continued)**

| Interrupt Input Line           | Interrupt ID | Source Interrupt                                                  |
|--------------------------------|--------------|-------------------------------------------------------------------|
| WKUP_ESM0_ESM_LVL_EVENT_IN_14  | 14           | MCU_ECC_AGGR0_CORR_LEVEL_0                                        |
| WKUP_ESM0_ESM_LVL_EVENT_IN_15  | 15           | MCU_ECC_AGGR0_UNCORR_LEVEL_0                                      |
| WKUP_ESM0_ESM_LVL_EVENT_IN_16  | 16           | MCU_MCAN0_MCANSS_MSGMEM_WRAP_ECC_AGGR_MCANSS_ECC_CORR_LVL_INT_0   |
| WKUP_ESM0_ESM_LVL_EVENT_IN_17  | 17           | MCU_MCAN0_MCANSS_MSGMEM_WRAP_ECC_AGGR_MCANSS_ECC_UNCORR_LVL_INT_0 |
| WKUP_ESM0_ESM_LVL_EVENT_IN_18  | 18           | MCU_MCAN1_MCANSS_MSGMEM_WRAP_ECC_AGGR_MCANSS_ECC_CORR_LVL_INT_0   |
| WKUP_ESM0_ESM_LVL_EVENT_IN_19  | 19           | MCU_MCAN1_MCANSS_MSGMEM_WRAP_ECC_AGGR_MCANSS_ECC_UNCORR_LVL_INT_0 |
| WKUP_ESM0_ESM_LVL_EVENT_IN_20  | 20           | WKUP_SAFE_ECC_AGGR0_CORR_LEVEL_0                                  |
| WKUP_ESM0_ESM_LVL_EVENT_IN_21  | 21           | WKUP_SAFE_ECC_AGGR0_UNCORR_LEVEL_0                                |
| WKUP_ESM0_ESM_LVL_EVENT_IN_22  | 22           | PLLFRACF_SSMOD17_LOCKLOSS_IPCFG_0                                 |
| WKUP_ESM0_ESM_LVL_EVENT_IN_23  | 23           | WKUP_ECC_AGGR0_CORR_LEVEL_0                                       |
| WKUP_ESM0_ESM_LVL_EVENT_IN_24  | 24           | WKUP_ECC_AGGR0_UNCORR_LEVEL_0                                     |
| WKUP_ESM0_ESM_LVL_EVENT_IN_25  | 25           | GLUE_EFC_ERROR_AGGREGATED_ERR_0                                   |
| WKUP_ESM0_ESM_LVL_EVENT_IN_26  | 26           | MGASKET_INTR_GLUE_OUT_0                                           |
| WKUP_ESM0_ESM_LVL_EVENT_IN_27  | 27           | SGASKET_INTR_GLUE_OUT_0                                           |
| WKUP_ESM0_ESM_LVL_EVENT_IN_37  | 37           | MCU_DCC0_INTR_ERR_LEVEL_0                                         |
| WKUP_ESM0_ESM_LVL_EVENT_IN_47  | 47           | MCU_PLLFRACF_SSMOD0_LOCKLOSS_IPCFG_0                              |
| WKUP_ESM0_ESM_LVL_EVENT_IN_54  | 54           | PLLFRACF_SSMOD0_LOCKLOSS_IPCFG_0                                  |
| WKUP_ESM0_ESM_LVL_EVENT_IN_55  | 55           | PLLFRACF_SSMOD1_LOCKLOSS_IPCFG_0                                  |
| WKUP_ESM0_ESM_LVL_EVENT_IN_56  | 56           | PLLFRACF_SSMOD2_LOCKLOSS_IPCFG_0                                  |
| WKUP_ESM0_ESM_LVL_EVENT_IN_57  | 57           | PLLFRACF_SSMOD8_LOCKLOSS_IPCFG_0                                  |
| WKUP_ESM0_ESM_LVL_EVENT_IN_58  | 58           | PLLFRACF_SSMOD12_LOCKLOSS_IPCFG_0                                 |
| WKUP_ESM0_ESM_LVL_EVENT_IN_59  | 59           | PLLFRACF_SSMOD15_LOCKLOSS_IPCFG_0                                 |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_64 | 64           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_0                    |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_64 | 64           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_0                    |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_64 | 64           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_0                    |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_65 | 65           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_1                    |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_65 | 65           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_1                    |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_65 | 65           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_1                    |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_66 | 66           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_2                    |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_66 | 66           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_2                    |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_66 | 66           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_2                    |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_69 | 69           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_3                    |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_69 | 69           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_3                    |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_69 | 69           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_3                    |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_70 | 70           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_4                    |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_70 | 70           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_4                    |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_70 | 70           | MCU_PRG_MCU_5POKS0_POK_PGOOD_OV_OUT_N_TO_ESM_4                    |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_71 | 71           | MCU_PRG_MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_0                    |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_71 | 71           | MCU_PRG_MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_0                    |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_71 | 71           | MCU_PRG_MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_0                    |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_72 | 72           | MCU_PRG_MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_1                    |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_72 | 72           | MCU_PRG_MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_1                    |

Table 10-3. WKUP\_ESM0\_INTERRUPT\_MAP Memory Map (continued)

| Interrupt Input Line           | Interrupt ID | Source Interrupt                               |
|--------------------------------|--------------|------------------------------------------------|
| WKUP_ESM0_ESM_PLS_EVENT2_IN_72 | 72           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_1 |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_73 | 73           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_2 |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_73 | 73           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_2 |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_73 | 73           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_2 |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_76 | 76           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_3 |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_76 | 76           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_3 |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_76 | 76           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_3 |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_77 | 77           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_4 |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_77 | 77           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_4 |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_77 | 77           | MCU_PRG MCU_5POKS0_POK_PGOOD_UV_OUT_N_TO_ESM_4 |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_78 | 78           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_0       |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_78 | 78           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_0       |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_78 | 78           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_0       |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_79 | 79           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_1       |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_79 | 79           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_1       |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_79 | 79           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_1       |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_80 | 80           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_2       |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_80 | 80           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_2       |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_80 | 80           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_2       |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_81 | 81           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_3       |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_81 | 81           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_3       |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_81 | 81           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_3       |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_82 | 82           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_4       |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_82 | 82           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_4       |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_82 | 82           | MCU_PRG MCU0_POK_PGOOD_UV_OUT_N_TO_ESM_4       |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_85 | 85           | MCU_RTI0_INTR_WWD_0                            |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_85 | 85           | MCU_RTI0_INTR_WWD_0                            |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_85 | 85           | MCU_RTI0_INTR_WWD_0                            |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_88 | 88           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_8            |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_88 | 88           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_8            |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_88 | 88           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_8            |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_89 | 89           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_9            |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_89 | 89           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_9            |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_89 | 89           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_9            |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_90 | 90           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_10           |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_90 | 90           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_10           |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_90 | 90           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_10           |
| WKUP_ESM0_ESM_PLS_EVENT0_IN_91 | 91           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_11           |
| WKUP_ESM0_ESM_PLS_EVENT1_IN_91 | 91           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_11           |
| WKUP_ESM0_ESM_PLS_EVENT2_IN_91 | 91           | WKUP_MCU_GPIOMUX_INTRROUTER0_OUTP_11           |

### 10.1.2 Events

Events are mainly generated by the BCDMA and the pktDMA. In addition, the sec\_proxy IPC module also generates event outputs. Events can be directly utilized by the BCDMA and the pktDMA. If those events need

to be processed by processor, the events need to be converted to interrupts through the Interrupt Aggregator (IA) Module. Refer to for information on how IA is used. [Figure 10-6](#) shows which modules generates events and how the events are converted to the interrupt.

BCDMA transfer can only be triggered through an event or by software. There are 32 SoC level interrupt signals that can be used to trigger a BCDMA transfer. [Figure 10-7](#) shows all of the possible interrupts and signals that can be used to trigger BCDMA transfer autonomously.



**Figure 10-6. Event Handling**



**Figure 10-7. SoC Level Interrupt Could be Used for BCDMA Trigger**

Table 10-4 shows all the possible interrupt sources which can be used as BCDMA triggers.

**Table 10-4. Interrupts Can Be Used as BCDMA Triggers**

| Input Index | Interrupt Sources                |
|-------------|----------------------------------|
| 0           | cmp_event_introuter.0.outp.24    |
| 1           | cmp_event_introuter.0.outp.25    |
| 2           | cmp_event_introuter.0.outp.26    |
| 3           | cmp_event_introuter.0.outp.27    |
| 4           | cmp_event_introuter.0.outp.28    |
| 5           | cmp_event_introuter.0.outp.29    |
| 6           | cmp_event_introuter.0.outp.30    |
| 7           | cmp_event_introuter.0.outp.31    |
| 8           | timesync_event_introuter0.outl.0 |
| 9           | timesync_event_introuter0.outl.1 |
| 10          | timesync_event_introuter0.outl.2 |
| 11          | timesync_event_introuter0.outl.3 |
| 12          | timesync_event_introuter0.outl.4 |
| 13          | timesync_event_introuter0.outl.5 |
| 14          | timesync_event_introuter0.outl.6 |
| 15          | timesync_event_introuter0.outl.7 |
| 16          | gpiomux_introuter.outp.24        |
| 17          | gpiomux_introuter.outp.25        |
| 18          | gpiomux_introuter.outp.26        |
| 19          | gpiomux_introuter.outp.27        |
| 20          | gpiomux_introuter.outp.28        |
| 21          | gpiomux_introuter.outp.29        |
| 22          | gpiomux_introuter.outp.30        |
| 23          | gpiomux_introuter.outp.31        |
| 24          | gpiomux_introuter.outp.22        |
| 25          | gpiomux_introuter.outp.23        |
| 26          | gpmc.0.gpmc_sdmareq.0            |
| 27          | debugssdavdma_level.0            |
| 28          | mcrc64.0.dma_event.0             |
| 29          | mcrc64.0.dma_event.1             |
| 30          | mcrc64.0.dma_event.2             |
| 31          | mcrc64.0.dma_event.3             |

### 10.1.3 Interrupt Router (INTRROUTER)

### 10.1.4 Time Synchronization Support

Time sync event router enables the flexibility to choose any time synchronization source, whether it is the time synchronization source coming from the external pin or the synchronization pulse generated by the internal peripheral or from the ARM system time counter. Time sync event router also enables the system to utilize time synchronized signal as block copy DMA trigger or as periodical control of EPWM.

The compare event router allows the processor to be interrupted by any of the compared events periodically or use a compared event to generate periodical control on EPWM or triggering block copy DMA transfer. Figure 10-8 shows all the synchronization sources and compare events in the device.



**Figure 10-8. Time Synchronization Support**

**Table 10-5. CMP\_EVENT\_Introuter Connection**

| Input index | Interrupt Sources         |
|-------------|---------------------------|
| 0           | ICSSM.pr1_host_intr_req.0 |
| 1           | ICSSM.pr1_host_intr_req.1 |
| 2           | ICSSM.pr1_host_intr_req.2 |
| 3           | ICSSM.pr1_host_intr_req.3 |

**Table 10-5. CMP\_EVENT\_Introuter Connection (continued)**

| Input index | Interrupt Sources              |
|-------------|--------------------------------|
| 4           | ICSSM.pr1_host_intr_req.4      |
| 5           | ICSSM.pr1_host_intr_req.5      |
| 6           | ICSSM.pr1_host_intr_req.6      |
| 7           | ICSSM.pr1_host_intr_req.7      |
| 8           | ICSSM.pr1_iep0_cmp_intr_req.0  |
| 9           | ICSSM.pr1_iep0_cmp_intr_req.1  |
| 10          | ICSSM.pr1_iep0_cmp_intr_req.2  |
| 11          | ICSSM.pr1_iep0_cmp_intr_req.3  |
| 12          | ICSSM.pr1_iep0_cmp_intr_req.4  |
| 13          | ICSSM.pr1_iep0_cmp_intr_req.5  |
| 14          | ICSSM.pr1_iep0_cmp_intr_req.6  |
| 15          | ICSSM.pr1_iep0_cmp_intr_req.7  |
| 16          | ICSSM.pr1_iep0_cmp_intr_req.8  |
| 17          | ICSSM.pr1_iep0_cmp_intr_req.9  |
| 18          | ICSSM.pr1_iep0_cmp_intr_req.10 |
| 19          | ICSSM.pr1_iep0_cmp_intr_req.11 |
| 20          | ICSSM.pr1_iep0_cmp_intr_req.12 |
| 21          | ICSSM.pr1_iep0_cmp_intr_req.13 |
| 22          | ICSSM.pr1_iep0_cmp_intr_req.14 |
| 23          | ICSSM.pr1_iep0_cmp_intr_req.15 |
| 24          | CPSW0.cpts_comp.0              |

**Table 10-6. TimeSynch\_Event\_Introuter**

| Input Index | Interrupt Sources                                 |
|-------------|---------------------------------------------------|
| 0           | timer0.timer_pwm                                  |
| 1           | timer1.timer_pwm                                  |
| 2           | timer2.timer_pwm                                  |
| 3           | timer3.timer_pwm                                  |
| 4           | N/A                                               |
| 5           | N/A                                               |
| 6           | N/A                                               |
| 7           | N/A                                               |
| 8           | EPWM.epwm_sync0_o                                 |
| 9           | ICSSM.pr1_edc0_sync1_out                          |
| 10          | ICSSM.pr1_edc0_sync0_out                          |
| 11          | gtc_r10.wkup_0.gtc_push_event                     |
| 12          | CP_GEMAC_CPTS0_HW1TSPUSH.CP_GEMAC_CPTS0_HW1TSPUSH |
| 13          | CP_GEMAC_CPTS0_HW2TSPUSH.CP_GEMAC_CPTS0_HW2TSPUSH |
| 14          | N/A                                               |
| 15          | N/A                                               |
| 16          | CPSW0.cpts_genf0                                  |
| 17          | CPSW0.cpts_genf1                                  |
| 18          | CPSW0.cpts_sync                                   |

**Table 10-7. Push Event for CPSW**

| Input Index | Interrupt Source                  |
|-------------|-----------------------------------|
| 1           | timesync_event_introuter0.outl.10 |
| 2           | timesync_event_introuter0.outl.11 |
| 3           | timesync_event_introuter0.outl.12 |
| 4           | timesync_event_introuter0.outl.13 |
| 5           | timesync_event_introuter0.outl.14 |
| 6           | timesync_event_introuter0.outl.15 |
| 7           | timesync_event_introuter0.outl.16 |
| 8           | timesync_event_introuter0.outl.17 |

**Table 10-8. ICSSM Latch and Capture Events**

| Input Index                    | Interrupt Source                 |
|--------------------------------|----------------------------------|
| icssm0.pr1_edc0_latch0_in.0    | timesync_event_introuter0.outl.8 |
| icssm0.pr1_edc0_latch1_in.0    | timesync_event_introuter0.outl.9 |
| icssm0.pr1_iep0_cap_intr_req.0 | gpiomux_introuter.outp.16        |
| icssm0.pr1_iep0_cap_intr_req.1 | gpiomux_introuter.outp.17        |
| icssm0.pr1_iep0_cap_intr_req.2 | gpiomux_introuter.outp.18        |
| icssm0.pr1_iep0_cap_intr_req.3 | gpiomux_introuter.outp.19        |
| icssm0.pr1_iep0_cap_intr_req.4 | gpiomux_introuter.outp.20        |
| icssm0.pr1_iep0_cap_intr_req.5 | gpiomux_introuter.outp.21        |

### 10.1.5 GPIO Interrupt Handling

There are three GPIO modules in the device, which could generate almost 200 interrupts. Those GPIO interrupt outputs are routed to the GPIO interrupt router first before they are routed to the final interrupt destination. The GPIO interrupt router allows each output to select each GPIO interrupt independently.

Two of the GPIO modules in the Main domain use one GPIO interrupt router while the GPIO module in MCU domain has its own dedicated GPIO router. See [Figure 10-9](#).



Figure 10-9. GPIO Interrupt Routing

Table 10-9. GPIO\_mux\_introuter Connection

| Input index | Interrupt Source |
|-------------|------------------|
| 0           | GPIO0 gpio.0     |
| 1           | GPIO0 gpio.1     |
| 2           | GPIO0 gpio.2     |
| 3           | GPIO0 gpio.3     |
| 4           | GPIO0 gpio.4     |
| 5           | GPIO0 gpio.5     |
| 6           | GPIO0 gpio.6     |
| 7           | GPIO0 gpio.7     |
| 8           | GPIO0 gpio.8     |
| 9           | GPIO0 gpio.9     |
| 10          | GPIO0 gpio.10    |
| 11          | GPIO0 gpio.11    |
| 12          | GPIO0 gpio.12    |
| 13          | GPIO0 gpio.13    |
| 14          | GPIO0 gpio.14    |
| 15          | GPIO0 gpio.15    |
| 16          | GPIO0 gpio.16    |
| 17          | GPIO0 gpio.17    |
| 18          | GPIO0 gpio.18    |
| 19          | GPIO0 gpio.19    |
| 20          | GPIO0 gpio.20    |
| 21          | GPIO0 gpio.21    |

**Table 10-9. GPIO\_mux\_introuter Connection (continued)**

| Input index | Interrupt Source |
|-------------|------------------|
| 22          | GPIO0 gpio.22    |
| 23          | GPIO0 gpio.23    |
| 24          | GPIO0 gpio.24    |
| 25          | GPIO0 gpio.25    |
| 26          | GPIO0 gpio.26    |
| 27          | GPIO0 gpio.27    |
| 28          | GPIO0 gpio.28    |
| 29          | GPIO0 gpio.29    |
| 30          | GPIO0 gpio.30    |
| 31          | GPIO0 gpio.31    |
| 32          | GPIO0 gpio.32    |
| 33          | GPIO0 gpio.33    |
| 34          | GPIO0 gpio.34    |
| 35          | GPIO0 gpio.35    |
| 36          | GPIO0 gpio.36    |
| 37          | GPIO0 gpio.37    |
| 38          | GPIO0 gpio.38    |
| 39          | GPIO0 gpio.39    |
| 40          | GPIO0 gpio.40    |
| 41          | GPIO0 gpio.41    |
| 42          | GPIO0 gpio.42    |
| 43          | GPIO0 gpio.43    |
| 44          | GPIO0 gpio.44    |
| 45          | GPIO0 gpio.45    |
| 46          | GPIO0 gpio.46    |
| 47          | GPIO0 gpio.47    |
| 48          | GPIO0 gpio.48    |
| 49          | GPIO0 gpio.49    |
| 50          | GPIO0 gpio.50    |
| 51          | GPIO0 gpio.51    |
| 52          | GPIO0 gpio.52    |
| 53          | GPIO0 gpio.53    |
| 54          | GPIO0 gpio.54    |
| 55          | GPIO0 gpio.55    |
| 56          | GPIO0 gpio.56    |
| 57          | GPIO0 gpio.57    |
| 58          | GPIO0 gpio.58    |
| 59          | GPIO0 gpio.59    |
| 60          | GPIO0 gpio.60    |
| 61          | GPIO0 gpio.61    |
| 62          | GPIO0 gpio.62    |
| 63          | GPIO0 gpio.63    |
| 64          | GPIO0 gpio.64    |
| 65          | GPIO0 gpio.65    |
| 66          | GPIO0 gpio.66    |

**Table 10-9. GPIO\_mux\_introuter Connection (continued)**

| Input index | Interrupt Source |
|-------------|------------------|
| 67          | GPIO0 gpio.67    |
| 68          | GPIO0 gpio.68    |
| 69          | GPIO0 gpio.69    |
| 70          | GPIO0 gpio.70    |
| 71          | GPIO0 gpio.71    |
| 72          | GPIO0 gpio.72    |
| 73          | GPIO0 gpio.73    |
| 74          | GPIO0 gpio.74    |
| 75          | GPIO0 gpio.75    |
| 76          | GPIO0 gpio.76    |
| 77          | GPIO0 gpio.77    |
| 78          | GPIO0 gpio.78    |
| 79          | GPIO0 gpio.79    |
| 80          | GPIO0 gpio.80    |
| 81          | GPIO0 gpio.81    |
| 82          | GPIO0 gpio.82    |
| 83          | GPIO0 gpio.83    |
| 84          | GPIO0 gpio.84    |
| 85          | GPIO0 gpio.85    |
| 86          | GPIO0 gpio.86    |
| 87          | GPIO0 gpio.87    |
| 88          | GPIO0 gpio.88    |
| 89          | GPIO0 gpio.89    |
| 90          | GPIO1 gpio.0     |
| 91          | GPIO1 gpio.1     |
| 92          | GPIO1 gpio.2     |
| 93          | GPIO1 gpio.3     |
| 94          | GPIO1 gpio.4     |
| 95          | GPIO1 gpio.5     |
| 96          | GPIO1 gpio.6     |
| 97          | GPIO1 gpio.7     |
| 98          | GPIO1 gpio.8     |
| 99          | GPIO1 gpio.9     |
| 100         | GPIO1 gpio.10    |
| 101         | GPIO1 gpio.11    |
| 102         | GPIO1 gpio.12    |
| 103         | GPIO1 gpio.13    |
| 104         | GPIO1 gpio.14    |
| 105         | GPIO1 gpio.15    |
| 106         | GPIO1 gpio.16    |
| 107         | GPIO1 gpio.17    |
| 108         | GPIO1 gpio.18    |
| 109         | GPIO1 gpio.19    |
| 110         | GPIO1 gpio.20    |
| 111         | GPIO1 gpio.21    |

**Table 10-9. GPIO\_mux\_introuter Connection (continued)**

| Input index | Interrupt Source |
|-------------|------------------|
| 112         | GPIO1 gpio.22    |
| 113         | GPIO1 gpio.23    |
| 114         | GPIO1 gpio.24    |
| 115         | GPIO1 gpio.25    |
| 116         | GPIO1 gpio.26    |
| 117         | GPIO1 gpio.27    |
| 118         | GPIO1 gpio.28    |
| 119         | GPIO1 gpio.29    |
| 120         | GPIO1 gpio.30    |
| 121         | GPIO1 gpio.31    |
| 122         | GPIO1 gpio.32    |
| 123         | GPIO1 gpio.33    |
| 124         | GPIO1 gpio.34    |
| 125         | GPIO1 gpio.35    |
| 126         | GPIO1 gpio.36    |
| 127         | GPIO1 gpio.37    |
| 128         | GPIO1 gpio.38    |
| 129         | GPIO1 gpio.39    |
| 130         | GPIO1 gpio.40    |
| 131         | GPIO1 gpio.41    |
| 132         | GPIO1 gpio.42    |
| 133         | GPIO1 gpio.43    |
| 134         | GPIO1 gpio.44    |
| 135         | GPIO1 gpio.45    |
| 136         | GPIO1 gpio.46    |
| 137         | GPIO1 gpio.47    |
| 138         | GPIO1 gpio.48    |
| 139         | GPIO1 gpio.49    |
| 140         | GPIO1 gpio.50    |
| 141         | GPIO1 gpio.51    |
| 142         | GPIO1 gpio.52    |
| 143         | GPIO1 gpio.53    |
| 144         | GPIO1 gpio.54    |
| 145         | GPIO1 gpio.55    |
| 146         | GPIO1 gpio.56    |
| 147         | GPIO1 gpio.57    |
| 148         | GPIO1 gpio.58    |
| 149         | GPIO1 gpio.59    |
| 150         | GPIO1 gpio.60    |
| 151         | GPIO1 gpio.61    |
| 152         | GPIO1 gpio.62    |
| 153         | GPIO1 gpio.63    |
| 154         | GPIO1 gpio.64    |
| 155         | GPIO1 gpio.65    |
| 156         | GPIO1 gpio.66    |

**Table 10-9. GPIO\_mux\_introuter Connection (continued)**

| Input index | Interrupt Source  |
|-------------|-------------------|
| 157         | GPIO1 gpio.67     |
| 158         | GPIO1 gpio.68     |
| 159         | GPIO1 gpio.69     |
| 160         | GPIO1 gpio.70     |
| 161         | GPIO1 gpio.71     |
| 162         |                   |
| 163         |                   |
| 164         |                   |
| 165         |                   |
| 166         |                   |
| 167         |                   |
| 168         |                   |
| 169         |                   |
| 170         |                   |
| 171         |                   |
| 172         |                   |
| 173         |                   |
| 174         |                   |
| 175         |                   |
| 176         | GPIO0 gpio.90     |
| 177         | GPIO0 gpio.91     |
| 178         |                   |
| 179         |                   |
| 180         | GPIO1 gpio_bank.0 |
| 181         | GPIO1 gpio_bank.1 |
| 182         | GPIO1 gpio_bank.2 |
| 183         | GPIO1 gpio_bank.3 |
| 184         | GPIO1 gpio_bank.4 |
| 185         |                   |
| 186         |                   |
| 187         |                   |
| 188         |                   |
| 189         |                   |
| 190         | GPIO0 gpio_bank.0 |
| 191         | GPIO0 gpio_bank.1 |
| 192         | GPIO0 gpio_bank.2 |
| 193         | GPIO0 gpio_bank.3 |
| 194         | GPIO0 gpio_bank.4 |
| 195         | GPIO0 gpio_bank.5 |
| 196         |                   |
| 197         |                   |
| 198         |                   |
| 199         |                   |

**Table 10-10. MCU GPIO MUX Introuter Connections**

| Input Index | Interrupt Source      |
|-------------|-----------------------|
| 0           | GPIO0_mcu gpio.0      |
| 1           | GPIO0_mcu gpio.1      |
| 2           | GPIO0_mcu gpio.2      |
| 3           | GPIO0_mcu gpio.3      |
| 4           | GPIO0_mcu gpio.4      |
| 5           | GPIO0_mcu gpio.5      |
| 6           | GPIO0_mcu gpio.6      |
| 7           | GPIO0_mcu gpio.7      |
| 8           | GPIO0_mcu gpio.8      |
| 9           | GPIO0_mcu gpio.9      |
| 10          | GPIO0_mcu gpio.10     |
| 11          | GPIO0_mcu gpio.11     |
| 12          | GPIO0_mcu gpio.12     |
| 13          | GPIO0_mcu gpio.13     |
| 14          | GPIO0_mcu gpio.14     |
| 15          | GPIO0_mcu gpio.15     |
| 16          | GPIO0_mcu gpio.16     |
| 17          | GPIO0_mcu gpio.17     |
| 18          | GPIO0_mcu gpio.18     |
| 19          | GPIO0_mcu gpio.19     |
| 20          | GPIO0_mcu gpio.20     |
| 21          | GPIO0_mcu gpio.21     |
| 22          | GPIO0_mcu gpio.22     |
| 23          | GPIO0_mcu gpio.23     |
| 24          |                       |
| 25          |                       |
| 26          |                       |
| 27          |                       |
| 28          |                       |
| 29          |                       |
| 30          | GPIO0_mcu gpio_bank.0 |
| 31          | GPIO0_mcu gpio_bank.1 |

### 10.1.6 Utilizing Miscellaneous Signals as Interrupt

Some of the signals are aggregated through glue logic and need to be handled separately.

#### 10.1.6.1 Aggregated Interrupt from Timeout Gasket

There are multiple timeout gaskets in SoC, some of them are inserted at the initiator side and the others are inserted at the target interface side. Each timeout gasket module generates its own interrupt. Instead of routing the interrupt from each timeout gasket individually to the processor, the interrupts from all the timeout gasket inserted at the target sides are aggregated together (ORed), and all the interrupts from all the timeout gasket inserted at the initiator sides are aggregated together (ORed). The status of each interrupt status is captured by the TOG\_STAT registers in both wkup\_ctrl\_mmr and mcu\_ctrl\_mmr. Refer to [Figure 10-10](#).



Figure 10-10. Interrupt from Timeout Gaskets

#### 10.1.6.2 Aggregated DCC Interrupt

There are multiple DCC modules in the main domain and each DCC module generates its own DCC\_done interrupt. The DCC\_done interrupt from all the DCC modules in the main domain are aggregated (ORed) together before it is routed to all the processors, refer to Figure 10-11.



Figure 10-11. DCC Intr\_done Interrupt Aggregation

#### 10.1.6.3 Aggregated Access Error Interrupt from CBASS

CBASS modules are the interconnection blocks on the SoC level to provide access path between initiators and targets. When the transaction is not completed successfully, an interrupt is generated by the CBASS and the error transaction is logged by the CBASS module.

There are multiple CBASS modules on the SoC level to provide three layers of interconnect: the data plane, security configuration plane and debug configuration plane. The CBASS access error from the security configuration plane is only routed to TIFS and HSM, and the other CBASS access errors are aggregated before routing it to the processors, refer to [Figure 10-12](#).



**Figure 10-12. Aggregated CBASS Access Error**

#### 10.1.6.4 Access Error to Control Register Block Interrupt Aggregation

There are multiple register blocks on the SoC level, and each register block generates an error interrupt when there is an access error. Those access error interrupts are aggregated together before they are routed to processor, refer to [Figure 10-13](#).



Figure 10-13. Access Error Aggregation

#### 10.1.6.4.1 EPWM Trip Signal Aggregation



Figure 10-14. EPWM Trip Signal Aggregation as Interrupt

#### 10.1.7 Interrupt Connections for MCUSS NVIC

Table 10-11. MCUSS NVIC Interrupt Connection

| Input index | Interrupt Sources             |
|-------------|-------------------------------|
| 0           | gpiomux_introuter_mcu0.outp.4 |
| 1           | gpiomux_introuter_mcu0.outp.5 |

**Table 10-11. MCUSS NVIC Interrupt Connection (continued)**

| Input index | Interrupt Sources                            |
|-------------|----------------------------------------------|
| 2           | gpiomux_introuter_mcu0.outp.6                |
| 3           | gpiomux_introuter_mcu0.outp.7                |
| 4           | timer_mcu0.intr_pend.0                       |
| 5           | timer_mcu1.intr_pend.0                       |
| 6           | timer_mcu2.intr_pend.0                       |
| 7           | timer_mcu3.intr_pend.0                       |
| 8           | sa3ss_am62.0.intaggr_vintr.7                 |
| 9           | mainreset_request_glue.resetz_sync_stretch.0 |
| 10          | mainreset_request_glue.porz_sync_stretch.0   |
| 11          | esm_am64_mcu.wkup_0.esm_int_cfg_lvl.0        |
| 12          | esm_am64_mcu.wkup_0.esm_int_hi_lvl.0         |
| 13          | esm_am64_mcu.wkup_0.esm_int_low_lvl.0        |
| 14          | MCUSS_MCU0.rat_exp.0                         |
| 15          | gpiomux_introuter.outp.34                    |
| 16          | gpiomux_introuter.outp.35                    |
| 17          | mshsi2c.mcu_0.pointrpPEND.0                  |
| 18          | k3_ddpa.0.ddpa_intr.0                        |
| 19          | rti.mcum4_0.intr_wwd.0                       |
| 20          | smcu_psc_wrap.wkup_0.psc_allint.0            |
| 21          | dcc.mcu0.intr_done_level.0                   |
| 22          | spi.mcu_0.intr_spi.0                         |
| 23          | spi.mcu_1.intr_spi.0                         |
| 24          | uart.mcu_0.usart_irq.0                       |
| 25          | mcrc64.mcu_0.int_mcrc.0                      |
| 26          | sms.0.sec_out.0                              |
| 27          | sms.0.sec_out.1                              |
| 28          | vtm.wkup_0.therm_lvl_lt_th0_intr.0           |
| 29          | vtm.wkup_0.therm_lvl_gt_th1_intr.0           |
| 30          | vtm.wkup_0.therm_lvl_gt_th2_intr.0           |
| 31          | mcu_cbass_intr_or_glue.out.0                 |
| 32          | dmss0.intaggr_vintr.168                      |
| 33          | dmss0.intaggr_vintr.169                      |
| 34          | dmss0.intaggr_vintr.170                      |
| 35          | dmss0.intaggr_vintr.171                      |
| 36          | k3_epwm.0.epwm_etint.0                       |
| 37          | k3_epwm.1.epwm_etint.0                       |
| 38          | k3_epwm.2.epwm_etint.0                       |
| 39          | mcu_access_err_intr_glue.out.0               |
| 40          | dss0.dispc_intr_req_0.0                      |
| 41          | dss0.dispc_intr_req_1.0                      |
| 42          | mcan_mcu0.mcanss_ext_ts_rollover_lvl_int.0   |
| 43          | mcan_mcu0.mcanss_mcan_lvl_int.0              |
| 44          | mcan_mcu0.mcanss_mcan_lvl_int.1              |
| 45          | mcan_mcu1.mcanss_ext_ts_rollover_lvl_int.0   |
| 46          | mcan_mcu1.mcanss_mcan_lvl_int.0              |

**Table 10-11. MCUSS NVIC Interrupt Connection (continued)**

| Input index | Interrupt Sources                           |
|-------------|---------------------------------------------|
| 47          | mcan_mcu1.mcanss_mcan_lvl_int.1             |
| 48          | sms.0.aes_sintrequest_p.0                   |
| 49          | sms.0.aes_sintrequest_s.0                   |
| 50          | mailbox1.0.mailbox_cluster0_pend.2          |
| 51          | icssm0.pr1_host_intr_pend.6                 |
| 52          | icssm0.pr1_host_intr_pend.7                 |
| 53          | icssm0.iso_reset_protocol_ack.0             |
| 54          | dmss0.intaggr_vintr.172                     |
| 55          | dmss0.intaggr_vintr.173                     |
| 56          | dmss0.intaggr_vintr.174                     |
| 57          | dmss0.intaggr_vintr.175                     |
| 58          | cmp_event_introuter.0.outp.34               |
| 59          | cmp_event_introuter.0.outp.35               |
| 60          | cmp_event_introuter.0.outp.36               |
| 61          | cmp_event_introuter.0.outp.37               |
| 62          | Aggregated target side timeout interrupt    |
| 63          | Aggregated initiator side timeout interrupt |

### 10.1.8 Interrupt Connections for GICSS

**Table 10-12. GIC Interrupt Connection**

| Input index      | Interrupt Source               |
|------------------|--------------------------------|
| gicss0.ppi0_0.16 | not connected                  |
| gicss0.ppi0_0.17 | not connected                  |
| gicss0.ppi0_0.18 | compute_cluster0.ctiirq1.0     |
| gicss0.ppi0_0.19 | compute_cluster0.ctiirq2.0     |
| gicss0.ppi0_0.20 | compute_cluster0.ctiirq3.0     |
| gicss0.ppi0_0.21 | not connected                  |
| gicss0.ppi0_0.22 | compute_cluster0.commirq0.0    |
| gicss0.ppi0_0.23 | compute_cluster0.pmuirq0.0     |
| gicss0.ppi0_0.24 | compute_cluster0.ctiirq0.0     |
| gicss0.ppi0_0.25 | compute_cluster0.vcpumntirq0.0 |
| gicss0.ppi0_0.26 | compute_cluster0.cnthpirq0.0   |
| gicss0.ppi0_0.27 | compute_cluster0.cntvirq0.0    |
| gicss0.ppi0_0.28 | not connected                  |
| gicss0.ppi0_0.29 | compute_cluster0.cntrpsirq0.0  |
| gicss0.ppi0_0.30 | compute_cluster0.cntrnsirq0.0  |
| gicss0.ppi0_0.31 | not connected                  |
| gicss0.ppi0_1.16 | not connected                  |
| gicss0.ppi0_1.17 | compute_cluster0.ctiirq0.0     |
| gicss0.ppi0_1.18 | not connected                  |
| gicss0.ppi0_1.19 | compute_cluster0.ctiirq2.0     |
| gicss0.ppi0_1.20 | compute_cluster0.ctiirq3.0     |
| gicss0.ppi0_1.21 | not connected                  |
| gicss0.ppi0_1.22 | compute_cluster0.commirq1.0    |
| gicss0.ppi0_1.23 | compute_cluster0.pmuirq1.0     |

**Table 10-12. GIC Interrupt Connection (continued)**

| Input index      | Interrupt Source               |
|------------------|--------------------------------|
| gicss0.ppi0_1.24 | compute_cluster0.ctiirq1.0     |
| gicss0.ppi0_1.25 | compute_cluster0.vcpumntirq1.0 |
| gicss0.ppi0_1.26 | compute_cluster0.cnthpirq1.0   |
| gicss0.ppi0_1.27 | compute_cluster0.cntvirq1.0    |
| gicss0.ppi0_1.28 | not connected                  |
| gicss0.ppi0_1.29 | compute_cluster0.cntpsirq1.0   |
| gicss0.ppi0_1.30 | compute_cluster0.cntpnsirq1.0  |
| gicss0.ppi0_1.31 | not connected                  |
| gicss0.ppi0_2.16 | not connected                  |
| gicss0.ppi0_2.17 | compute_cluster0.ctiirq0.0     |
| gicss0.ppi0_2.18 | compute_cluster0.ctiirq1.0     |
| gicss0.ppi0_2.19 | not connected                  |
| gicss0.ppi0_2.20 | compute_cluster0.ctiirq3.0     |
| gicss0.ppi0_2.21 | not connected                  |
| gicss0.ppi0_2.22 | compute_cluster0.commirq2.0    |
| gicss0.ppi0_2.23 | compute_cluster0.pmuirq2.0     |
| gicss0.ppi0_2.24 | compute_cluster0.ctiirq2.0     |
| gicss0.ppi0_2.25 | compute_cluster0.vcpumntirq2.0 |
| gicss0.ppi0_2.26 | compute_cluster0.cnthpirq2.0   |
| gicss0.ppi0_2.27 | compute_cluster0.cntvirq2.0    |
| gicss0.ppi0_2.28 | not connected                  |
| gicss0.ppi0_2.29 | compute_cluster0.cntpsirq2.0   |
| gicss0.ppi0_2.30 | compute_cluster0.cntpnsirq2.0  |
| gicss0.ppi0_2.31 | not connected                  |
| gicss0.ppi0_3.16 | not connected                  |
| gicss0.ppi0_3.17 | compute_cluster0.ctiirq0.0     |
| gicss0.ppi0_3.18 | compute_cluster0.ctiirq1.0     |
| gicss0.ppi0_3.19 | compute_cluster0.ctiirq2.0     |
| gicss0.ppi0_3.20 | not connected                  |
| gicss0.ppi0_3.21 | not connected                  |
| gicss0.ppi0_3.22 | compute_cluster0.commirq3.0    |
| gicss0.ppi0_3.23 | compute_cluster0.pmuirq3.0     |
| gicss0.ppi0_3.24 | compute_cluster0.ctiirq3.0     |
| gicss0.ppi0_3.25 | compute_cluster0.vcpumntirq3.0 |
| gicss0.ppi0_3.26 | compute_cluster0.cnthpirq3.0   |
| gicss0.ppi0_3.27 | compute_cluster0.cntvirq3.0    |
| gicss0.ppi0_3.28 | not connected                  |
| gicss0.ppi0_3.29 | compute_cluster0.cntpsirq3.0   |
| gicss0.ppi0_3.30 | compute_cluster0.cntpnsirq3.0  |
| gicss0.ppi0_3.31 | not connected                  |
| gicss0.spi.32    | gpiomux_introuter.outp.0       |
| gicss0.spi.33    | gpiomux_introuter.outp.1       |
| gicss0.spi.34    | gpiomux_introuter.outp.2       |
| gicss0.spi.35    | gpiomux_introuter.outp.3       |
| gicss0.spi.36    | gpiomux_introuter.outp.4       |

Table 10-12. GIC Interrupt Connection (continued)

| Input index   | Interrupt Source              |
|---------------|-------------------------------|
| gicss0.spi.37 | gpiomux_introuter.outp.5      |
| gicss0.spi.38 | gpiomux_introuter.outp.6      |
| gicss0.spi.39 | gpiomux_introuter.outp.7      |
| gicss0.spi.40 | gpiomux_introuter.outp.8      |
| gicss0.spi.41 | gpiomux_introuter.outp.9      |
| gicss0.spi.42 | gpiomux_introuter.outp.10     |
| gicss0.spi.43 | gpiomux_introuter.outp.11     |
| gicss0.spi.44 | gpiomux_introuter.outp.12     |
| gicss0.spi.45 | gpiomux_introuter.outp.13     |
| gicss0.spi.46 | gpiomux_introuter.outp.14     |
| gicss0.spi.47 | gpiomux_introuter.outp.15     |
| gicss0.spi.48 | cmp_event_introuter.0.outp.0  |
| gicss0.spi.49 | cmp_event_introuter.0.outp.1  |
| gicss0.spi.50 | cmp_event_introuter.0.outp.2  |
| gicss0.spi.51 | cmp_event_introuter.0.outp.3  |
| gicss0.spi.52 | cmp_event_introuter.0.outp.4  |
| gicss0.spi.53 | cmp_event_introuter.0.outp.5  |
| gicss0.spi.54 | cmp_event_introuter.0.outp.6  |
| gicss0.spi.55 | cmp_event_introuter.0.outp.7  |
| gicss0.spi.56 | cmp_event_introuter.0.outp.8  |
| gicss0.spi.57 | cmp_event_introuter.0.outp.9  |
| gicss0.spi.58 | cmp_event_introuter.0.outp.10 |
| gicss0.spi.59 | cmp_event_introuter.0.outp.11 |
| gicss0.spi.60 | cmp_event_introuter.0.outp.12 |
| gicss0.spi.61 | cmp_event_introuter.0.outp.13 |
| gicss0.spi.62 | cmp_event_introuter.0.outp.14 |
| gicss0.spi.63 | cmp_event_introuter.0.outp.15 |
| gicss0.spi.64 | dmss0.intaggr_vintr.0         |
| gicss0.spi.65 | dmss0.intaggr_vintr.1         |
| gicss0.spi.66 | dmss0.intaggr_vintr.2         |
| gicss0.spi.67 | dmss0.intaggr_vintr.3         |
| gicss0.spi.68 | dmss0.intaggr_vintr.4         |
| gicss0.spi.69 | dmss0.intaggr_vintr.5         |
| gicss0.spi.70 | dmss0.intaggr_vintr.6         |
| gicss0.spi.71 | dmss0.intaggr_vintr.7         |
| gicss0.spi.72 | dmss0.intaggr_vintr.8         |
| gicss0.spi.73 | dmss0.intaggr_vintr.9         |
| gicss0.spi.74 | dmss0.intaggr_vintr.10        |
| gicss0.spi.75 | dmss0.intaggr_vintr.11        |
| gicss0.spi.76 | dmss0.intaggr_vintr.12        |
| gicss0.spi.77 | dmss0.intaggr_vintr.13        |
| gicss0.spi.78 | dmss0.intaggr_vintr.14        |
| gicss0.spi.79 | dmss0.intaggr_vintr.15        |
| gicss0.spi.80 | dmss0.intaggr_vintr.16        |
| gicss0.spi.81 | dmss0.intaggr_vintr.17        |

**Table 10-12. GIC Interrupt Connection (continued)**

| Input index    | Interrupt Source                             |
|----------------|----------------------------------------------|
| gicss0.spi.82  | dmss0.intaggr_vintr.18                       |
| gicss0.spi.83  | dmss0.intaggr_vintr.19                       |
| gicss0.spi.84  | dmss0.intaggr_vintr.20                       |
| gicss0.spi.85  | dmss0.intaggr_vintr.21                       |
| gicss0.spi.86  | dmss0.intaggr_vintr.22                       |
| gicss0.spi.87  | dmss0.intaggr_vintr.23                       |
| gicss0.spi.88  | dmss0.intaggr_vintr.24                       |
| gicss0.spi.89  | dmss0.intaggr_vintr.25                       |
| gicss0.spi.90  | dmss0.intaggr_vintr.26                       |
| gicss0.spi.91  | dmss0.intaggr_vintr.27                       |
| gicss0.spi.92  | dmss0.intaggr_vintr.28                       |
| gicss0.spi.93  | dmss0.intaggr_vintr.29                       |
| gicss0.spi.94  | dmss0.intaggr_vintr.30                       |
| gicss0.spi.95  | dmss0.intaggr_vintr.31                       |
| gicss0.spi.96  | dmss0.intaggr_vintr.32                       |
| gicss0.spi.97  | dmss0.intaggr_vintr.33                       |
| gicss0.spi.98  | dmss0.intaggr_vintr.34                       |
| gicss0.spi.99  | dmss0.intaggr_vintr.35                       |
| gicss0.spi.100 | dmss0.intaggr_vintr.36                       |
| gicss0.spi.101 | dmss0.intaggr_vintr.37                       |
| gicss0.spi.102 | dmss0.intaggr_vintr.38                       |
| gicss0.spi.103 | dmss0.intaggr_vintr.39                       |
| gicss0.spi.104 | gpiomux_introuter_mcu0.outp.0                |
| gicss0.spi.105 | gpiomux_introuter_mcu0.outp.1                |
| gicss0.spi.106 | gpiomux_introuter_mcu0.outp.2                |
| gicss0.spi.107 | gpiomux_introuter_mcu0.outp.3                |
| gicss0.spi.108 | mailbox1.0.mailbox_cluster0_pend.0           |
| gicss0.spi.109 | mailbox1.0.mailbox_cluster0_pend.1           |
| gicss0.spi.110 | mainreset_request_glue.porz_sync_stretch.0   |
| gicss0.spi.111 | mainreset_request_glue.resetz_sync_stretch.0 |
| gicss0.spi.112 | sa3ss_am62.0.intaggr_vintr.4                 |
| gicss0.spi.113 | sa3ss_am62.0.intaggr_vintr.5                 |
| gicss0.spi.114 | mmcsd1.emmcisdss_intr.0                      |
| gicss0.spi.115 | mmcsd0.emmcisdss_intr.0                      |
| gicss0.spi.116 | dss0.dispc_intr_req_0.0                      |
| gicss0.spi.117 | dss0.dispc_intr_req_1.0                      |
| gicss0.spi.118 | k3_gpu_axe116m.0.gpu_os_irq.0                |
| gicss0.spi.119 | k3_gpu_axe116m.0.gpu_os_irq.1                |
| gicss0.spi.120 | icssm0.pr1_host_intr_pend.0                  |
| gicss0.spi.121 | icssm0.pr1_host_intr_pend.1                  |
| gicss0.spi.122 | icssm0.pr1_host_intr_pend.2                  |
| gicss0.spi.123 | icssm0.pr1_host_intr_pend.3                  |
| gicss0.spi.124 | icssm0.pr1_host_intr_pend.4                  |
| gicss0.spi.125 | icssm0.pr1_host_intr_pend.5                  |
| gicss0.spi.126 | icssm0.pr1_host_intr_pend.6                  |

Table 10-12. GIC Interrupt Connection (continued)

| Input index    | Interrupt Source                             |
|----------------|----------------------------------------------|
| gicss0.spi.127 | icssm0.pr1_host_intr_pend.7                  |
| gicss0.spi.128 | DCC_done_glue.dcc_done.0                     |
| gicss0.spi.129 | soc_access_err_intr_glue.out.0               |
| gicss0.spi.130 |                                              |
| gicss0.spi.131 |                                              |
| gicss0.spi.132 | rtcss.wkup_0 rtc_event_pend.0                |
| gicss0.spi.133 | SoC_cbass_err_intr_glue.cbass_agg_err_intr.0 |
| gicss0.spi.134 | CPSW0.evnt_pend.0                            |
| gicss0.spi.135 | CPSW0.mdio_pend.0                            |
| gicss0.spi.136 | CPSW0.stat_pend.0                            |
| gicss0.spi.137 |                                              |
| gicss0.spi.138 | gpmc.0.gpmc_sinterrupt.0                     |
| gicss0.spi.139 | mshsi2c.mcu_0.pointrpend.0                   |
| gicss0.spi.140 |                                              |
| gicss0.spi.141 |                                              |
| gicss0.spi.142 |                                              |
| gicss0.spi.143 | sms.0.sec_out.0                              |
| gicss0.spi.144 | sms.0.sec_out.1                              |
| gicss0.spi.145 | ecap.0.ecap_int.0                            |
| gicss0.spi.146 | ecap.1.ecap_int.0                            |
| gicss0.spi.147 | ecap.2.ecap_int.0                            |
| gicss0.spi.148 | eqep_t2.0.eqep_int.0                         |
| gicss0.spi.149 | eqep_t2.1.eqep_int.0                         |
| gicss0.spi.150 | eqep_t2.2.eqep_int.0                         |
| gicss0.spi.151 | ddr16ss.ddrss_controller.0                   |
| gicss0.spi.152 | timer0.intr_pend.0                           |
| gicss0.spi.153 | timer1.intr_pend.0                           |
| gicss0.spi.154 | timer2.intr_pend.0                           |
| gicss0.spi.155 | timer3.intr_pend.0                           |
| gicss0.spi.156 | timer4.intr_pend.0                           |
| gicss0.spi.157 | timer5.intr_pend.0                           |
| gicss0.spi.158 | timer6.intr_pend.0                           |
| gicss0.spi.159 | timer7.intr_pend.0                           |
| gicss0.spi.160 | sa3ss_am62.0.sa_ul_pk.0                      |
| gicss0.spi.161 | sa3ss_am62.0.sa_ul_trng.0                    |
| gicss0.spi.162 |                                              |
| gicss0.spi.163 |                                              |
| gicss0.spi.164 | elm.0.elm_porocpsinterrupt_lvl.0             |
| gicss0.spi.165 | mmcsd0.emmcisdss_intr.0                      |
| gicss0.spi.166 | mcrc64.0.int_mcrc.0                          |
| gicss0.spi.167 | icssm0.iso_reset_protocol_ack.0              |
| gicss0.spi.168 |                                              |
| gicss0.spi.169 |                                              |
| gicss0.spi.170 |                                              |
| gicss0.spi.171 | fss0.ospi0_lvl_intr.0                        |

**Table 10-12. GIC Interrupt Connection (continued)**

| Input index    | Interrupt Source                       |
|----------------|----------------------------------------|
| gicss0.spi.172 | ddr16ss.ddrss_pll_freq_change_req.0    |
| gicss0.spi.173 | csi_rx_if.0.csi_irq.0                  |
| gicss0.spi.174 | csi_rx_if.0.csi_level.0                |
| gicss0.spi.175 | csi_rx_if.0.csi_err_irq.0              |
| gicss0.spi.176 | sms.0.aes_sintrequest_p.0              |
| gicss0.spi.177 | k3_ddpa.0.ddpa_intr.0                  |
| gicss0.spi.178 | rti.15.intr_wwd.0                      |
| gicss0.spi.179 |                                        |
| gicss0.spi.180 | esm0.esm_int_cfg_lvl.0                 |
| gicss0.spi.181 | esm0.esm_int_hi_lvl.0                  |
| gicss0.spi.182 | esm0.esm_int_low_lvl.0                 |
| gicss0.spi.183 | vtm.wkup_0.therm_lvl_gt_th1_intr.0     |
| gicss0.spi.184 | vtm.wkup_0.therm_lvl_gt_th2_intr.0     |
| gicss0.spi.185 | vtm.wkup_0.therm_lvl_lt_th0_intr.0     |
| gicss0.spi.186 | mcan0.mcanss_ext_ts_rollover_lvl_int.0 |
| gicss0.spi.187 | mcan0.mcanss_mcan_lvl_int.0            |
| gicss0.spi.188 | mcan0.mcanss_mcan_lvl_int.1            |
| gicss0.spi.189 |                                        |
| gicss0.spi.190 |                                        |
| gicss0.spi.191 |                                        |
| gicss0.spi.192 | mcrc64.mcu_0.int_mcrc.0                |
| gicss0.spi.193 | mshsi2c.0.pointrpend.0                 |
| gicss0.spi.194 | mshsi2c.1.pointrpend.0                 |
| gicss0.spi.195 | mshsi2c.2.pointrpend.0                 |
| gicss0.spi.196 | mshsi2c.3.pointrpend.0                 |
| gicss0.spi.197 | mshsi2c.wkup_0.pointrpend.0            |
| gicss0.spi.198 | sms.0.aes_sintrequest_s.0              |
| gicss0.spi.199 |                                        |
| gicss0.spi.200 |                                        |
| gicss0.spi.201 | debugssaqcmpintr_level.0               |
| gicss0.spi.202 | debugssctm_level.0                     |
| gicss0.spi.203 | spsc_wrap.0.psc_allint.0               |
| gicss0.spi.204 | spi.0.intr_spi.0                       |
| gicss0.spi.205 | spi.1.intr_spi.0                       |
| gicss0.spi.206 | spi.2.intr_spi.0                       |
| gicss0.spi.207 |                                        |
| gicss0.spi.208 | spi.mcu_0.intr_spi.0                   |
| gicss0.spi.209 | spi.mcu_1.intr_spi.0                   |
| gicss0.spi.210 | uart.0.usart_irq.0                     |
| gicss0.spi.211 | uart.1.usart_irq.0                     |
| gicss0.spi.212 | uart.2.usart_irq.0                     |
| gicss0.spi.213 | uart.3.usart_irq.0                     |
| gicss0.spi.214 | uart.4.usart_irq.0                     |
| gicss0.spi.215 | uart.5.usart_irq.0                     |
| gicss0.spi.216 | uart.6.usart_irq.0                     |

Table 10-12. GIC Interrupt Connection (continued)

| Input index    | Interrupt Source             |
|----------------|------------------------------|
| gicss0.spi.217 | usart.mcu_0.usart_irq.0      |
| gicss0.spi.218 | usart.wkup_0.usart_irq.0     |
| gicss0.spi.219 |                              |
| gicss0.spi.220 | usb0.irq.0                   |
| gicss0.spi.221 | usb0.irq.1                   |
| gicss0.spi.222 | usb0.irq.2                   |
| gicss0.spi.223 | usb0.irq.3                   |
| gicss0.spi.224 | usb0.irq.4                   |
| gicss0.spi.225 | usb0.irq.5                   |
| gicss0.spi.226 | usb0.irq.6                   |
| gicss0.spi.227 | usb0.irq.7                   |
| gicss0.spi.228 | usb0.misc_level.0            |
| gicss0.spi.229 | k3_epwm.0.epwm_etint.0       |
| gicss0.spi.230 | k3_epwm.0.epwm_tripint.0     |
| gicss0.spi.231 | k3_epwm.1.epwm_etint.0       |
| gicss0.spi.232 |                              |
| gicss0.spi.233 | k3_epwm.1.epwm_tripint.0     |
| gicss0.spi.234 | k3_epwm.2.epwm_etint.0       |
| gicss0.spi.235 | k3_epwm.2.epwm_tripint.0     |
| gicss0.spi.236 |                              |
| gicss0.spi.237 |                              |
| gicss0.spi.238 |                              |
| gicss0.spi.239 |                              |
| gicss0.spi.240 |                              |
| gicss0.spi.241 |                              |
| gicss0.spi.242 |                              |
| gicss0.spi.243 |                              |
| gicss0.spi.244 | icssm0.pr1_rx_sof_intr_req.0 |
| gicss0.spi.245 | icssm0.pr1_rx_sof_intr_req.1 |
| gicss0.spi.246 | icssm0.pr1_tx_sof_intr_req.0 |
| gicss0.spi.247 | icssm0.pr1_tx_sof_intr_req.1 |
| gicss0.spi.248 |                              |
| gicss0.spi.249 |                              |
| gicss0.spi.250 |                              |
| gicss0.spi.251 |                              |
| gicss0.spi.252 | rti0.intr_wwd.0              |
| gicss0.spi.253 | rti1.intr_wwd.0              |
| gicss0.spi.254 | rti2.intr_wwd.0              |
| gicss0.spi.255 | rti3.intr_wwd.0              |
| gicss0.spi.256 | Glue_ext_intn.out.0          |
| gicss0.spi.257 |                              |
| gicss0.spi.258 | usb1.irq.0                   |
| gicss0.spi.259 | usb1.irq.1                   |
| gicss0.spi.260 | usb1.irq.2                   |
| gicss0.spi.261 | usb1.irq.3                   |

**Table 10-12. GIC Interrupt Connection (continued)**

| Input index    | Interrupt Source         |
|----------------|--------------------------|
| gicss0.spi.262 | usb1.irq.4               |
| gicss0.spi.263 | usb1.irq.5               |
| gicss0.spi.264 | usb1.irq.6               |
| gicss0.spi.265 | usb1.irq.7               |
| gicss0.spi.266 | usb1.misc_level.0        |
| gicss0.spi.267 | mcasp.0.rec_intr_pend.0  |
| gicss0.spi.268 | mcasp.0.xmit_intr_pend.0 |
| gicss0.spi.269 | mcasp.1.rec_intr_pend.0  |
| gicss0.spi.270 | mcasp.1.xmit_intr_pend.0 |
| gicss0.spi.271 | mcasp.2.rec_intr_pend.0  |
| gicss0.spi.272 | mcasp.2.xmit_intr_pend.0 |

**10.1.9 Interrupt Connections for R5FSS**
**Table 10-13. R5FSS VIM Interrupt Connection**

| Input index | Interrupt Sources                                  |
|-------------|----------------------------------------------------|
| 0           | mcu_ctrl_mmr.wkup_0.IPC_SET0_ipc_set_ipcfg.0       |
| 1           | sms.0.aes_sintrequest_p.0                          |
| 2           | sms.0.aes_sintrequest_s.0                          |
| 3           | Blazar_LBIST_Done.out.0                            |
| 4           | R5FSS.wkup_0.cpu0_exp_intr.0                       |
| 5           | R5FSS.wkup_0.commrx_level_0.0                      |
| 6           | R5FSS.wkup_0.commtx_level_0.0                      |
| 7           | sa3ss_am62.0.intaggr_vintr.6                       |
| 8           | dmss0.intaggr_vintr.72                             |
| 9           | dmss0.intaggr_vintr.73                             |
| 10          | dmss0.intaggr_vintr.74                             |
| 11          | dmss0.intaggr_vintr.75                             |
| 12          | dmss0.intaggr_vintr.76                             |
| 13          | dmss0.intaggr_vintr.77                             |
| 14          | dmss0.intaggr_vintr.78                             |
| 15          | dmss0.intaggr_vintr.79                             |
| 16          | sa3ss_am62.0.sa_ul_pka.0                           |
| 17          | sa3ss_am62.0.sa_ul_trng.0                          |
| 18          | gpio_144.mcu_0 gpio_lvl.0                          |
| 19          | sms.0.sec_out.0                                    |
| 20          | sms.0.sec_out.1                                    |
| 21          | sms.0.sec_out.2                                    |
| 22          | debug_force_deactive.out.0                         |
| 23          | icemelter.wkup_0.psc_force_power_on.0              |
| 24          | dss0.dispc_intr_req_0.0                            |
| 25          | dss0.dispc_intr_req_1.0                            |
| 26          | inverted_resetz_latched.intr.0                     |
| 27          | sdm_wakeup_deepsleep_sources.wkup_0.wakeup_event.0 |
| 28          | timer_wkup_0.timer_clkstop_wakeup.0                |

**Table 10-13. R5FSS VIM Interrupt Connection (continued)**

| Input index | Interrupt Sources                   |
|-------------|-------------------------------------|
| 29          | timer_wkup_1.timer_clkstop_wakeup.0 |
| 30          | rti.wkupdm_0.intr_wwd.0             |
| 31          |                                     |
| 32          | gpiomux_introuter.outp.0            |
| 33          | gpiomux_introuter.outp.1            |
| 34          | gpiomux_introuter.outp.2            |
| 35          | gpiomux_introuter.outp.3            |
| 36          | gpiomux_introuter.outp.4            |
| 37          | gpiomux_introuter.outp.5            |
| 38          | gpiomux_introuter.outp.6            |
| 39          | gpiomux_introuter.outp.7            |
| 40          | gpiomux_introuter.outp.8            |
| 41          | gpiomux_introuter.outp.9            |
| 42          | gpiomux_introuter.outp.10           |
| 43          | gpiomux_introuter.outp.11           |
| 44          | gpiomux_introuter.outp.12           |
| 45          | gpiomux_introuter.outp.13           |
| 46          | gpiomux_introuter.outp.14           |
| 47          | gpiomux_introuter.outp.15           |
| 48          | cmp_event_introuter.0.outp.16       |
| 49          | cmp_event_introuter.0.outp.17       |
| 50          | cmp_event_introuter.0.outp.18       |
| 51          | cmp_event_introuter.0.outp.19       |
| 52          | cmp_event_introuter.0.outp.20       |
| 53          | cmp_event_introuter.0.outp.21       |
| 54          | cmp_event_introuter.0.outp.22       |
| 55          | cmp_event_introuter.0.outp.23       |
| 56          | gpio_144.0 gpio_bank.0              |
| 57          | gpio_144.0 gpio_bank.1              |
| 58          | R5FSS.wkup_0.cpu0_pmu.0             |
| 59          | R5FSS.wkup_0.cpu0_valfiq.0          |
| 60          | R5FSS.wkup_0.cpu0_valirq.0          |
| 61          | usb0.usb_wakeup_clkstop_wakeup.0    |
| 62          | usb1.usb_wakeup_clkstop_wakeup.0    |
| 63          |                                     |
| 64          | dmss0.intaggr_vintr.40              |
| 65          | dmss0.intaggr_vintr.41              |
| 66          | dmss0.intaggr_vintr.42              |
| 67          | dmss0.intaggr_vintr.43              |
| 68          | dmss0.intaggr_vintr.44              |
| 69          | dmss0.intaggr_vintr.45              |
| 70          | dmss0.intaggr_vintr.46              |
| 71          | dmss0.intaggr_vintr.47              |
| 72          | dmss0.intaggr_vintr.48              |
| 73          | dmss0.intaggr_vintr.49              |

**Table 10-13. R5FSS VIM Interrupt Connection (continued)**

| Input index | Interrupt Sources                            |
|-------------|----------------------------------------------|
| 74          | dmss0.intaggr_vintr.50                       |
| 75          | dmss0.intaggr_vintr.51                       |
| 76          | dmss0.intaggr_vintr.52                       |
| 77          | dmss0.intaggr_vintr.53                       |
| 78          | dmss0.intaggr_vintr.54                       |
| 79          | dmss0.intaggr_vintr.55                       |
| 80          | dmss0.intaggr_vintr.56                       |
| 81          | dmss0.intaggr_vintr.57                       |
| 82          | dmss0.intaggr_vintr.58                       |
| 83          | dmss0.intaggr_vintr.59                       |
| 84          | dmss0.intaggr_vintr.60                       |
| 85          | dmss0.intaggr_vintr.61                       |
| 86          | dmss0.intaggr_vintr.62                       |
| 87          | dmss0.intaggr_vintr.63                       |
| 88          | dmss0.intaggr_vintr.64                       |
| 89          | dmss0.intaggr_vintr.65                       |
| 90          | dmss0.intaggr_vintr.66                       |
| 91          | dmss0.intaggr_vintr.67                       |
| 92          | dmss0.intaggr_vintr.68                       |
| 93          | dmss0.intaggr_vintr.69                       |
| 94          | dmss0.intaggr_vintr.70                       |
| 95          | dmss0.intaggr_vintr.71                       |
| 96          |                                              |
| 97          | rtcss.wkup_0 rtc_event_pend.0                |
| 98          |                                              |
| 99          |                                              |
| 100         |                                              |
| 101         | mainreset_request_glue.resetz_sync_stretch.0 |
| 102         | mainreset_request_glue.porz_sync_stretch.0   |
| 103         | gpmc.0.gpmc_sinterrupt.0                     |
| 104         | gpiomux_introuter_mcu0.outp.0                |
| 105         | gpiomux_introuter_mcu0.outp.1                |
| 106         | gpiomux_introuter_mcu0.outp.2                |
| 107         | gpiomux_introuter_mcu0.outp.3                |
| 108         | dcc.mcu0.intr_done_level.0                   |
| 109         | DCC_done_glue.dcc_done.0                     |
| 110         | MCUSS MCU0.rat_exp.0                         |
| 111         | sms.0.hsm_rat_exp.0                          |
| 112         | sms.0.tifs_rat_exp.0                         |
| 113         | compute_cluster0.dft_pbist_cpu.0             |
| 114         | pbist0.dft_pbist_cpu.0                       |
| 115         | pbist0.wkup0.dft_pbist_cpu.0                 |
| 116         | pbist1.dft_pbist_cpu.0                       |
| 117         |                                              |
| 118         |                                              |

**Table 10-13. R5FSS VIM Interrupt Connection (continued)**

| Input index | Interrupt Sources                            |
|-------------|----------------------------------------------|
| 119         | mcrc64.0.int_mcrc.0                          |
| 120         | icssm0.pr1_host_intr_pend.0                  |
| 121         | icssm0.pr1_host_intr_pend.1                  |
| 122         | icssm0.pr1_host_intr_pend.2                  |
| 123         | icssm0.pr1_host_intr_pend.3                  |
| 124         | icssm0.pr1_host_intr_pend.4                  |
| 125         | icssm0.pr1_host_intr_pend.5                  |
| 126         | icssm0.pr1_host_intr_pend.6                  |
| 127         | icssm0.pr1_host_intr_pend.7                  |
| 128         | soc_access_err_intr_glue.out.0               |
| 129         |                                              |
| 130         |                                              |
| 131         |                                              |
| 132         |                                              |
| 133         |                                              |
| 134         | CPSW0.evnt_pend.0                            |
| 135         | CPSW0.mdio_pend.0                            |
| 136         | CPSW0.stat_pend.0                            |
| 137         |                                              |
| 138         | timer_wkup_0.intr_pend.0                     |
| 139         | timer_wkup_1.intr_pend.0                     |
| 140         | esm_mcu0.esm_int_cfg_lvl.0                   |
| 141         | esm_mcu0.esm_int_hi_lvl.0                    |
| 142         | esm_mcu0.esm_int_low_lvl.0                   |
| 143         | mshsi2c.wkup_0.clkstop_wakeup.0              |
| 144         | uart.wkup_0.clkstop_wakeup.0                 |
| 145         | smcu_psc_wrap.wkup_0.psc_allint.0            |
| 146         | spsc_wrap.0.psc_allint.0                     |
| 147         | SoC_cbass_err_intr_glue.cbass_agg_err_intr.0 |
| 148         | mcu_cbass_intr_or_glue.out.0                 |
| 149         |                                              |
| 150         |                                              |
| 151         | ddr16ss.ddrss_controller.0                   |
| 152         | Mgasket_intr_glue.out.0                      |
| 153         | Sgasket_intr_glue.out.0                      |
| 154         | gicss0.gic_pwr0_wake_request.0               |
| 155         | gicss0.gic_pwr0_wake_request.1               |
| 156         | gicss0.gic_pwr0_wake_request.2               |
| 157         | gicss0.gic_pwr0_wake_request.3               |
| 158         |                                              |
| 159         |                                              |
| 160         |                                              |
| 161         | mmcsd0.emmcisdss_intr.0                      |
| 162         | mmcsd0.emmcisdss_intr.0                      |
| 163         | mmcsd1.emmcisdss_intr.0                      |

**Table 10-13. R5FSS VIM Interrupt Connection (continued)**

| Input index | Interrupt Sources                      |
|-------------|----------------------------------------|
| 164         | elm.0.elm_porocpsinterrupt_lvl.0       |
| 165         |                                        |
| 166         |                                        |
| 167         | esm0.esm_int_cfg_lvl.0                 |
| 168         | esm0.esm_int_hi_lvl.0                  |
| 169         | esm0.esm_int_low_lvl.0                 |
| 170         | icssm0.iso_reset_protocol_ack.0        |
| 171         | fss0.ospi0_lvl_intr.0                  |
| 172         |                                        |
| 173         |                                        |
| 174         |                                        |
| 175         | R5FSS.wkup_0.cpu0_cti.0                |
| 176         |                                        |
| 177         | k3_ddpa.0.ddpa_intr.0                  |
| 178         |                                        |
| 179         |                                        |
| 180         |                                        |
| 181         | ddr16ss.ddrss_pll_freq_change_req.0    |
| 182         |                                        |
| 183         | vtm.wkup_0.therm_lvl_gt_th1_intr.0     |
| 184         | vtm.wkup_0.therm_lvl_gt_th2_intr.0     |
| 185         | vtm.wkup_0.therm_lvl_lt_th0_intr.0     |
| 186         | mcan0.mcanss_ext_ts_rollover_lvl_int.0 |
| 187         | mcan0.mcanss_mcan_lvl_int.0            |
| 188         | mcan0.mcanss_mcan_lvl_int.1            |
| 189         |                                        |
| 190         | mshsi2c.wkup_0.pointrpend.0            |
| 191         |                                        |
| 192         | mcrc64.mcu_0.int_mcrc.0                |
| 193         | mshsi2c.0.pointrpend.0                 |
| 194         | mshsi2c.1.pointrpend.0                 |
| 195         | mshsi2c.2.pointrpend.0                 |
| 196         | mshsi2c.3.pointrpend.0                 |
| 197         | mshsi2c.mcu_0.pointrpend.0             |
| 198         |                                        |
| 199         |                                        |
| 200         |                                        |
| 201         | debugssaqcmpintr_level.0               |
| 202         | debugssctm_level.0                     |
| 203         | Glue_ext_intr.out.0                    |
| 204         | spi.0.intr_spi.0                       |
| 205         | spi.1.intr_spi.0                       |
| 206         | spi.2.intr_spi.0                       |
| 207         | spi.mcu_0.intr_spi.0                   |
| 208         | spi.mcu_1.intr_spi.0                   |

**Table 10-13. R5FSS VIM Interrupt Connection (continued)**

| Input index | Interrupt Sources            |
|-------------|------------------------------|
| 209         |                              |
| 210         | usart.0.usart_irq.0          |
| 211         | usart.1.usart_irq.0          |
| 212         | usart.2.usart_irq.0          |
| 213         | usart.3.usart_irq.0          |
| 214         | usart.4.usart_irq.0          |
| 215         | usart.5.usart_irq.0          |
| 216         | usart.6.usart_irq.0          |
| 217         | usart.mcu_0.usart_irq.0      |
| 218         |                              |
| 219         | usart.wkup_0.usart_irq.0     |
| 220         | usb0.irq.0                   |
| 221         | usb0.irq.1                   |
| 222         | usb0.irq.2                   |
| 223         | usb0.irq.3                   |
| 224         | usb0.irq.4                   |
| 225         | usb0.irq.5                   |
| 226         | usb0.irq.6                   |
| 227         | usb0.irq.7                   |
| 228         | usb0.misc_level.0            |
| 229         |                              |
| 230         | usb1.irq.0                   |
| 231         | usb1.irq.1                   |
| 232         | usb1.irq.2                   |
| 233         | usb1.irq.3                   |
| 234         | usb1.irq.4                   |
| 235         | usb1.irq.5                   |
| 236         | usb1.irq.6                   |
| 237         | usb1.irq.7                   |
| 238         | usb1.misc_level.0            |
| 239         |                              |
| 240         |                              |
| 241         |                              |
| 242         |                              |
| 243         |                              |
| 244         | icssm0.pr1_rx_sof_intr_req.0 |
| 245         | icssm0.pr1_rx_sof_intr_req.1 |
| 246         | icssm0.pr1_tx_sof_intr_req.0 |
| 247         | icssm0.pr1_tx_sof_intr_req.1 |
| 248         |                              |
| 249         |                              |
| 250         |                              |
| 251         | IO_swakeup.CAN_USART_IO.0    |
| 252         | IO_swakeup.IO.0              |
| 253         | IO_swakeup.MCU_IO.0          |

**Table 10-13. R5FSS VIM Interrupt Connection (continued)**

| Input index | Interrupt Sources                  |
|-------------|------------------------------------|
| 254         | mailbox1.0.mailbox_cluster0_pend.1 |
| 255         | mailbox1.0.mailbox_cluster0_pend.3 |

### 10.1.10 Interrupt Connection for HSM

#### 10.1.10.1 HSM0\_INTERRUPT\_MAP

**Table 10-14. HSM0\_INTERRUPT\_MAP Memory Map**

| Interrupt Input Line | Interrupt ID | Source Interrupt                          |
|----------------------|--------------|-------------------------------------------|
| HSM0_NVIC_IN_8       | 8            | SMS0_DMTIMER_0_INTR_PEND_0                |
| HSM0_NVIC_IN_10      | 10           | SMS0_DMTIMER_1_INTR_PEND_0                |
| HSM0_NVIC_IN_11      | 11           | SMS0_RAT_0_EXP_INTR_0                     |
| HSM0_NVIC_IN_14      | 14           | INVERTED_WKUP_RDY_OUT_0                   |
| HSM0_NVIC_IN_16      | 16           | SMS0_RTI_0_WDG_INTR_4                     |
| HSM0_NVIC_IN_17      | 17           | SMS0_RTI_0_WDG_INTR_0                     |
| HSM0_NVIC_IN_18      | 18           | SMS0_RTI_0_WDG_INTR_1                     |
| HSM0_NVIC_IN_19      | 19           | SMS0_RTI_0_WDG_INTR_2                     |
| HSM0_NVIC_IN_20      | 20           | SMS0_RTI_0_WDG_INTR_3                     |
| HSM0_NVIC_IN_32      | 32           | SMS0_DMTIMER_2_INTR_PEND_0                |
| HSM0_NVIC_IN_34      | 34           | SMS0_DMTIMER_3_INTR_PEND_0                |
| HSM0_NVIC_IN_36      | 36           | SMS0_DBG_AUTH_0_DBG_AUTH_0                |
| HSM0_NVIC_IN_38      | 38           | SMS0_AESEIP38T_0_AES_SINTREQUEST_S_0      |
| HSM0_NVIC_IN_39      | 39           | SMS0_AESEIP38T_0_AES_SINTREQUEST_P_0      |
| HSM0_NVIC_IN_51      | 51           | CMP_EVENT_INROUTER0_OUTP_38               |
| HSM0_NVIC_IN_52      | 52           | CMP_EVENT_INROUTER0_OUTP_39               |
| HSM0_NVIC_IN_53      | 53           | CMP_EVENT_INROUTER0_OUTP_40               |
| HSM0_NVIC_IN_54      | 54           | CMP_EVENT_INROUTER0_OUTP_41               |
| HSM0_NVIC_IN_60      | 60           | ICSSM0_PR1_HOST_INTR_PEND_0               |
| HSM0_NVIC_IN_61      | 61           | ICSSM0_PR1_HOST_INTR_PEND_1               |
| HSM0_NVIC_IN_62      | 62           | ICSSM0_PR1_HOST_INTR_PEND_2               |
| HSM0_NVIC_IN_63      | 63           | ICSSM0_PR1_HOST_INTR_PEND_3               |
| HSM0_NVIC_IN_64      | 64           | ICSSM0_PR1_HOST_INTR_PEND_4               |
| HSM0_NVIC_IN_65      | 65           | ICSSM0_PR1_HOST_INTR_PEND_5               |
| HSM0_NVIC_IN_66      | 66           | ICSSM0_PR1_HOST_INTR_PEND_6               |
| HSM0_NVIC_IN_67      | 67           | ICSSM0_PR1_HOST_INTR_PEND_7               |
| HSM0_NVIC_IN_68      | 68           | EPWM0_EPWM_ETINT_0                        |
| HSM0_NVIC_IN_69      | 69           | EPWM1_EPWM_ETINT_0                        |
| HSM0_NVIC_IN_70      | 70           | EPWM2_EPWM_ETINT_0                        |
| HSM0_NVIC_IN_71      | 71           | EQEP0_EQEP_INT_0                          |
| HSM0_NVIC_IN_72      | 72           | EQEP1_EQEP_INT_0                          |
| HSM0_NVIC_IN_73      | 73           | EQEP2_EQEP_INT_0                          |
| HSM0_NVIC_IN_74      | 74           | ECAP0_ECAP_INT_0                          |
| HSM0_NVIC_IN_75      | 75           | ECAP1_ECAP_INT_0                          |
| HSM0_NVIC_IN_76      | 76           | ECAP2_ECAP_INT_0                          |
| HSM0_NVIC_IN_77      | 77           | MAILBOX0_CLUSTER_0_MAILBOX_CLUSTER_PEND_3 |

Table 10-14. HSM0\_INTERRUPT\_MAP Memory Map (continued)

| Interrupt Input Line | Interrupt ID | Source Interrupt                                     |
|----------------------|--------------|------------------------------------------------------|
| HSM0_NVIC_IN_78      | 78           | WKUP MCU GPIOMUX_INROUTER0_OUTP_4                    |
| HSM0_NVIC_IN_79      | 79           | WKUP MCU GPIOMUX_INROUTER0_OUTP_5                    |
| HSM0_NVIC_IN_80      | 80           | WKUP MCU GPIOMUX_INROUTER0_OUTP_6                    |
| HSM0_NVIC_IN_81      | 81           | WKUP MCU GPIOMUX_INROUTER0_OUTP_7                    |
| HSM0_NVIC_IN_83      | 83           | MCRC64_0_INT_MCRC_0                                  |
| HSM0_NVIC_IN_84      | 84           | MCSPI0_INTR_SPI_0                                    |
| HSM0_NVIC_IN_85      | 85           | MCU_MCSPI0_INTR_SPI_0                                |
| HSM0_NVIC_IN_86      | 86           | MCU_MCSPI1_INTR_SPI_0                                |
| HSM0_NVIC_IN_87      | 87           | MCSPI1_INTR_SPI_0                                    |
| HSM0_NVIC_IN_88      | 88           | MCSPI2_INTR_SPI_0                                    |
| HSM0_NVIC_IN_89      | 89           | UART0_USART_IRQ_0                                    |
| HSM0_NVIC_IN_90      | 90           | UART1_USART_IRQ_0                                    |
| HSM0_NVIC_IN_91      | 91           | UART2_USART_IRQ_0                                    |
| HSM0_NVIC_IN_92      | 92           | UART3_USART_IRQ_0                                    |
| HSM0_NVIC_IN_93      | 93           | UART4_USART_IRQ_0                                    |
| HSM0_NVIC_IN_94      | 94           | UART5_USART_IRQ_0                                    |
| HSM0_NVIC_IN_95      | 95           | UART6_USART_IRQ_0                                    |
| HSM0_NVIC_IN_96      | 96           | MCU_UART0_USART_IRQ_0                                |
| HSM0_NVIC_IN_97      | 97           | I2C0_PONTRPEND_0                                     |
| HSM0_NVIC_IN_98      | 98           | I2C1_PONTRPEND_0                                     |
| HSM0_NVIC_IN_99      | 99           | I2C2_PONTRPEND_0                                     |
| HSM0_NVIC_IN_100     | 100          | I2C3_PONTRPEND_0                                     |
| HSM0_NVIC_IN_101     | 101          | MCU_I2C0_PONTRPEND_0                                 |
| HSM0_NVIC_IN_102     | 102          | MCAN0_COMMON_0_MCANSS_EXT_TS_ROLLOVER_LVL_INT_0      |
| HSM0_NVIC_IN_103     | 103          | MCAN0_COMMON_0_MCANSS_MCAN_LVL_INT_0                 |
| HSM0_NVIC_IN_104     | 104          | MCAN0_COMMON_0_MCANSS_MCAN_LVL_INT_1                 |
| HSM0_NVIC_IN_105     | 105          | MCU_MCAN1_COMMON_0_MCANSS_EXT_TS_ROLLOVER_LVL_IN_T_0 |
| HSM0_NVIC_IN_106     | 106          | MCU_MCAN1_COMMON_0_MCANSS_MCAN_LVL_INT_0             |
| HSM0_NVIC_IN_107     | 107          | MCU_MCAN1_COMMON_0_MCANSS_MCAN_LVL_INT_1             |
| HSM0_NVIC_IN_108     | 108          | MCU_MCAN0_COMMON_0_MCANSS_EXT_TS_ROLLOVER_LVL_IN_T_0 |
| HSM0_NVIC_IN_109     | 109          | MCU_MCAN0_COMMON_0_MCANSS_MCAN_LVL_INT_0             |
| HSM0_NVIC_IN_110     | 110          | MCU_MCAN0_COMMON_0_MCANSS_MCAN_LVL_INT_1             |
| HSM0_NVIC_IN_111     | 111          | MAIN_DCC_DONE_GLUE_DCC_DONE_0                        |
| HSM0_NVIC_IN_112     | 112          | MCU_DCC0_INTR_DONE_LEVEL_0                           |
| HSM0_NVIC_IN_113     | 113          | MCASP0_XMIT_INTR_PEND_0                              |
| HSM0_NVIC_IN_114     | 114          | MCASP1_XMIT_INTR_PEND_0                              |
| HSM0_NVIC_IN_115     | 115          | MCASP2_XMIT_INTR_PEND_0                              |
| HSM0_NVIC_IN_116     | 116          | MCASP0_REC_INTR_PEND_0                               |
| HSM0_NVIC_IN_117     | 117          | MCASP1_REC_INTR_PEND_0                               |
| HSM0_NVIC_IN_118     | 118          | MCASP2_REC_INTR_PEND_0                               |
| HSM0_NVIC_IN_152     | 152          | SMS0_RAT_1_EXP_INTR_0                                |
| HSM0_NVIC_IN_155     | 155          | SMS0_RTI_1_WDG_INTR_4                                |
| HSM0_NVIC_IN_156     | 156          | SMS0_RTI_1_WDG_INTR_0                                |
| HSM0_NVIC_IN_157     | 157          | SMS0_RTI_1_WDG_INTR_1                                |

**Table 10-14. HSM0\_INTERRUPT\_MAP Memory Map (continued)**

| Interrupt Input Line | Interrupt ID | Source Interrupt                                  |
|----------------------|--------------|---------------------------------------------------|
| HSM0_NVIC_IN_158     | 158          | SMS0_RTI_1_WDG_INTR_2                             |
| HSM0_NVIC_IN_159     | 159          | SMS0_RTI_1_WDG_INTR_3                             |
| HSM0_NVIC_IN_176     | 176          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_136           |
| HSM0_NVIC_IN_177     | 177          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_137           |
| HSM0_NVIC_IN_178     | 178          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_138           |
| HSM0_NVIC_IN_179     | 179          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_139           |
| HSM0_NVIC_IN_180     | 180          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_140           |
| HSM0_NVIC_IN_181     | 181          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_141           |
| HSM0_NVIC_IN_182     | 182          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_142           |
| HSM0_NVIC_IN_183     | 183          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_143           |
| HSM0_NVIC_IN_184     | 184          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_144           |
| HSM0_NVIC_IN_185     | 185          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_145           |
| HSM0_NVIC_IN_186     | 186          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_146           |
| HSM0_NVIC_IN_187     | 187          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_147           |
| HSM0_NVIC_IN_188     | 188          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_148           |
| HSM0_NVIC_IN_189     | 189          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_149           |
| HSM0_NVIC_IN_190     | 190          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_150           |
| HSM0_NVIC_IN_191     | 191          | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_151           |
| HSM0_NVIC_IN_192     | 192          | MAINRESET_REQUEST_GLUE_MAIN_PORZ_SYNC_STRETCH_0   |
| HSM0_NVIC_IN_193     | 193          | MAINRESET_REQUEST_GLUE_MAIN_RESETZ_SYNC_STRETCH_0 |
| HSM0_NVIC_IN_194     | 194          | ICSSM0_ISO_RESET_PROTOCOL_ACK_0                   |
| HSM0_NVIC_IN_195     | 195          | PBIST0_DFT_PBIST_CPU_0                            |
| HSM0_NVIC_IN_196     | 196          | WKUP_VTM0_COMMON_0_THERM_LVL_GT_TH1_INTR_0        |
| HSM0_NVIC_IN_197     | 197          | WKUP_VTM0_COMMON_0_THERM_LVL_LT_TH0_INTR_0        |
| HSM0_NVIC_IN_198     | 198          | WKUP_VTM0_COMMON_0_THERM_LVL_GT_TH2_INTR_0        |
| HSM0_NVIC_IN_199     | 199          | ESM0_ESM_INT_CFG_LVL_0                            |
| HSM0_NVIC_IN_200     | 200          | ESM0_ESM_INT_HI_LVL_0                             |
| HSM0_NVIC_IN_201     | 201          | ESM0_ESM_INT_LOW_LVL_0                            |
| HSM0_NVIC_IN_202     | 202          | CBASS_FW0_DEFAULT_ERR_INTR_0                      |
| HSM0_NVIC_IN_203     | 203          | GICSS0_GIC_PWR0_WAKE_REQUEST_0                    |
| HSM0_NVIC_IN_204     | 204          | GICSS0_GIC_PWR0_WAKE_REQUEST_1                    |
| HSM0_NVIC_IN_205     | 205          | DDR16SS0_DDRSS_PLL_FREQ_CHANGE_REQ_0              |
| HSM0_NVIC_IN_206     | 206          | SA3_SS0_SA_UL_0_SA_UL_PKA_0                       |
| HSM0_NVIC_IN_207     | 207          | SA3_SS0_SA_UL_0_SA_UL_TRNG_0                      |
| HSM0_NVIC_IN_208     | 208          | MAIN_GPIOMUX_INTROUTER0_OUTP_0                    |
| HSM0_NVIC_IN_209     | 209          | MAIN_GPIOMUX_INTROUTER0_OUTP_1                    |
| HSM0_NVIC_IN_210     | 210          | MAIN_GPIOMUX_INTROUTER0_OUTP_2                    |
| HSM0_NVIC_IN_211     | 211          | MAIN_GPIOMUX_INTROUTER0_OUTP_3                    |
| HSM0_NVIC_IN_212     | 212          | MAIN_GPIOMUX_INTROUTER0_OUTP_4                    |
| HSM0_NVIC_IN_213     | 213          | MAIN_GPIOMUX_INTROUTER0_OUTP_5                    |
| HSM0_NVIC_IN_214     | 214          | MAIN_GPIOMUX_INTROUTER0_OUTP_6                    |
| HSM0_NVIC_IN_215     | 215          | MAIN_GPIOMUX_INTROUTER0_OUTP_7                    |
| HSM0_NVIC_IN_216     | 216          | SA3_SS0_INTAGGR_0_INTAGGR_VINTR_0                 |
| HSM0_NVIC_IN_217     | 217          | SA3_SS0_INTAGGR_0_INTAGGR_VINTR_1                 |
| HSM0_NVIC_IN_218     | 218          | SA3_SS0_INTAGGR_0_INTAGGR_VINTR_2                 |

**Table 10-14. HSM0\_INTERRUPT\_MAP Memory Map (continued)**

| Interrupt Input Line | Interrupt ID | Source Interrupt                  |
|----------------------|--------------|-----------------------------------|
| HSM0_NVIC_IN_219     | 219          | SA3_SS0_INTAGGR_0_INTAGGR_VINTR_3 |
| HSM0_NVIC_IN_220     | 220          | SOC_ACCESS_ERR_INTR_GLUE_OUT_0    |
| HSM0_NVIC_IN_221     | 221          | BLAZAR_LBIST_DONE_OUT_0           |
| HSM0_NVIC_IN_222     | 222          | GICSS0_GIC_PWR0_WAKE_REQUEST_2    |
| HSM0_NVIC_IN_223     | 223          | GICSS0_GIC_PWR0_WAKE_REQUEST_3    |
| HSM0_NVIC_IN_224     | 224          | FSS0_OSPI_0_OSPI_LVL_INTR_0       |
| HSM0_NVIC_IN_227     | 227          | FSS0_FSAS_0_OTFE_INTR_ERR_PEND_0  |
| HSM0_NVIC_IN_229     | 229          | COMPUTE_CLUSTER0_DFT_PBIST_CPU_0  |
| HSM0_NVIC_IN_234     | 234          | PBIST1_DFT_PBIST_CPU_0            |
| HSM0_NVIC_IN_235     | 235          | WKUP_PBIST0_DFT_PBIST_CPU_0       |
| HSM0_NVIC_IN_238     | 238          | PSC0_PSC_0_PSC_ALLINT_0           |
| HSM0_NVIC_IN_239     | 239          | WKUP_PSC0_PSC_ALLINT_0            |

### 10.1.11 Interrupt Connection for ICSSM

#### 10.1.11.1 ICSSM0\_INTERRUPT\_MAP

**Table 10-15. ICSSM Latch and Capture Map**

| Interrupt ID | Source Interrupt                 |
|--------------|----------------------------------|
| 0            | TIMESYNC_EVENT_ROUTER0_OUTL_8    |
| 0            | TIMESYNC_EVENT_ROUTER0_OUTL_9    |
| 0            | MAIN_GPIOMUX_INTRROUTER0_OUTP_16 |
| 1            | MAIN_GPIOMUX_INTRROUTER0_OUTP_17 |
| 2            | MAIN_GPIOMUX_INTRROUTER0_OUTP_18 |
| 3            | MAIN_GPIOMUX_INTRROUTER0_OUTP_19 |
| 4            | MAIN_GPIOMUX_INTRROUTER0_OUTP_20 |
| 5            | MAIN_GPIOMUX_INTRROUTER0_OUTP_21 |

**Table 10-16. ICSSM0\_INTERRUPT\_MAP Memory Map**

| Interrupt ID | Source Interrupt          |
|--------------|---------------------------|
| 0            | pr1_ecc_err_intr          |
| 1            | pr1_pru0_r31_status_cnt16 |
| 2            | pr1_pru1_r31_status_cnt16 |
| 3            | reset_iso_req             |
| 4            | pr1_uart0_urxevt_intr_req |
| 5            | pr1_uart0_utxevt_intr_req |
| 6            | pr1_uart0_uint_intr_req   |
| 7            | pr1_iep_tim_cap_cmp_pend  |
| 8            | digio_event_req           |
| 9            | pd_wd_exp_pend            |
| 10           | pdi_wd_exp_pend           |
| 11           | latch1_in(input to ICSS)  |
| 12           | latch0_in(input to ICSS)  |
| 13           | sync1_out_pend            |
| 14           | sync0_out_pend            |
| 15           | pr1_ecap_intr_req         |

**Table 10-16. ICSSM0\_INTERRUPT\_MAP Memory Map (continued)**

| Interrupt ID | Source Interrupt                                      |
|--------------|-------------------------------------------------------|
| 16           | pr1_pru_mst_intr0_intr_req                            |
| 17           | pr1_pru_mst_intr1_intr_req                            |
| 18           | pr1_pru_mst_intr2_intr_req                            |
| 19           | pr1_pru_mst_intr3_intr_req                            |
| 20           | pr1_pru_mst_intr4_intr_req                            |
| 21           | pr1_pru_mst_intr5_intr_req                            |
| 22           | pr1_pru_mst_intr6_intr_req                            |
| 23           | pr1_pru_mst_intr7_intr_req                            |
| 24           | pr1_pru_mst_intr8_intr_req                            |
| 25           | pr1_pru_mst_intr9_intr_req                            |
| 26           | pr1_pru_mst_intr10_intr_req                           |
| 27           | pr1_pru_mst_intr11_intr_req                           |
| 28           | pr1_pru_mst_intr12_intr_req                           |
| 29           | pr1_pru_mst_intr13_intr_req                           |
| 30           | pr1_pru_mst_intr14_intr_req                           |
| 31           | pr1_pru_mst_intr15_intr_req                           |
| 32           | UART1_USART_IRQ_0 <sup>(1)</sup>                      |
| 33           | MCASP1_XMIT_INTR_PEND_0 <sup>(1)</sup>                |
| 34           | MCASP1_REC_INTR_PEND_0 <sup>(1)</sup>                 |
| 35           | ECAP1_ECAP_INT_0 <sup>(1)</sup>                       |
| 36           | ECAP2_ECAP_INT_0 <sup>(1)</sup>                       |
| 37           | EPWM2_EPWM_ETINT_0 <sup>(1)</sup>                     |
| 38           | WKUP_MCU_GPIOMUX_INTROUTER0_OUTP_12 <sup>(1)</sup>    |
| 39           | TIMESYNC_EVENT_ROUTER0_OUTL_24 <sup>(1)</sup>         |
| 40           | TIMESYNC_EVENT_ROUTER0_OUTL_25 <sup>(1)</sup>         |
| 41           | I2C0_PONTRPEND_0 <sup>(1)</sup>                       |
| 42           | ECAP0_ECAP_INT_0 <sup>(1)</sup>                       |
| 43           | EPWM0_EPWM_ETINT_0 <sup>(1)</sup>                     |
| 44           | MCSPI0_INTR_SPI_0 <sup>(1)</sup>                      |
| 45           | EQEP0_EQEP_INT_0 <sup>(1)</sup>                       |
| 46           | EPWM1_EPWM_ETINT_0 <sup>(1)</sup>                     |
| 47           | MCSPI1_INTR_SPI_0 <sup>(1)</sup>                      |
| 48           | EQEP1_EQEP_INT_0 <sup>(1)</sup>                       |
| 49           | EQEP2_EQEP_INT_0 <sup>(1)</sup>                       |
| 50           | MAIN_GPIOMUX_INTROUTER0_OUTP_32 <sup>(1)</sup>        |
| 51           | UART0_USART_IRQ_0 <sup>(1)</sup>                      |
| 52           | UART2_USART_IRQ_0 <sup>(1)</sup>                      |
| 53           | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_80 <sup>(1)</sup> |
| 54           | MCASP0_REC_INTR_PEND_0 <sup>(1)</sup>                 |
| 55           | MCASP0_XMIT_INTR_PEND_0 <sup>(1)</sup>                |
| 56           | PWM_TRIP_OR_GLUE_OUT_0 <sup>(1)</sup>                 |
| 57           | MAIN_GPIOMUX_INTROUTER0_OUTP_33 <sup>(1)</sup>        |
| 58           | FSS0_OSPI_0_OSPI_LVL_INTR_0 <sup>(1)</sup>            |
| 59           | MCASP2_XMIT_INTR_PEND_0 <sup>(1)</sup>                |
| 60           | MCASP2_REC_INTR_PEND_0 <sup>(1)</sup>                 |

Table 10-16. ICSSM0\_INTERRUPT\_MAP Memory Map (continued)

| Interrupt ID | Source Interrupt                                      |
|--------------|-------------------------------------------------------|
| 61           | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_81 <sup>(1)</sup> |
| 62           | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_82 <sup>(1)</sup> |
| 63           | DMASS0_INTAGGR_0_INTAGGR_VINTR_PEND_83 <sup>(1)</sup> |

(1) SoC level only.

### 10.1.12 Interrupt Connections Summary

Table 10-17. Interrupt Connections Summary

|                                 | GIC | R5FSS | MCUSS | TIFS/HS<br>M | ICSSM |
|---------------------------------|-----|-------|-------|--------------|-------|
| SPI: MAIN domain                | Y   | Y     | N     | Y            | Y     |
| SPI: MCU domain                 | Y   | Y     | Y     | Y            | N     |
| USART: MAIN domain              | Y   | Y     | N     | Y            | Y     |
| UART: WKUP domain               | Y   | Y     | N     | N            | N     |
| UART:MCU domain                 | Y   | Y     | Y     | Y            | N     |
| I2C: MAIN domain                | Y   | Y     | N     | Y            | Y     |
| I2C: WKUP domain                | Y   | Y     | N     | N            | N     |
| I2C: MCU                        | Y   | Y     | Y     | Y            | N     |
| TIMER: MAIN                     | Y   | N     | N     | N            | N     |
| TIMER: WKUP                     | N   | Y     | N     | N            | N     |
| TIMER:MCU                       | N   | N     | Y     | N            | N     |
| MCAN: MAIN                      | Y   | Y     | N     | Y            | N     |
| MCAN: MCU                       | N   | N     | Y     | Y            | N     |
| ECAP                            | Y   | N     | N     | Y            | Y     |
| EQEP                            | Y   | N     | N     | Y            | Y     |
| PWM                             | Y   | N     | Y     | Y            | Y     |
| McASP                           | Y   | N     | N     | Y            | Y     |
| USB                             | Y   | Y     | N     | N            | N     |
| EMMC4b                          | Y   | Y     | N     | N            | N     |
| EMMC8b                          | Y   | Y     | N     | N            | N     |
| GPMC                            | Y   | Y     | N     | N            | N     |
| ELM                             | Y   | Y     | N     | N            | N     |
| MCRC: MAIN                      | Y   | Y     | N     | Y            | N     |
| MCRC:MCU                        | Y   | Y     | Y     | N            | N     |
| debug_cell                      | Y   | Y     | N     | N            | N     |
| wakeup signals from peripherals | N   | Y     | N     | N            | N     |
| GIC wake up                     | N   | Y     | N     | Y            | N     |
| DDR frequency scaling           | Y   | Y     | N     | Y            | N     |
| Other DDR interrupt             | Y   | Y     | N     | N            | N     |
| FSS                             | Y   | Y     | N     | Y            | Y     |

**Table 10-17. Interrupt Connections Summary (continued)**

|                             | GIC | R5FSS | MCUSS | TIFS/HS<br>M | ICSSM                                 |
|-----------------------------|-----|-------|-------|--------------|---------------------------------------|
| CPSW                        | Y   | Y     | N     | N            | N                                     |
| DSS                         | Y   | Y     | Y     | N            | N                                     |
| CSI_RX                      | Y   | Y     | N     | N            | N                                     |
| MAIN DMSS                   | Y   | Y     | Y     | Y            | Y                                     |
| DMSS_HSM                    | Y   | Y     | Y     | Y            | N                                     |
| DDPA                        | Y   | Y     | Y     | Y            | N                                     |
| VTM                         | Y   | Y     | Y     | Y            | N                                     |
| RTC                         | Y   | Y     | N     | N            | N                                     |
| ESM: MAIN                   | Y   | Y     | Y     | Y            | N                                     |
| ESM:MCU                     | Y   | Y     | Y     | Y            | N                                     |
| sa3_UL                      | Y   | Y     | N     | Y            | N                                     |
| GPIO: MAIN                  | Y   | Y     | Y     | Y            | Both as Capture inputs and interrupts |
| GPIO: MCU                   | Y   | Y     | Y     | Y            | Only as interrupts                    |
| PBIST:MAIN                  | N   | Y     | N     | Y            | N                                     |
| PBIST: WKUP                 | N   | Y     | N     | Y            | N                                     |
| PBIST:MCU                   | N   | Y     | N     | Y            | N                                     |
| DCC: MAIN                   | Y   | Y     | N     | Y            | N                                     |
| DCC:MCU                     | N   | Y     | Y     | Y            | N                                     |
| ICSSM                       |     |       | Y     |              | n/a                                   |
| PSC MAIN                    | Y   | Y     | N     | Y            | N                                     |
| PSC:MCU                     | N   | Y     | Y     | Y            | N                                     |
| SMS                         | Y   | Y     | Y     | N/A          | N                                     |
| Timeout gasket              | N   | Y     | Y     | N            | N                                     |
| CMP_event_introute output   | Y   | Y     | N     | Y            | N                                     |
| timesynch Intrrouter output | Y   | Y     | N     | Y            | Y                                     |
| MAILBOX                     | Y   | Y     | Y     | Y            | Y                                     |

Chapter 11  
**Data Movement Architecture**

---



This chapter describes the data movement architecture of the device.

|                                               |     |
|-----------------------------------------------|-----|
| 11.1 Data Movement Architecture Overview..... | 867 |
| 11.2 Data Movement Subsystem (DMSS).....      | 928 |
| 11.3 Peripheral DMA (PDMA).....               | 958 |

## 11.1 Data Movement Architecture Overview

This chapter is a high-level summary of the data movement architecture implemented in the device.

### 11.1.1 Overview

The primary goal of the device Data Movement Architecture and related Subsystems is to ensure that data can be efficiently transferred from a producer to a consumer while meeting the real time requirements of the system can be met.

The Data Movement Subsystem (DMSS) aims to facilitate direct memory access (DMA) and provides a consistent Application Programming Interface (API) to the host software.

Data movement tasks are commonly offloaded from the host processor to peripheral hardware to increase system performance. Significant performance gains may result from careful design of the interface between the host software and the underlying acceleration hardware. In networking applications, packet transmission and reception are critical tasks. In general purpose compute, ping pong buffer prefetch and store are critical tasks as well as general mis-aligned block copy operations.

The design goals for the device Data Movement Architecture and are as follows:

- Minimize cost
- Minimize host overhead
- Maximize memory use efficiency
- Maximize bus burst efficiency
- Maximize symmetry between transmit/receive operations
- Maximize scalability for number of connections / buffer sizes / queue sizes / protocols supported
- Minimize protocol specific features
- Minimize complexity

#### 11.1.1.1 Ring Accelerator (RINGACC)

The ring accelerator (RINGACC or RA) is a hardware module that is responsible for accelerating management of various types of queues in the system. The RINGACC accelerates passing of packets between a producer and consumer in normal system memory (including cached memory). The RINGACC is capable of accelerating the read/write pointer maintenance and occupancy tracking operations.

The ring accelerator operates like a bus infrastructure bridge in that it passes transactions through it between a source and destination interface. As transactions are passed, the RINGACC modifies the address, byte count, and transaction identifiers and internally updates the occupancies/pointers.

Each queue that the RINGACC provides can operate in either exposed-ring-mode or private-queue-mode.

- The exposed ring mode allows software to directly access the underlying ring structure to add or remove items from the tail or head of the ring respectively. Whenever items are added or removed from a ring, the host software is required to write to a corresponding doorbell register (RINGRT[a]\_RT\_DB) to increment or decrement the ring occupancy. When using the exposed ring mode, no proxy is required between the software and the RINGACC but all queue add operations require a memory fence to be performed to ensure that the data has landed in a snoopable cache before the doorbell register is written.
- The private queue mode provides an abstract view of the ring so that the host software does not need to know the actual physical address location or current read or write indexes of the ring. The private queue mode provides a memory window for each ring which when written redirects the write to the address pointed to by the write pointer and when read redirects the read to the address pointed to by the read pointer. The same address range is always used to push or pop elements from a given queue.

Rings are an implementation of a logical queue with the following limitations:

- Each ring has a finite size. When rings are used in exposed ring mode the following conditions apply:
  - A separate operation is required to write/read the contents of a ring and to update the occupancy of the ring

- It is not straightforward to allow multiple producers to write to a ring or multiple consumers to read from a ring. Additional synchronization and pointer passing is required since rings require software to manage one of the pointers for the queue.
- An exposed ring cannot be used when software or hardware needs to both read and write the same queue (such as for a DMA RX free queue where errors can have the DMA write the element back onto the same RX free queue). Since software owns one side of the pointers and hardware owns the other, they cannot be kept coherent if either side needs to update either at any time.

The RINGACC allows each ring to be configured to a different primary element size. Element sized chunks of data are placed onto and retrieved from rings when queuing or de-queueing occurs. Element sizes can be as small as 4 bytes or as large as 256 bytes.

#### 11.1.1.2 Secure Proxy (SEC\_PROXY)

A proxy provides a mechanism for software to access the RINGACC coherently when the processor does not support large bursts. The RINGACC requires a single burst for each operation so that it maintains atomicity and coherence by relying on the atomicity of the bursts on the bus interconnect fabric, since it only delivers a single burst to the RINGACC before the next. Since processors are usually limited in the size of a burst they can deliver natively, such as 32 to 128 bits, they cannot be used directly with the data access region of the RINGACC for larger element sizes. The proxy solves this gap by providing a temporary space for the software to form a larger burst of data before it is sent to the RINGACC. The proxy allows smaller processor accesses to the data and only forwards to the RINGACC when the entire data burst is complete, as directed by the software.

Each proxy hardware can support multiple threads of software (whether on the same or different processors) operating on bursts at the same time, and they do not interfere with each other, as long as each thread of software only operates on its thread in the proxy. Each proxy thread also supports access to any RINGACC queue via different offsets similar to how the RINGACC provides access to the queues via different offsets.

A special version of a proxy is the Secure Proxy that provides secured access to RINGACC queues for communication to the security initiator of the system. It provides basically the same function as a normal proxy. The data burst size is fixed for message sizes to the security initiator, so there is no support for all the element sizes of the RINGACC. The security initiator locks down the RINGACC queue to access and direction for each proxy thread so that the software cannot access anything they shouldn't, so the software only sees a single queue (unlike the normal proxy), and any attempts to access another queue or access it in violation of how the security initiator defined and an error will be flagged. This allows for a much more controlled setup for passing messages to the security initiator.

#### 11.1.1.3 Interrupt Aggregator (INTAGGR)

The interrupt aggregator (INTAGGR or INTA) is a hardware module which provides a persistent view of the real time status of various DMA components within the overall SoC DMA system. The main function of the module is to convert between 'global events' (assertion and de-assertion events transmitted on the event-transport-lane bus) and 'local events' (level sensitive signals on output, and level or edge sensitive signals on input).

The INTA block provides the following functions:

- Conversion of local event signal lines into global events
- Performing an 'Y-split' operation of global events
- Counting global events
- Steering and aggregation of global events into specified bit positions in one of N interrupt cause registers
- SoC interrupt-architecture-compliant set/clear and mask set/clear functionality to cover interrupt cause registers

#### 11.1.1.4 Packet DMA (PKTDMA)

The PKTDMA module supports the transmission and reception of various packet types. The PKTDMA is architected to facilitate the segmentation and reassembly of DMA data structure compliant packets to/from smaller data blocks that are natively compatible with the specific requirements of each connected peripheral. Multiple Tx and Rx channels are provided within the DMA which allow multiple segmentation or reassembly operations to be ongoing. The DMA controller maintains state information for each of the channels which allows

packet segmentation and reassembly operations to be time division multiplexed between channels in order to share the underlying DMA hardware. An internal DMA scheduler is used to control the ordering and rate at which this multiplexing occurs for Transmit operations. The ordering and rate of Receive operations is indirectly controlled by the order in which blocks are pushed into the DMA on the Rx PSI-L interface.

A block diagram of the PKTDMA Controller is shown below:



Figure 11-1. PKTDMA Block Diagram

#### 11.1.1.4.1 PKTDMA Submodule Descriptions

##### 11.1.1.4.1.1 Bus Interface Unit

The Bus Interface Unit is responsible for merging and buffering all of the transactions that originate from the various initiator blocks inside the DMA controller into the 4 separate VBUSM initiator interfaces. Arbitration between the blocks to a given VBUSM interface is round robin within a single priority level. A 2 word deep retiming buffer is provided on each sub interface of each provided VBUSM bus.

##### 11.1.1.4.1.2 Config CR

The function of the Config CR is to switch transactions which arrive on the configuration interface to the various configuration targets within the DMA. The Config CR also provides a retiming buffer on the configuration bus primary interface ports.

##### 11.1.1.4.1.3 Configuration Registers

The Configuration Registers block is responsible for monitoring the fullness level of the Tx Per Channel FIFOs, monitoring data transfer work which is pending, maintaining data movement thread state information, arbitrating which channel will be allowed to perform work next, issuing scheduler commands to the Tx PKTDMA core blocks, and writing back the updated state returned from those same DMA core blocks.

The Configuration Registers block is also responsible for providing memory mapped registers for configuration of the Rx DMA functions including the default settings for the free descriptor and destination queues. For modularity and high speed pipelining reasons, the Rx traffic is looped through the Configuration Registers block where the original stream information is merged with information from the configuration registers on its way to the Rx DMA Core module. This prevents the Rx DMA Core from having to spend cycles accessing the channel configuration information for the channel.

### 11.1.1.4.1.3.1 RX State Mapping

|                          |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
|--------------------------|------------|-----|-----|-----|-----|-----|-----|----------|-----|-----|-----|------------|-----|-----|-----|---------------------|-----|---------------------|-----|-----|-----|-----|-----|---------|-----|------------|-----|-------------------|------------|-----|-----|----------------------|--|
| 0                        | 1          | 2   | 3   | 4   | 5   | 6   | 7   | 8        | 9   | 10  | 11  | 12         | 13  | 14  | 15  | 16                  | 17  | 18                  | 19  | 20  | 21  | 22  | 23  | 24      | 25  | 26         | 27  | 28                | 29         | 30  | 31  |                      |  |
| sop_descriptor_ptr[35:4] |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 0x80                     |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 32                       | 33         | 34  | 35  | 36  | 37  | 38  | 39  | 40       | 41  | 42  | 43  | 44         | 45  | 46  | 47  | 48                  | 49  | 50                  | 51  | 52  | 53  | 54  | 55  | 56      | 57  | 58         | 59  | 60                | 61         | 62  | 63  |                      |  |
| sop_descriptor_ptr[35:4] |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     | sop_descriptor_asel |     | curr_descriptor_ptr |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 0x84                     |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 64                       | 65         | 66  | 67  | 68  | 69  | 70  | 71  | 72       | 73  | 74  | 75  | 76         | 77  | 78  | 79  | 80                  | 81  | 82                  | 83  | 84  | 85  | 86  | 87  | 88      | 89  | 90         | 91  | 92                | 93         | 94  | 95  |                      |  |
| curr_descriptor_ptr      |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     | curr_descriptor_asel |  |
| 0x88                     |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 96                       | 97         | 98  | 99  | 100 | 101 | 102 | 103 | 104      | 105 | 106 | 107 | 108        | 109 | 110 | 111 | 112                 | 113 | 114                 | 115 | 116 | 117 | 118 | 119 | 120     | 121 | 122        | 123 | 124               | 125        | 126 | 127 |                      |  |
| curr_buffer_ptr          |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 0x8C                     |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 128                      | 129        | 130 | 131 | 132 | 133 | 134 | 135 | 136      | 137 | 138 | 139 | 140        | 141 | 142 | 143 | 144                 | 145 | 146                 | 147 | 148 | 149 | 150 | 151 | 152     | 153 | 154        | 155 | 156               | 157        | 158 | 159 |                      |  |
| curr_buffer_ptr          |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     | curr_buffer_asel    |     | curr_buffer_length  |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 0x90                     |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 160                      | 161        | 162 | 163 | 164 | 165 | 166 | 167 | 168      | 169 | 170 | 171 | 172        | 173 | 174 | 175 | 176                 | 177 | 178                 | 179 | 180 | 181 | 182 | 183 | 184     | 185 | 186        | 187 | 188               | 189        | 190 | 191 |                      |  |
| curr_buffer_length       |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     | curr_buffer_offset  |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 0x94                     |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 192                      | 193        | 194 | 195 | 196 | 197 | 198 | 199 | 200      | 201 | 202 | 203 | 204        | 205 | 206 | 207 | 208                 | 209 | 210                 | 211 | 212 | 213 | 214 | 215 | 216     | 217 | 218        | 219 | 220               | 221        | 222 | 223 |                      |  |
| curr_buffer_eop          | pkt_length |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     | ps_wordcnt |     | flowid_is_default | drop_flush |     |     |                      |  |
|                          | 0x98       |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |
| 224                      | 225        | 226 | 227 | 228 | 229 | 230 | 231 | 232      | 233 | 234 | 235 | 236        | 237 | 238 | 239 | 240                 | 241 | 242                 | 243 | 244 | 245 | 246 | 247 | 248     | 249 | 250        | 251 | 252               | 253        | 254 | 255 |                      |  |
| ps_offset                |            |     |     |     |     |     |     | ps_flags |     |     |     | pktid_data |     |     |     |                     |     |                     |     |     |     |     |     | orderid |     | priority   |     |                   |            |     |     |                      |  |
| 0x9C                     |            |     |     |     |     |     |     |          |     |     |     |            |     |     |     |                     |     |                     |     |     |     |     |     |         |     |            |     |                   |            |     |     |                      |  |

**Table 11-1. RX State Mapping Table**

| Total Bits | Bits    | Register Offset | Field                    | Description                                                        |
|------------|---------|-----------------|--------------------------|--------------------------------------------------------------------|
| 31 - 0     | 31 - 0  | 0x80            | sop_descriptor_ptr[35:4] | The descriptor pointer at start of packet                          |
| 43 - 32    | 11 - 0  | 0x84            | sop_descriptor_ptr[35:4] | The descriptor pointer at start of packet                          |
| 47 - 44    | 15 - 12 | 0x84            | sop_descriptor_asel      | The asel for descriptor pointer at start of packet                 |
| 63 - 48    | 31 - 16 | 0x84            | curr_descriptor_ptr      | The pointer for the current descriptor aligned on 16 byte boundary |
| 91 - 64    | 27 - 0  | 0x88            | curr_descriptor_ptr      | The pointer for the current descriptor aligned on 16 byte boundary |
| 95 - 92    | 31 - 28 | 0x88            | curr_descriptor_asel     | The asel of the current descriptor                                 |
| 127 - 96   | 31 - 0  | 0x8C            | curr_buffer_ptr          | The pointer for the current buffer                                 |
| 143 - 128  | 15 - 0  | 0x90            | curr_buffer_ptr          | The pointer for the current buffer                                 |
| 147 - 144  | 19 - 16 | 0x90            | curr_buffer_asel         | The asel for the current buffer                                    |
| 159 - 148  | 9 - 0   | 0x90            | curr_buffer_length       | The length of the current buffer                                   |
| 169 - 160  | 31 - 20 | 0x90            | curr_buffer_length       | The length of the current buffer                                   |
| 191 - 170  | 31 - 10 | 0x94            | curr_buffer_offset       | The offset inside the current buffer                               |
| 192        | 0       | 0x98            | curr_buffer_eop          | The end of packet flag for the current buffer                      |
| 213 - 193  | 21 - 1  | 0x98            | pkt_length               | The size of the packet length                                      |
| 214        | 22      | 0x98            | flush                    | The packet is being flushed                                        |
| 220 - 215  | 28 - 23 | 0x98            | ps_wordcnt               | protocol specific word count                                       |
| 221        | 29      | 0x98            | flowid_is_default        | Use default flow id                                                |
| 223 - 222  | 31 - 30 | 0x98            | drop_flush               | The flush is a drop condition                                      |
| 230 - 224  | 6 - 0   | 0x9C            | ps_offset                | protocol specific offset                                           |
| 234 - 231  | 10 - 7  | 0x9C            | ps_flags                 | protocol specific flags                                            |
| 247 - 235  | 23 - 11 | 0x9C            | pktid_data               | The pktid number for scoreboard                                    |
| 251 - 248  | 27 - 24 | 0x9C            | orderid                  | The orderid of the packet                                          |
| 254 - 252  | 30 - 28 | 0x9C            | priority                 | The priority of the packet                                         |

### 11.1.1.4.1.3.2 TX State Mapping

|                          |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
|--------------------------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------------------|-----------|-----|-----|---------------------|-----|---------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------------------|--------------|--|
| 0                        | 1                 | 2   | 3   | 4   | 5   | 6   | 7   | 8   | 9   | 10  | 11  | 12  | 13  | 14  | 15  | 16                 | 17        | 18  | 19  | 20                  | 21  | 22                  | 23  | 24  | 25  | 26  | 27  | 28  | 29  | 30  | 31  |                      |              |  |
| sop_descriptor_ptr[35:4] |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 0x80                     |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 32                       | 33                | 34  | 35  | 36  | 37  | 38  | 39  | 40  | 41  | 42  | 43  | 44  | 45  | 46  | 47  | 48                 | 49        | 50  | 51  | 52                  | 53  | 54                  | 55  | 56  | 57  | 58  | 59  | 60  | 61  | 62  | 63  |                      |              |  |
| sop_descriptor_ptr[35:4] |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     | sop_descriptor_asel |     | curr_descriptor_ptr |     |     |     |     |     |     |     |     |     |                      |              |  |
| 0x84                     |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 64                       | 65                | 66  | 67  | 68  | 69  | 70  | 71  | 72  | 73  | 74  | 75  | 76  | 77  | 78  | 79  | 80                 | 81        | 82  | 83  | 84                  | 85  | 86                  | 87  | 88  | 89  | 90  | 91  | 92  | 93  | 94  | 95  |                      |              |  |
| curr_descriptor_ptr      |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     | curr_descriptor_asel |              |  |
| 0x88                     |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 96                       | 97                | 98  | 99  | 100 | 101 | 102 | 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112                | 113       | 114 | 115 | 116                 | 117 | 118                 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 |                      |              |  |
| curr_buffer_ptr          |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 0x8C                     |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 128                      | 129               | 130 | 131 | 132 | 133 | 134 | 135 | 136 | 137 | 138 | 139 | 140 | 141 | 142 | 143 | 144                | 145       | 146 | 147 | 148                 | 149 | 150                 | 151 | 152 | 153 | 154 | 155 | 156 | 157 | 158 | 159 |                      |              |  |
| curr_buffer_ptr          |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     | curr_buffer_asel    |     | curr_buffer_length  |     |     |     |     |     |     |     |     |     |                      |              |  |
| 0x90                     |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 160                      | 161               | 162 | 163 | 164 | 165 | 166 | 167 | 168 | 169 | 170 | 171 | 172 | 173 | 174 | 175 | 176                | 177       | 178 | 179 | 180                 | 181 | 182                 | 183 | 184 | 185 | 186 | 187 | 188 | 189 | 190 | 191 |                      |              |  |
| curr_buffer_length       |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     | curr_buffer_offset |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 0x94                     |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 192                      | 193               | 194 | 195 | 196 | 197 | 198 | 199 | 200 | 201 | 202 | 203 | 204 | 205 | 206 | 207 | 208                | 209       | 210 | 211 | 212                 | 213 | 214                 | 215 | 216 | 217 | 218 | 219 | 220 | 221 | 222 | 223 |                      |              |  |
| curr_buffer_eop          | rem_length        |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      | info_present |  |
|                          | truncated_non_eop |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 224                      | 225               | 226 | 227 | 228 | 229 | 230 | 231 | 232 | 233 | 234 | 235 | 236 | 237 | 238 | 239 | 240                | 241       | 242 | 243 | 244                 | 245 | 246                 | 247 | 248 | 249 | 250 | 251 | 252 | 253 | 254 | 255 | psbytes_rem          |              |  |
| psbytes_rem              | psbytes_off       |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    | wptr_data |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      | pktd_data    |  |
|                          | orderid           |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    | priority  |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |
| 0x9C                     |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                    |           |     |     |                     |     |                     |     |     |     |     |     |     |     |     |     |                      |              |  |

**Table 11-2. TX State Mapping Table**

| Total Bits | Bits    | Register Offset | Field                    | Description                                                        |
|------------|---------|-----------------|--------------------------|--------------------------------------------------------------------|
| 31 - 0     | 31 - 0  | 0x80            | sop_descriptor_ptr[35:4] | The descriptor pointer at start of packet                          |
| 43 - 32    | 11 - 0  | 0x84            | sop_descriptor_ptr[35:4] | The descriptor pointer at start of packet                          |
| 47 - 44    | 15 - 12 | 0x84            | sop_descriptor_asel      | The asel for descriptor pointer at start of packet                 |
| 63 - 48    | 31 - 16 | 0x84            | curr_descriptor_ptr      | The pointer for the current descriptor aligned on 16 byte boundary |
| 91 - 64    | 27 - 0  | 0x88            | curr_descriptor_ptr      | The pointer for the current descriptor aligned on 16 byte boundary |
| 95 - 92    | 31 - 28 | 0x88            | curr_descriptor_asel     | The asel of the current descriptor                                 |
| 127 - 96   | 31 - 0  | 0x8C            | curr_buffer_ptr          | The pointer for the current buffer                                 |
| 143 - 128  | 15 - 0  | 0x90            | curr_buffer_ptr          | The pointer for the current buffer                                 |
| 147 - 144  | 19 - 16 | 0x90            | curr_buffer_asel         | The asel for the current buffer                                    |
| 159 - 148  | 9 - 0   | 0x90            | curr_buffer_length       | The length of the current buffer                                   |
| 169 - 160  | 31 - 20 | 0x90            | curr_buffer_length       | The length of the current buffer                                   |
| 191 - 170  | 31 - 10 | 0x94            | curr_buffer_offset       | The offset inside the current buffer                               |
| 192        | 0       | 0x98            | curr_buffer_eop          | The end of packet flag for the current buffer                      |
| 214 - 193  | 22 - 1  | 0x98            | rem_length               | The remaining length in the buffer                                 |
| 215        | 23      | 0x98            | info_present             | The packet has info present                                        |
| 216        | 24      | 0x98            | truncated_non_eop        | Eop if packet length is greater than the total buffer length       |
| 223 - 217  | 31 - 25 | 0x98            | psbytes_rem              | Number of protocol specific bytes remaining                        |
| 224        | 0       | 0x9C            | psbytes_rem              | Number of protocol specific bytes remaining                        |
| 232 - 225  | 8 - 1   | 0x9C            | psbytes_off              | The offset of the protocol specific bytes                          |
| 245 - 233  | 21 - 9  | 0x9C            | wptr_data                | The current write pointer in the data fifo                         |
| 247 - 246  | 23 - 22 | 0x9C            | pktid_data               | The pktid number for scoreboard                                    |
| 251 - 248  | 27 - 24 | 0x9C            | orderid                  | The orderid of the packet                                          |
| 254 - 252  | 30 - 28 | 0x9C            | priority                 | The priority of the packet                                         |

#### 11.1.4.1.4 Tx Packet DMA Unit

The Tx Packet DMA Unit block implements all of the state machine functionality necessary to implement the KS3 DMA Host Tx protocol. The Tx Packet DMA unit initiates VBUSM transactions in order to read descriptor pointers from the memory mapped Tx ring, read descriptors from memory, and read data from buffers in memory.

#### 11.1.4.1.5 Tx Packet Coherency Unit

The Tx Packet Coherency Unit is responsible for ensuring that all control structures and data have been read (and updated if applicable) by the Tx DMA unit(s) and that all previous packets on that channel/flow have also completed prior to incrementing the reverse ring occupancy for the channel/flow.

#### 11.1.4.1.6 Tx Per Channel Buffers

The Tx Per Channel Buffers implement a FIFO for each Tx DMA channel that is used for buffering packet control and payload data that has been fetched by the Tx Packet DMA units. The buffers are byte oriented on write so that the data from the DMA units which may not be full words can be packed properly. The buffers are block

oriented on read and each Tx (source) channel in the PKTDMA controller maps directly onto a thread in the Tx PSI interface. The Tx Per Channel Buffer block outputs queue fullness information to the Tx Scheduler block which it then uses to determine when it should initiate DMA opportunities to backfill the buffers. The Tx Per Channel Buffer will initiate transfers to the target whenever any data is available in each channel buffer and credits are available in the corresponding thread. The block will simultaneously monitor the status of all of the threads and will perform a round robin arbitration between the different threads for the use of the Transmit PSI-L interface. Each thread for which the target is indicating it can accept data and which currently has data available in the channel buffer will be included in the arbitration.

#### **11.1.1.4.1.7 Rx Per Channel Buffers**

The Rx Per Channel Buffers implement a FIFO for each Rx DMA channel that is used for buffering packet control and payload data that has been pushed into the DMA from the Rx PSI-L interface. The Rx Per Channel Buffers also includes an arbitration unit which determines which Rx DMA channel should be serviced next.

#### **11.1.1.4.1.8 Rx Packet DMA Unit**

The Rx Packet DMA Unit block implements all of the state machine functionality necessary to implement the KS3 DMA Rx protocol for Host descriptor types. The Rx Packet DMA Unit initiates VBUSM transactions in order to read descriptor pointers from memory mapped rings, read buffer descriptor information, write descriptors to memory, and write data to buffers in memory.

#### **11.1.1.4.1.9 Rx Packet Coherency Unit**

The Rx Packet Coherency Unit is responsible for ensuring that all control structures and data have been written by the Rx DMA unit(s) and that all previous packets on that channel/flow have completed prior to incrementing the reverse ring occupancy for the channel/flow. This unit ensures that the ordering of the Packet Descriptor pointer writes to the return queue directly matches the ordering in which those packets were fetched from the Rx free queues. Writes are not considered complete by this unit until the entire write status has been returned for all outstanding transactions for a given packet ID.

#### **11.1.1.4.1.10 Event Handler**

The Event Handler block is responsible for generating channel completion and error events.

#### **11.1.1.4.2 Channel Classes**

Not all channels within the PKTDMA require the same performance capabilities. Raw bandwidth and latency tolerance requirements will vary greatly between data transfers at various points in the system. Due to area concerns, several different classes of DMA channels are provided in the PKTDMA and are described as follows:

| Class Name          | Description                                                                                                                                                                                                                                                                          |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Normal Capacity     | Provides baseline amount of descriptor prefetch and Tx/Rx control and data buffering. Suitable for most peripheral transfers which are communicating with on-chip memories and DDR                                                                                                   |
| High Capacity       | Provides an elevated amount of descriptor prefetch and custom Tx/Rx control and data buffering. Suitable for applications which require moderate per-channel bandwidth with significantly increased latency (ex. Transferring data to/from PCIe)                                     |
| Ultra-High Capacity | Provides identical descriptor and TR prefetch as High Capacity but with increased Tx data buffering to allow for more read data in flight. Suitable for applications requiring high per-channel bandwidth with significantly increased latency (ex. 16+Gbps transfers to/from PCIe). |

PKTDMA instances may provide support for any or all of the above channel classes through design time configuration parameters.

### 11.1.1.5 Block Copy DMA (BCDMA)

The Block Copy DMA is intended to perform similar functions as an Embedded DMA (EDMA) and the UDMA-P. The BCDMA module moves data from a memory mapped source address set to a corresponding memory mapped address. The BCDMA maintains state information for each of the channels which allows data copy operations to be time division multiplexed between channels in order to share the underlying DMA hardware. An internal DMA scheduler is used to control the ordering and rate at which this multiplexing occurs.

A block diagram of the Block Copy DMA Controller is shown below:



**Figure 11-2. Block Copy DMA Block Diagram**

### **11.1.1.5.1 BCDMA Submodule Descriptions**

### **11.1.1.5.1.1 Bus Interface Unit**

The Bus Interface Unit is responsible for merging and buffering all of the transactions that originate from the various controller blocks inside the DMA controller into the 4 separate VBUSM controller interfaces. Arbitration between the blocks to a given VBUSM interface is round robin within a single priority level. A 2 word deep retiming buffer is provided on each sub interface of each provided VBUSM bus.

### 11.1.1.5.1.2 Config CR

The function of the Config CR is to switch transactions which arrive on the configuration interface to the various configuration targets within the DMA. The Config CR also provides a retiming buffer on the configuration bus primary interface ports.

### 11.1.1.5.1.3 Configuration Registers

The Configuration Registers block is responsible for monitoring the fullness level of the Per Channel FIFOs, monitoring data transfer work which is pending, maintaining data movement thread state information, arbitrating which channel will be allowed to perform work next, issuing scheduler commands to the Read and Write DMA units, and writing back the updated state returned from those same DMA units.

The Configuration Registers block is also responsible for providing memory mapped registers for configuration of the DMA channels.

**11.1.1.5.1.3.1 BCDMA Mapping Table**

Table 11-3 applies to TX, RX and BC Mapping.

|                |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|----------|------------|-----|----------|------------|------------|------------|-----|---------|-----|-----|-----|-----|-----|--------------|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0              | 1        | 2          | 3   | 4        | 5          | 6          | 7          | 8   | 9       | 10  | 11  | 12  | 13  | 14  | 15           | 16         | 17  | 18  | 19  | 20  | 21  | 22  | 23  | 24  | 25  | 26  | 27  | 28  | 29  | 30  | 31  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| reload_count   | waitcomp | event_size |     | trigger0 | trigger0_t | trigger1_t | trigger1_t |     | spflags |     | eop | eol |     |     | reload_count |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x80           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 32             | 33       | 34         | 35  | 36       | 37         | 38         | 39         | 40  | 41      | 42  | 43  | 44  | 45  | 46  | 47           | 48         | 49  | 50  | 51  | 52  | 53  | 54  | 55  | 56  | 57  | 58  | 59  | 60  | 61  | 62  | 63  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tr_dim1        |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x84           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 64             | 65       | 66         | 67  | 68       | 69         | 70         | 71         | 72  | 73      | 74  | 75  | 76  | 77  | 78  | 79           | 80         | 81  | 82  | 83  | 84  | 85  | 86  | 87  | 88  | 89  | 90  | 91  | 92  | 93  | 94  | 95  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tr_dim2        |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x88           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 96             | 97       | 98         | 99  | 100      | 101        | 102        | 103        | 104 | 105     | 106 | 107 | 108 | 109 | 110 | 111          | 112        | 113 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tr_dim3        |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x8C           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 128            | 129      | 130        | 131 | 132      | 133        | 134        | 135        | 136 | 137     | 138 | 139 | 140 | 141 | 142 | 143          | 144        | 145 | 146 | 147 | 148 | 149 | 150 | 151 | 152 | 153 | 154 | 155 | 156 | 157 | 158 | 159 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tr_icnt0       |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              | tr_icnt1   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x90           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 160            | 161      | 162        | 163 | 164      | 165        | 166        | 167        | 168 | 169     | 170 | 171 | 172 | 173 | 174 | 175          | 176        | 177 | 178 | 179 | 180 | 181 | 182 | 183 | 184 | 185 | 186 | 187 | 188 | 189 | 190 | 191 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tr_icnt2       |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              | tr_icnt3   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x94           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 192            | 193      | 194        | 195 | 196      | 197        | 198        | 199        | 200 | 201     | 202 | 203 | 204 | 205 | 206 | 207          | 208        | 209 | 210 | 211 | 212 | 213 | 214 | 215 | 216 | 217 | 218 | 219 | 220 | 221 | 222 | 223 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| icnt1          |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              | icnt2      |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x98           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 224            | 225      | 226        | 227 | 228      | 229        | 230        | 231        | 232 | 233     | 234 | 235 | 236 | 237 | 238 | 239          | 240        | 241 | 242 | 243 | 244 | 245 | 246 | 247 | 248 | 249 | 250 | 251 | 252 | 253 | 254 | 255 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| icnt3          |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              | rem_icnt0  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0x9C           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 256            | 257      | 258        | 259 | 260      | 261        | 262        | 263        | 264 | 265     | 266 | 267 | 268 | 269 | 270 | 271          | 272        | 273 | 274 | 275 | 276 | 277 | 278 | 279 | 280 | 281 | 282 | 283 | 284 | 285 | 286 | 287 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tr_addr        |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0xA0           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 288            | 289      | 290        | 291 | 292      | 293        | 294        | 295        | 296 | 297     | 298 | 299 | 300 | 301 | 302 | 303          | 304        | 305 | 306 | 307 | 308 | 309 | 310 | 311 | 312 | 313 | 314 | 315 | 316 | 317 | 318 | 319 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tr_addr        | tr_asel  |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| descriptor_ptr |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0xA4           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 320            | 321      | 322        | 323 | 324      | 325        | 326        | 327        | 328 | 329     | 330 | 331 | 332 | 333 | 334 | 335          | 336        | 337 | 338 | 339 | 340 | 341 | 342 | 343 | 344 | 345 | 346 | 347 | 348 | 349 | 350 | 351 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| descriptor_ptr |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              | RVSD       |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| curr_index     |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0xA8           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 352            | 353      | 354        | 355 | 356      | 357        | 358        | 359        | 360 | 361     | 362 | 363 | 364 | 365 | 366 | 367          | 368        | 369 | 370 | 371 | 372 | 373 | 374 | 375 | 376 | 377 | 378 | 379 | 380 | 381 | 382 | 383 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| last_index     |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              | nom_elsize |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| reload_index   |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0xAC           |          |            |     |          |            |            |            |     |         |     |     |     |     |     |              |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 384            | 385      | 386        | 387 | 388      | 389        | 390        | 391        | 392 | 393     | 394 | 395 | 396 | 397 | 398 | 399          |            |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| curr_wptr | pktid | orderid | priority | trid | evtid | sot |
|-----------|-------|---------|----------|------|-------|-----|
| 0xB0      |       |         |          |      |       |     |

**Table 11-3. BCDMA Mapping Table**

| Total Bits | Bits    | Register Offset | Field          | Description |
|------------|---------|-----------------|----------------|-------------|
| 3 - 0      | 3 - 0   | 0x80            | reload_count   |             |
| 4          | 4       | 0x80            | waitcomp       |             |
| 6 - 5      | 6 - 5   | 0x80            | event_size     |             |
| 8 - 7      | 8 - 7   | 0x80            | trigger0       |             |
| 10 - 9     | 10 - 9  | 0x80            | trigger0_type  |             |
| 12 - 11    | 12 - 11 | 0x80            | trigger1_type  |             |
| 14 - 13    | 14 - 13 | 0x80            | trigger1_type  |             |
| 18 - 15    | 18 - 15 | 0x80            | spflags        |             |
| 19         | 19      | 0x80            | eop            |             |
| 22 - 20    | 22 - 20 | 0x80            | eol            |             |
| 31 - 23    | 31 - 23 | 0x80            | reload_count   |             |
| 63 - 32    | 31 - 0  | 0x84            | tr_dim1        |             |
| 95 - 64    | 31 - 0  | 0x88            | tr_dim2        |             |
| 127 - 96   | 31 - 0  | 0x8C            | tr_dim3        |             |
| 143 - 128  | 15 - 0  | 0x90            | tr_icnt0       |             |
| 159 - 144  | 31 - 16 | 0x90            | tr_ictn1       |             |
| 175 - 160  | 15 - 0  | 0x94            | tr_ictn2       |             |
| 191 - 176  | 31 - 16 | 0x94            | tr_icnt3       |             |
| 207 - 192  | 15 - 0  | 0x98            | icnt1          |             |
| 223 - 208  | 31 - 16 | 0x98            | icnt2          |             |
| 239 - 224  | 15 - 0  | 0x9C            | icnt3          |             |
| 255 - 240  | 31 - 16 | 0x9C            | rem_icnt0      |             |
| 287 - 256  | 31 - 0  | 0xA0            | tr_addr        |             |
| 291 - 288  | 3 - 0   | 0xA4            | tr_addr        |             |
| 295 - 292  | 7 - 4   | 0xA4            | tr_asel        |             |
| 319 - 296  | 31 - 8  | 0xA4            | descriptor_ptr |             |
| 331 - 320  | 11 - 0  | 0xA8            | descriptor_ptr |             |
| 349 - 336  | 29 - 16 | 0xA8            | curr_index     |             |
| 363 - 350  | 11 - 30 | 0xA8            | last_index     |             |
| 366 - 364  | 14 - 12 | 0xAC            | nom_elsize     |             |
| 372 - 367  | 20 - 15 | 0xAC            | reload_index   |             |
| 385 - 373  | 1 - 21  | 0xAC            | curr_wptr      |             |
| 387 - 386  | 3 - 2   | 0xB0            | pktid          |             |
| 391 - 388  | 7 - 4   | 0xB0            | orderid        |             |
| 394 - 392  | 10 - 8  | 0xB0            | priority       |             |
| 396 - 395  | 12 - 11 | 0xB0            | trid           |             |
| 398 - 397  | 14 - 13 | 0xB0            | evtid          |             |

**Table 11-3. BCDMA Mapping Table (continued)**

| Total Bits | Bits | Register Offset | Field | Description |
|------------|------|-----------------|-------|-------------|
| 399        | 15   | 0xB0            | sot   |             |

#### 11.1.1.5.1.4 Read Unit(s)

The Read Units implement all of the state machine functionality necessary to perform the read transfers defined in the SW supplied Transfer Request records. The read DMA unit initiates VBUSM transactions in order to read descriptor pointers from memory mapped rings, read descriptors, Transfer Request records, and payload data from memory.

#### 11.1.1.5.1.5 TR Coherency Unit

The TR Coherency Unit is responsible for ensuring that all control structures and data have been read (and updated if applicable) by the BCDMA unit(s) and all prior TRs have completed prior to incrementing the reverse ring occupancy for the flow/channel.

#### 11.1.1.5.1.6 Per-Copy-Channel Buffers

The Per-Copy-Channel Buffers implement a FIFO for each BCDMA generic block copy channel and is used for buffering payload data that has been fetched by read DMA unit modules. The write DMA units issue write transfers from the Per Channel Buffers to specified addresses in memory. The buffers are byte oriented on both write and read so that the data from the DMA units which may not be full words can be packed and unpacked properly. This unit is optional and is only present if one or more generic block copy channels are configured in the BCDMA instance.

#### 11.1.1.5.1.7 Tx Per-Split-Channel Buffers

The Tx Per-Split-Channel Buffers implement a FIFO for each BCDMA Tx split mode channel and is used for buffering payload data that has been fetched by read DMA unit modules. Data is transferred from the buffer to the remote peripheral via a PSI-L interface. This unit is optional and is only present if one or more Tx split mode channels are configured in the BCDMA instance.

#### 11.1.1.5.1.8 Rx Per-Split-Channel Buffers

The Rx Per-Split-Channel Buffers implement a FIFO for each BCDMA Rx split mode channel and is used for buffering payload data that has been received from remote peripherals via a PSI-L interface. Data is read from these FIFOs and written out to memory as directed by the write DMA unit modules. This unit is optional and is only present if one or more Rx split mode channels are configured in the BCDMA instance.

#### 11.1.1.5.1.9 Write Unit(s)

The Write Units implement all of the state machine functionality necessary to perform the write transfers defined in the SW supplied Transfer Request records. The write DMA unit initiates VBUSM transactions in order to read descriptor pointers from memory mapped rings, read descriptors and/or Transfer Request records from memory mapped rings, read descriptor and Transfer Request records, and write payload data to memory.

#### 11.1.1.5.1.10 Event Coherency Unit

The Event Coherency Unit is responsible for ensuring that all writes have completed prior to signaling an output event for a channel/flow.

#### 11.1.1.5.1.11 Event Handler

The Event Handler block is responsible for generating channel completion and error events and for accepting and tracking channel triggering.

#### 11.1.1.5.2 Channel Classes

Not all channels within a DMA controller require the same performance capabilities. Raw bandwidth and latency tolerance requirements will vary greatly between data transfers at various points in the system. Due to area concerns, several different classes of DMA channels are provided in the BCDMA and are described as follows:

| Class Name          | Description                                                                                                                                                                                                                                                                          |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Normal Capacity     | Provides baseline amount of descriptor and TR prefetch and Tx/Rx control and data buffering. Suitable for most peripheral transfers which are communicating with on-chip memories and DDR                                                                                            |
| High Capacity       | Provides an elevated amount of descriptor and TR prefetch and custom Tx/Rx control and data buffering. Suitable for applications which require moderate per-channel bandwidth with significantly increased latency (ex. Transferring data to/from PCIe)                              |
| Ultra-High Capacity | Provides identical descriptor and TR prefetch as High Capacity but with increased Tx data buffering to allow for more read data in flight. Suitable for applications requiring high per-channel bandwidth with significantly increased latency (ex. 16+Gbps transfers to/from PCIe). |

BCDMA instances may provide support for any or all of the above channel classes through design time configuration parameters.

#### **11.1.2 Definition of Terms**

**Host**— The host is an intelligent system resource that configures and manages each communications control module. The host is responsible for allocating memory, initializing all data structures, and responding to port interrupts.

**Channel**— A channel refers to the sub-division of information (flows) that is transported across a DMA engine. Each channel has associated state information. Channels are used to segregate information flows based on the protocol used, scheduling requirements (for example, CBR, VBR, ABR), or concurrency requirements (that is, blocking avoidance). Information flow within a channel is a stream of strongly ordered information.

**Data Buffer**— A data buffer is a single data structure that contains payload information for transmission to or reception from a channel.

**Buffer Descriptor**— A buffer descriptor is a single data structure that contains information about one or more data buffers.

**Packet Descriptor**— A packet descriptor is another name for the first buffer descriptor within a packet. Some fields within a data buffer descriptor are only valid when it is a packet descriptor including the tags, packet length, packet type, and flags. All Monolithic type descriptors are packet descriptors (and are also a Data Buffer).

**Queue**— A queue is a list of strongly ordered entries which is typically used to pass work between a producer and a consumer. Queue entries in most cases are references to a work payload which is being passed, but in some cases, (Transfer Request Packets for example) queue entries may actually contain data which is being transferred. Queues are used throughout DMA whenever communication is required between entities. Queues can have multiple different implementations and DMA uses two of the most common: linked lists and rings.

**Linked list**— A linked list is a data structure in which each entry stores not only the entry data but also a chaining pointer to the next entry in the list. The last entry in each list has its chaining pointer set to NULL (typically encoded as 0x0). The list manager maintains a pointer to the head element on the list and to the tail element on the list. Since the chaining pointer is stored with the entry data, linked lists have a length which is dynamically changeable and limited only by the ability to allocate additional entries which are to be queued/de-queued. Linked lists are present in Host Descriptors to chain multiple descriptors to form a packet.

**Ring**— A ring is a data structure in which a contiguous memory block defined by M N-byte entries (total size is  $M \times N$  bytes) is statically allocated and sequentially written/read in order to pass data or data references.

Rings are also referred to as circular buffers because when the last element in the contiguous memory array is written, the pointers wrap back to the beginning address for the ring and start the process all over again. The Ring Accelerator component uses rings in order to implement logical queues.

**Free Descriptor/Buffer Queue**— A free descriptor/buffer queue is a list of available descriptors with prelinked empty buffers that are to be used by the receive ports for host type descriptors. Free Descriptor/Buffer Queues are implemented by the Ring Accelerator.

**Free Descriptor Queue**— A free descriptor queue is a list of available descriptors that are not yet linked with buffers that are to be used by the receive ports for monolithic type descriptors. Free Descriptor Queues are implemented by the Ring Accelerator.

**Packet Queue**— A packet queue is a list of valid (that is, populated) packet descriptors that is used for forwarding a packet from one entity to another for any number of purposes. Packet Queues are implemented by the Ring Accelerator.

**Memory**— Memory is an area of data storage managed by the host. This area is visible to the port as a 64-bit addressable area.

**Device Driver**— A device driver is application independent software that runs on the host for purposes abstracting the low level hardware so that upper level software can use the hardware without knowing every bit field location or initialization sequence. General device driver functions include port initialization, transmit packet queuing, and receive packet processing.

**SOP**— Start of Packet. This refers to the descriptor/buffer that is the first buffer in a packet.

**MOP**— Middle of Packet. This refers to the descriptors/buffers that are neither the first or last buffers in a packet.

**EOP**— End of Packet. This refers to the descriptor/buffer that is the last buffer in a packet.

### 11.1.3 DMSS Hardware/Software Interface

The intent of the Data Movement architecture is to provide a uniform HW/SW interface which includes a rich set of mechanisms that SW can make use of to transfer data with low overhead and reasonable complexity. To this goal, the number of components which SW is required to interact with on an ongoing real time basis has been kept to a minimum and is as follows (in order of anticipated frequency of access):

- Interrupt Aggregator
- Packet DMA
- Block Copy DMA

When interrupts are used, the interrupt aggregator will provide the vast majority of interrupt sources from all DMA components in the system. Each non-exception/non-debug packet and TR completion signaling originates from the Interrupt Aggregator and the IA provides a uniform set of MMRs that can be queried to quickly determine the cause of a specific interrupt. Events from PSI-L/ETL components are all routed to the host via the Interrupt Aggregator.

Each PKTDMA and BCDMA instance includes an inbuilt ring control mechanism which is the primary means by which work is sent to or received from these DMAs. Each DMA instance also includes both static configuration type memory mapped registers and some real-time accessible memory mapped registers for monitoring and control of each individual channel.

Memory mapped data structures are used anytime information needs to be passed between components in the system. These components may be hardware or software. The following sections describe the data structures which are used within the DMSS for passing information. These data structures include data buffers, packet descriptors, buffer descriptors, queues (including transmit queues, transmit completion queues, and receive queues) and the configuration MMRs that are provided in the various components. The following sections provide a detailed description of these data structures.

#### 11.1.3.1 Data Buffers

A data buffer is a byte aligned contiguous block of memory used to store payload data. Each buffer is described in an entry in either a packet descriptor or in a buffer descriptor. A data buffer may hold any portion of a packet and may be linked together (via descriptors) with other buffers to form packets. Data buffers may be allocated anywhere within the 64-bit memory space.

The Buffer Length field of the packet/buffer descriptor indicates the number of valid data bytes in the buffer. There may be from 1 to 4M-1 valid data bytes in each buffer.

#### 11.1.3.2 Descriptors

Descriptors are so named because their primary function is to describe other data structures.

The PKTDMA architecture provides for 2 basic types of descriptors whose characteristics are shown in [Table PKTDMA Descriptor Types and Attributes](#).

Table 11-4. PKTDMA Descriptor Types and Attributes

| Descriptor Type        | Includes Valid Packet Info | Provided # of Slots to Link In External Data | Provides Local Protocol Specific Storage | Provides Slot to Link Additional Descriptors Within Same Packet | Description                                                                                                                                                                                                                                                                                                                    |
|------------------------|----------------------------|----------------------------------------------|------------------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Host Packet Descriptor | ✓                          | 1                                            | ✓                                        | ✓                                                               | Used to describe packet and SOP buffer in applications that require Host OS compatible data structures (i.e. applications where the descriptors and buffers cannot be managed independently but must instead be pre-linked by the Host software). These applications inherently require a separate descriptor for each buffer. |
| Host Buffer Descriptor |                            | 1                                            |                                          | ✓                                                               | Used to describe non-SOP buffers in applications that require Host OS compatible data structures                                                                                                                                                                                                                               |

As the above table shows, the Host Packet Descriptor provides packet level information that is useful to both the ports and the Host in order to properly process the packet. These descriptors are referred to as Packet Descriptors and will always appear as the first descriptor within a packet.

The PKTDMA allows descriptors to be allocated on 16-byte address boundaries. This is intended to allow for better memory utilization by allowing on-chip descriptors which are not a power of 2 in length to be packed into arrays with little wasted memory space.

Even though descriptors and buffers may be allocated on any 16-byte alignment, careful consideration of the alignment effects should be made based on the storage location and any cache related affects that may exist. If data structures are placed in off-chip SDRAM the burst size and alignment restrictions of the memory devices must be considered in order to avoid performance issues related to continually fetching mis-aligned blocks. In this case, the memory efficiency can be reduced to 50% because 2 memory bank lines are read for every line sized data fetch. Similarly, placing more than one descriptor or buffer object within a single cache line can cause the adjacent object to become corrupted during cache line writeback operations.

Software/application specific control information may be added to the end of any of the packet descriptor types using as many extra words as necessary but the above alignment rules still apply.

The Block Copy DMA architecture provides a single descriptor type whose characteristics are shown in [Table Block Copy DMA Descriptor Types and Attributes](#).

**Table 11-5. Block Copy DMA Descriptor Types and Attributes**

| Descriptor Type                    | Includes Valid Packet Info | Provided # of Slots to Link In External Data | Provides Local Protocol Specific Storage | Provides Slot to Link Additional Descriptors Within Same Packet | Description                                          |
|------------------------------------|----------------------------|----------------------------------------------|------------------------------------------|-----------------------------------------------------------------|------------------------------------------------------|
| Transfer Request Packet Descriptor |                            | 0                                            |                                          |                                                                 | Used to feed transfer request sequences to the BCDMA |

**11.1.3.2.1 Host Packet Descriptor**

Host Packet Descriptors are designed to be used when the application requires support for true, unlimited fragment count scatter/gather type operations. The Host Packet Descriptor contains the following information:

- Indicator which identifies the descriptor as a Host Packet Descriptor
- Source and Destination Tags
- Packet Type
- Packet Length
- Protocol Specific Region Size
- Protocol Specific Control / Status Bits
- Pointer to the first valid byte in the SOP data buffer
- Length of the SOP data buffer
- Pointer to the next buffer descriptor in the packet
- Software specific information

Host Packet Descriptors always contain 48 bytes of required information and may also contain optional software specific information and protocol specific information. How much optional information (and therefore the allocated size of the descriptors) is required is application dependent.

The Host Packet descriptor layout is shown below.

**Table 11-6. Host Packet Descriptor Layout**

|                                                                                             |
|---------------------------------------------------------------------------------------------|
| Packet Info<br>(16 bytes)                                                                   |
| Linking Info<br>(8 bytes)                                                                   |
| Buffer Info<br>(12 bytes)                                                                   |
| Original Buffer Info<br>(12 bytes)                                                          |
| Extended Packet Info Block (Optional)<br>Includes Timestamp and Software Data<br>(16 bytes) |
| Protocol Specific Data (Optional)<br>(0 to M bytes where M is a multiple of 4)              |
| Other SW Data (Optional and User Defined)                                                   |

Host Packet Descriptors may be linked with zero or more additional Host Buffer Descriptors in a singly linked list fashion to form packets. Each Host Packet consists of a single Host Packet Descriptor followed by a chain of zero or more Host Buffer Descriptors linked together using the Next Descriptor Pointer fields in the descriptors. The last descriptor in a Host packet has a zero Next Descriptor Pointer.

The 'Other SW Data' portion of the descriptor exists after all of the defined words and is reserved for use by the host software to store completely private data. This region is not used in any way by HW components in a PKTDMA system and these modules will not modify any bytes within this region.

The contents of the Host Packet Descriptor words are detailed in [Table Host Packet Descriptor Packet Information Word 0 \(PD Word 0\)](#) through [Table Packet Descriptor Protocol Specific Word N](#):

**Table 11-7. Host Packet Descriptor Packet Information Word 0 (PD Word 0)**

| Bits  | Name                               | Description                                                                                                                                                                                                                                                                                                                                                        | Rx Overwrite |
|-------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:30 | 2'd1                               | 64-bit Host Packet Descriptor Type Identifier                                                                                                                                                                                                                                                                                                                      | Yes          |
| 29    | Extended Packet Info Block Present | This field indicates the presence of the Extended Packet Info Block in the descriptor.<br>0 = EPIB is not present<br>1 = 16 byte EPIB is present                                                                                                                                                                                                                   | Yes          |
| 28    | RESERVED                           | -                                                                                                                                                                                                                                                                                                                                                                  | Yes          |
| 27:22 | Protocol Specific Valid Word Count | This field indicates the valid # of 32-bit words in the protocol specific region. This is encoded in increments of 4 bytes as follows:<br>0 = 0 bytes<br>1 = 4 bytes<br>...<br>16 = 64 bytes<br>...<br>32 = 128 bytes<br>33-63 = RESERVED                                                                                                                          | Yes          |
| 21:0  | Packet Length                      | The length of the packet in bytes. If the Packet Length is less than the sum of the buffer lengths, then the packet data will be truncated. A Packet Length greater than the sum of the buffers is an error. The valid range for an exact packet length is 0 to 4M-1 bytes. If the packet length is set to 0, the port will not actually transmit any information. | Yes          |

**Table 11-8. Host Packet Descriptor Packet Information Word 1 (PD Word 1)**

| Bits  | Name                    | Description                                                                                              | Rx Overwrite |
|-------|-------------------------|----------------------------------------------------------------------------------------------------------|--------------|
| 31:28 | Error Flags             | This field contains error flags that can be assigned based on the packet type                            | Yes          |
| 27:24 | Protocol Specific Flags | This field contains protocol specific flags / information that can be assigned based on the packet type. | Yes          |
| 23:14 | RESERVED                | -                                                                                                        | Yes          |

**Table 11-8. Host Packet Descriptor Packet Information Word 1 (PD Word 1) (continued)**

| Bits | Name    | Description                                                                                                                                                                                                                                                    | Rx Overwrite |
|------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 13:0 | Flow ID | Flow ID within which this packet is being transported. The FlowID is used by downstream blocks to make decisions about packet steering and resource allocations. FlowIDs are also used to allow specific packets to be received into specific sets of buffers. | Yes          |

**Table 11-9. Host Packet Descriptor Packet Information Word 2 (PD Word 2)**

| Bits  | Name        | Description                                                                                            | Rx Overwrite |
|-------|-------------|--------------------------------------------------------------------------------------------------------|--------------|
| 31:27 | Packet Type | This field indicates the type of this packet and is encoded as follows:<br>0-31 = Application specific | Yes          |
| 26:16 | RESERVED    | -                                                                                                      | Yes          |
| 15:0  | RESERVED    | -                                                                                                      | Yes          |

**Table 11-10. Host Packet Descriptor Packet Information Word 3 (PD Word 3)**

| Bits  | Name            | Description                                                                                                                                                                         | Rx Overwrite |
|-------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:24 | Source Tag – Hi | This field is application specific. During Packet reception, the DMA controller in the port will overwrite this field with the value provided in the PSI-L src_tag field bits 15:8. | Yes          |
| 23:16 | Source Tag – Lo | This field is application specific. During Packet reception, the DMA controller in the port will overwrite this field with the value provided in the PSI-L src_tag field bits 7:0.  | Yes          |
| 15:8  | Dest Tag – Hi   | This field is application specific. During Packet reception, the DMA controller in the port will overwrite this field with the value provided in the PSI-L dst_tag field bits 15:8. | Yes          |
| 7:0   | Dest Tag – Lo   | This field is application specific. During Packet reception, the DMA controller in the port will overwrite this field with the value provided in the PSI-L dst_tag field bits 7:0.  | Yes          |

**Table 11-11. Host Packet Descriptor Linking Word 0 (PD Word 4)**

| Bits | Name                        | Description                                                                                                                                                                                                                                     | Rx Overwrite |
|------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Next Descriptor Pointer LSB | The 32 LSBs of the 48-bit word aligned memory address of the next buffer descriptor in the packet. If the value of this pointer is zero then the current buffer is the last buffer in the packet.<br>The host sets the Next Descriptor Pointer. | No           |

**Table 11-12. Host Packet Descriptor Linking Word 1 (PD Word 5)**

| Bits  | Name                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Rx Overwrite |
|-------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:20 | RESERVED                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | No           |
| 19:16 | Next Descriptor Pointer Address Space Select | Effectively bits 51:48 of the address. The value given in this field will be output by the DMA initiators on the casel pin which is used by the infrastructure as an identifier for which address space this particular memory region is located within. Address space 0 is the default unified address space for a given device. Address spaces 1-15 are used for alternate address maps which may be external to the device (PCIe/Hyperlink) or in other 'tiles' on large devices. | No           |
| 15:0  | Next Descriptor Pointer MSB                  | The 16 MSBs of the 48-bit next descriptor pointer. If a specific SoC uses less than 48 bits of address reach the width of this field may be reduced.                                                                                                                                                                                                                                                                                                                                 | No           |

**Table 11-13. Host Packet Descriptor Buffer 0 Info Word 0 (PD Word 6)**

| Bits | Name                 | Description                                                                                                                                                                                                                                                                                                   | Rx Overwrite |
|------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Buffer 0 Pointer LSB | The Buffer Pointer is the byte aligned memory address of the buffer associated with the buffer descriptor. This value will be written during reception. These are the 32 LSBs of the 48-bit buffer pointer.<br><b>THIS Value along with the MSB bits cannot be 0 or the buffer will be seen as a NULL PTR</b> | Yes          |

**Table 11-14. Host Packet Descriptor Buffer 0 Info Word 1 (PD Word 7)**

| Bits | Name     | Description | Rx Overwrite |
|------|----------|-------------|--------------|
| 31:0 | RESERVED |             | Yes          |

**Table 11-14. Host Packet Descriptor Buffer 0 Info Word 1 (PD Word 7) (continued)**

| Bits  | Name                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Rx Overwrite |
|-------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 19:16 | Buffer 0 Pointer Address Space Select | Effectively bits 51:48 of the address. The value given in this field will be output by the DMA initiators on the casel pin which is used by the infrastructure as an identifier for which address space this particular memory region is located within. Address space 0 is the default unified address space for a given device. Address spaces 1-15 are used for alternate address maps which may be external to the device (PCIe/Hyperlink) or in other 'tiles' on large devices. | Yes          |
| 15:0  | Buffer 0 Pointer MSB                  | The 16 MSBs of the 48-bit buffer pointer. If a specific SoC uses less than 48 bits of address reach the width of this field may be reduced.                                                                                                                                                                                                                                                                                                                                          | Yes          |

**Table 11-15. Host Packet Descriptor Buffer 0 Info Word 2 (PD Word 8)**

| Bits  | Name            | Description                                                                    | Rx Overwrite |
|-------|-----------------|--------------------------------------------------------------------------------|--------------|
| 31:22 | RESERVED        | Written to 0                                                                   | Yes          |
| 21:0  | Buffer 0 Length | The Buffer Length field indicates how many valid data bytes are in the buffer. | Yes          |

**Table 11-16. Host Packet Descriptor Reserved Word 0 (PD Word 9)**

| Bits | Name     | Description | Rx Overwrite |
|------|----------|-------------|--------------|
| 31:0 | RESERVED |             | No           |

**Table 11-17. Host Packet Descriptor Reserved Word 1 (PD Word 10)**

| Bits | Name     | Description | Rx Overwrite |
|------|----------|-------------|--------------|
| 31:0 | RESERVED |             | No           |

**Table 11-18. Host Packet Descriptor Reserved Word 2 (PD Word 11)**

| Bits  | Name     | Description | Rx Overwrite |
|-------|----------|-------------|--------------|
| 31:20 | RESERVED |             | No           |
| 15:0  | RESERVED |             | No           |

This word is only present if the Extended Packet Info Block present bit is set in Word 0

**Table 11-19. Host Packet Descriptor Extended Packet Info Block Word 0 (Optional)**

| Bits | Name           | Description                                                                                                          | Rx Overwrite |
|------|----------------|----------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Timestamp Info | This field contains an application specific timestamp which can be used for traffic shaping in a QoS enabled system. | Configurable |

This word is only present if the Extended Packet Info Block present bit is set in Word 0.

**Table 11-20. Host Packet Descriptor Extended Packet Info Block Word 1 (Optional)**

| Bits | Name            | Description                                                                                                                                                                                                                                                                                         | Rx Overwrite |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Software Info 0 | This field stores software centric information that needs to travel with the packet through the stack. This information will be copied from the source descriptor to the destination descriptor whenever a prefetch operation is performed or when transferring through an infrastructure DMA node. | Configurable |

This word is only present if the Extended Packet Info Block present bit is set in Word 0.

**Table 11-21. Host Packet Descriptor Extended Packet Info Block Word 2 (Optional)**

| Bits | Name            | Description                                                                                                                                                                                                                                                                                         | Rx Overwrite |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Software Info 1 | This field stores software centric information that needs to travel with the packet through the stack. This information will be copied from the source descriptor to the destination descriptor whenever a prefetch operation is performed or when transferring through an infrastructure DMA node. | Configurable |

This word is only present if the Extended Packet Info Block present bit is set in Word 0.

**Table 11-22. Host Packet Descriptor Extended Packet Info Block Word 3 (Optional)**

| Bits | Name            | Description                                                                                                                                                                                                                                                                                         | Rx Overwrite |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Software Info 2 | This field stores software centric information that needs to travel with the packet through the stack. This information will be copied from the source descriptor to the destination descriptor whenever a prefetch operation is performed or when transferring through an infrastructure DMA node. | Configurable |

**Table 11-23. Host Packet Descriptor Protocol Specific Word N (Optional)**

| Bits | Name                     | Description                                                                        | Rx Overwrite |
|------|--------------------------|------------------------------------------------------------------------------------|--------------|
| 31:0 | Protocol Specific Data N | This field stores information which varies depending on the block and packet type. | Configurable |

#### 11.1.3.2.2 Host Buffer Descriptor

The Host Buffer Descriptor is identical in size and organization to a Host Packet Descriptor but does not include valid information in the packet level fields and does not include a populated region for protocol specific information. Host Buffer Descriptors are designed to be linked onto a Host Packet Descriptor or another Host Buffer Descriptor to provide support for unlimited scatter / gather type operations. Host Buffer Descriptors provide information about a single corresponding data buffer. Every Host buffer descriptor stores the following information:

- Pointer to the first valid byte in the data buffer
- Length of the data buffer
- Pointer to the next buffer descriptor in the packet

Host Buffer Descriptors always contain 48 bytes of required information. Since it is a requirement that it is possible to convert a Host descriptor between a Buffer Descriptor and a Packet Descriptor (by filling in the appropriate fields) in practice, Host Buffer Descriptors will be allocated using the same sizes as Host Packet Descriptors. The Host Buffer Descriptor layout is shown below.

**Table 11-24. Host Buffer Descriptor Layout**

|                                       |
|---------------------------------------|
| Buffer Reclamation Info<br>(16 bytes) |
| Linking Info<br>(8 bytes)             |
| Buffer Info<br>(12 bytes)             |
| Original Buffer Info<br>(12 bytes)    |

A Host Packet Descriptor and zero or more Host Buffer Descriptors may be linked together using the Next Descriptor Pointer fields to form packets. The last descriptor in a packet has a zero Next Descriptor Pointer. Each Host Buffer descriptor also points to a single data buffer.

The contents of the Host Buffer Descriptor words are detailed in [Table Host Buffer Descriptor Reserved Word 0 \(BD Word 0\)](#) through [Table Host Buffer Descriptor Buffer N Info Word 2 \(BD Word 8\)](#):

**Table 11-25. Host Buffer Descriptor Reserved Word 0 (BD Word 0)**

| Bits | Name     | Description | Rx Overwrite |
|------|----------|-------------|--------------|
| 31:0 | RESERVED | -           | No           |

**Table 11-26. Host Buffer Descriptor Reserved Word 1 (BD Word 1)**

| Bits | Name     | Description | Rx Overwrite |
|------|----------|-------------|--------------|
| 31:0 | RESERVED | -           | No           |

**Table 11-27. Host Buffer Descriptor Reserved Word 2 (BD Word 2)**

| Bits  | Name     | Description | Rx Overwrite |
|-------|----------|-------------|--------------|
| 31:16 | RESERVED | -           | No           |

**Table 11-27. Host Buffer Descriptor Reserved Word 2 (BD Word 2) (continued)**

| Bits | Name     | Description | Rx Overwrite |
|------|----------|-------------|--------------|
| 15:0 | RESERVED | -           | No           |

**Table 11-28. Host Buffer Descriptor Reserved Word 3 (BD Word 3)**

| Bits | Name     | Description | Rx Overwrite |
|------|----------|-------------|--------------|
| 31:0 | RESERVED |             | No           |

**Table 11-29. Host Buffer Descriptor Linking Word 0 (BD Word 4)**

| Bits | Name                        | Description                                                                                                                                                                                                                                  | Rx Overwrite |
|------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Next Descriptor Pointer LSB | The 32 LSBs of the 48-bit word aligned memory address of the next buffer descriptor in the packet. If the value of this pointer is zero then the current buffer is the last buffer in the packet. The host sets the Next Descriptor Pointer. | No           |

**Table 11-30. Host Buffer Descriptor Linking Word 1 (BD Word 5)**

| Bits  | Name                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Rx Overwrite |
|-------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:20 | RESERVED                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | No           |
| 19:16 | Next Descriptor Pointer Address Space Select | Effectively bits 51:48 of the address. The value given in this field will be output by the DMA initiators on the casel pin which is used by the infrastructure as an identifier for which address space this particular memory region is located within. Address space 0 is the default unified address space for a given device. Address spaces 1-15 are used for alternate address maps which may be external to the device (PCIe/Hyperlink) or in other 'tiles' on large devices. | No           |
| 15:0  | Next Descriptor Pointer MSB                  | The 16 MSBs of the 48-bit next descriptor pointer. If a specific SoC uses less than 48 bits of address reach the width of this field may be reduced.                                                                                                                                                                                                                                                                                                                                 | No           |

**Table 11-31. Host Buffer Descriptor Buffer N Info Word 1 (BD Word 6)**

| Bits | Name                 | Description                                                                                                                                                                                                 | Rx Overwrite |
|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:0 | Buffer 0 Pointer LSB | The Buffer Pointer is the byte aligned memory address of the buffer associated with the buffer descriptor. This value will be written during reception. These are the 32 LSBs of the 48-bit buffer pointer. | No           |

**Table 11-32. Host Buffer Descriptor Buffer N Info Word 1 (BD Word 7)**

| Bits  | Name                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Rx Overwrite |
|-------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:20 | RESERVED                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | No           |
| 19:16 | Buffer 0 Pointer Address Space Select | Effectively bits 51:48 of the address. The value given in this field will be output by the DMA initiators on the casel pin which is used by the infrastructure as an identifier for which address space this particular memory region is located within. Address space 0 is the default unified address space for a given device. Address spaces 1-15 are used for alternate address maps which may be external to the device (PCIe/Hyperlink) or in other 'tiles' on large devices. | No           |
| 15:0  | Buffer 0 Pointer MSB                  | The MSBs of the 48-bit buffer pointer. If a specific SoC uses less than 48 bits of address reach the width of this field may be reduced.                                                                                                                                                                                                                                                                                                                                             | No           |

**Table 11-33. Host Buffer Descriptor Buffer N Info Word 2 (BD Word 8)**

| Bits  | Name            | Description                                                                                                                                                                                                                                  | Rx Overwrite |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:22 | RESERVED        |                                                                                                                                                                                                                                              | No           |
| 21:0  | Buffer N Length | The Buffer Length field indicates how many valid data bytes are in the buffer. Unused or protocol specific bytes at the beginning of the buffer are not counted in the Buffer Length field. This value will be overwritten during reception. | No           |

#### 11.1.3.2.3 Transfer Request Descriptor

The Transfer Request Descriptor contains the following information:

- Indicator which identifies the descriptor as a TR Descriptor
- Set of one or more Transfer Request Records
- Set of one or more Transfer Response Records

Transfer Request Packet Descriptors always contain 16 bytes of required information and a variable number of Transfer Request / Transfer Response Records (request and response counts match).

The Transfer Request descriptor layout is shown below.

**Table 11-34. Transfer Request Packet Descriptor Layout**

| Packet Info                                                                                         |  |
|-----------------------------------------------------------------------------------------------------|--|
| Given via Transfer Request Packet Descriptor Word 0-3 (16 bytes)                                    |  |
| Null                                                                                                |  |
| (0-102 bytes to bring start of TR request array into natural alignment for memory fetch efficiency) |  |
| Array of Transfer Request Records                                                                   |  |
| Array of Transfer Response Records                                                                  |  |

**Table 11-35. Transfer Request Packet Descriptor Word 0**

| Bits  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Rx Overwrite |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:30 | 2'd3         | TR Packet Descriptor type.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | No           |
| 29    | RESERVED     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | No           |
| 28:20 | Reload Count | Specifies what to do when the last entry is processed in this packet. This field specifies how many times to return to the Reload Index upon reaching the Last Entry. When an internal count is incremented to this value and the TR indicated by the Last Entry has been processed, this packet will be considered complete and the descriptor will be placed back on the return queue specified in Word 2. A value of 0xFF indicates that a perpetual loop is desired. In this case, the loop count is considered infinite and the internal count will not be incremented. A teardown operation on the channel will cause the loop to be broken at the nearest iteration boundary. | No           |
| 19:14 | Reload Index | Specifies the value to set the current processing index to when the last entry is processed and the Reload Enable is set to 1. This is basically an absolute index to jump to on the 2 <sup>nd</sup> and following passes through the TR packet.                                                                                                                                                                                                                                                                                                                                                                                                                                     | No           |
| 13:0  | Last Entry   | Specifies the index of the last valid entry in this packet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | No           |

**Table 11-36. Transfer Request Packet Descriptor Word 1**

| Bits  | Name                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Rx Overwrite |
|-------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 31:28 | RESERVED                              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | No           |
| 27    | RESERVED                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | No           |
| 26:24 | Transfer Request Nominal Element Size | Specifies the stride between TR entries. The value in this field must be set large enough that any TR in the buffer will fit within the given dimension. TRs are expected to be placed on boundaries as given in this dimension. This field is also used to calculate the location where the Transfer Responses will be written back. This field is encoded as follows:<br>0 = 16-byte Transfer Request record size<br>1 = 32-byte Transfer Request record size<br>2 = 64-byte Transfer Request record size<br>3 = 128-byte Transfer Request record size<br>4-7 = RESERVED | No           |
| 23:14 | RESERVED                              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | No           |
| 13:0  | RESERVED                              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | No           |

**Table 11-37. Transfer Request Packet Descriptor Word 2**

| Bits  | Name     | Description | Rx Overwrite |
|-------|----------|-------------|--------------|
| 31:17 | RESERVED |             | Yes          |
| 16    | RESERVED | -           | Yes          |
| 15:0  | RESERVED | -           | Yes          |

**Table 11-38. Transfer Request Packet Descriptor Word 3**

| Bits  | Name     | Description | Rx Overwrite |
|-------|----------|-------------|--------------|
| 31:24 | RESERVED | -           | No           |
| 15:0  | RESERVED | -           | No           |

**Table 11-39. Transfer Request Packet Descriptor Payload Words 0-N**

| Bits | Name                          | Description                                                                                                                                             | Rx Overwrite  |
|------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 31:0 | Transfer Control Record Array | Transfer Control Records. This is an array of records which encapsulate the Transfer Request and Transfer Response messages which are used by the BCDMA | Yes (partial) |

### 11.1.3.3 Transfer Request Record

#### 11.1.3.3.1 Overview

This section describes the standard transfer request (TR) format to initiate a DMA transfer. The TRs can support both half and full duplex with multiple dimensions. Each TR will also generate a TR response. A TR can be sent to the BCDMA either through a TR descriptor using a pass-by-reference ring or as a Direct TR submission using a pass-by-value ring.

**Table 11-40. Terms and Definitions**

| Term | Definition                                                                                                                         |
|------|------------------------------------------------------------------------------------------------------------------------------------|
| TR   | A transfer request to move data.                                                                                                   |
| CR   | A cache operation request. A request to send messages to a specified cache controller to prepare the cache for a future operation. |

#### 11.1.3.3.2 Addressing Algorithm

For a basic TR request the same algorithm is used. The innermost loop always consumes physically contiguous elements from memory. Its implicit dimension is 1 byte. The pointer itself moves from fetch to fetch on the maximum byte alignments specified for the BCDMA, in increasing order. In each level outside the inner loop, the loop moves the pointer to a new location based on the size of that loop level's dimension.

##### 11.1.3.3.2.1 Linear Addressing (Forward)

The following code illustrates the basic algorithm for a 4-level loop nest block move. This model assumes that it transfers data 1 byte at a time and the input and output block are the same size in all dimensions.

```

// sptr is a byte pointer.
// dptr is a byte pointer.
// Source address is indirect
if (TR_ISA) {
    sptr = *sptr;
}
// Destination address is indirect
if (TR_IDA) {
    dptr = *dptr;
}
// TR_TRIGX can be selected to come from Global events, Local event, or none.
// Check for trigger of TYPE0
if (TR_TRIG0_TYPE == TYPE0) while(!TR_TRIG0);
if (TR_TRIG1_TYPE == TYPE0) while(!TR_TRIG1);
for (i3 = 0; i3 < ICNT3; i3++)
{
    sptr3 = sptr; // save current position before entering next level
    dptr3 = dptr; // save current position before entering next level
    // Check for trigger of TYPE1
    if (TR_TRIG0_TYPE == TYPE1) while(!TR_TRIG0);
    if (TR_TRIG1_TYPE == TYPE1) while(!TR_TRIG1);
    for (i2 = 0; i2 < ICNT2; i2++) {
        sptr2 = sptr; // save current position before entering next level
        dptr2 = dptr; // save current position before entering next level
        // Check for trigger of TYPE2
        if (TR_TRIG0_TYPE == TYPE2) while(!TR_TRIG0);
        if (TR_TRIG1_TYPE == TYPE2) while(!TR_TRIG1);
        for (i1 = 0; i1 < ICNT1; i1++) {
            sptr1 = sptr; // save current position before entering next level
            dptr1 = dptr; // save current position before entering next level
            // Check for trigger of TYPE3
            if (TR_TRIG0_TYPE == TYPE3) while(!TR_TRIG0);
            if (TR_TRIG1_TYPE == TYPE3) while(!TR_TRIG1);
            for (i0 = 0; i0 < ICNT0; i0++) {
                // BCDMA can combine these in optimized burst aligned accesses.
                *dptr = *sptr;
                sptr = sptr++;
                dptr = dptr++;
            }
        }
    }
}
// Update based on saved pointer for this level
sptr = sptr1 + SDIM1;

```

```

        dptr = dptr1 + DDIM1;
    }
    // Update based on saved pointer for this level
    sptr = sptr2 + SDIM2;
    dptr = dptr1 + DDIM2;
}

```

This form of addressing allows programs to specify regular paths through memory in a small number of parameters. Additionally, it allows for various stall points through the loop to allow for hardware or software induced pausing of the transfer. The following section defines these parameters in detail.

#### 11.1.3.3.3 Transfer Request Formats

The BCDMA defines a four-level loop nest for addressing elements within the TR, using the algorithms described in the Addressing algorithm. Most of the fields in the TR template map directly to the parameters in those algorithms.

**Table 11-41. Transfer Request Fields**

| Field Name    | Description                                                                                                              | Size    |
|---------------|--------------------------------------------------------------------------------------------------------------------------|---------|
| <b>FLAGS</b>  | TR flags that specify type of TR and how the TR should be handled. It also supports the TR triggering and output events. | 32 bits |
| <b>ICNT0</b>  | Total loop iteration count for level 0 (innermost)                                                                       | 16 bits |
| <b>ICNT1</b>  | Total loop iteration count for level 1                                                                                   | 16 bits |
| <b>ADDR</b>   | Starting address for the source data or destination data if it is a half-duplex write.                                   | 64 bits |
| <b>DIM1</b>   | Signed dimension for loop level 1 for the source data                                                                    | 32 bits |
| <b>ICNT2</b>  | Total loop iteration count for level 2                                                                                   | 16 bits |
| <b>ICNT3</b>  | Total loop iteration count for level 3 (outermost)                                                                       | 16 bits |
| <b>DIM2</b>   | Signed dimension for loop level 2                                                                                        | 32 bits |
| <b>DIM3</b>   | Signed dimension for loop level 3                                                                                        | 32 bits |
| <b>DDIM1</b>  | Signed dimension for loop level 1 for the destination data                                                               | 32 bits |
| <b>DADDR</b>  | Starting address for the destination of the data                                                                         | 64 bits |
| <b>DDIM2</b>  | Signed dimension for loop level 2 for the destination data                                                               | 32 bits |
| <b>DDIM3</b>  | Signed dimension for loop level 3 for the destination data                                                               | 32 bits |
| <b>DICNT0</b> | Total loop iteration count for level 0 (innermost) used for destination                                                  | 16 bits |
| <b>DICNT1</b> | Total loop iteration count for level 1 used for destination                                                              | 16 bits |
| <b>DICNT2</b> | Total loop iteration count for level 2 used for destination                                                              | 16 bits |

**Table 11-41. Transfer Request Fields (continued)**

| Field Name    | Description                                                 | Size    |
|---------------|-------------------------------------------------------------|---------|
| <b>DICNT3</b> | Total loop iteration count for level 3 used for destination | 16 bits |

The TR assumes all iteration counts as unsigned integers, and all dimensions as signed integers representing byte offsets.

The template above fully specifies the type of elements, length, and dimensions of the transfer.

Since all transfers will not require all the fields the TRs have the type field which allow the number of words required to be sent for the TR to be reduced.

#### 11.1.3.3.4 Flags Field Definition

The next diagram expands the 32-bit FLAGS field. The numbers above each field here indicate bit numbers within the field.

**Table 11-42. Transfer Request Template FLAGS Field**

|                              |          |                   |          |                |      |            |  |      |
|------------------------------|----------|-------------------|----------|----------------|------|------------|--|------|
| 31                           | 24       | 23                |          |                |      |            |  | 16   |
| CONFIGURATION SPECIFIC FLAGS |          |                   |          | Reserved       |      |            |  |      |
| 15                           | 8        | 7                 | 5        | 4              | 3    |            |  | 0    |
| TRIGGER_S<br>IZE1            | TRIGGER1 | TRIGGER_S<br>IZE0 | TRIGGER0 | EVENT_SIZ<br>E | WAIT | STATI<br>C |  | TYPE |

The flags field fills in the remaining details about the stream, as follows:

**Table 11-43. FLAGS Field Descriptions**

| Bit | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-3 | TYPE     | The TYPE of TR that is being sent<br>0: One dimensional data move<br>1: Two dimensional data move<br>2: Three dimensional data move<br>3: Four dimensional data move<br>4: Four dimensional data move with data<br>formatting<br>5: Four dimensional Cache Warm<br>6-7: Reserved<br>8: Four Dimensional Block Move<br>9: Four Dimensional Block Move with<br>Repacking<br>10: Two Dimensional Block Move<br>11: Two Dimensional Block Move with<br>Repacking<br>12-14: Reserved<br>15: Four Dimensional Block Move with<br>Repacking and Indirection |
| 4   | Reserved | Reserved for Future use.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**Table 11-43. FLAGS Field Descriptions (continued)**

| Bit   | Field                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5     | <b>WAIT</b>          | <p>This field is only valid on Type 15 TRs. This field indicates whether or not this TR should ensure it completes before allowing the next TR to start on this channel. The encoding is as follows:</p> <p>0 = Allow next TR to start immediately<br/>1 = Wait for this TR to complete before allowing next TR to start</p> <p>When set, the next TR will not be considered triggered (regardless of any other trigger conditions) until all write status responses for the current TR have landed.</p> |
| 6-7   | <b>EVENT_SIZE</b>    | <p>This is how often the TR will generate an output event.</p> <p>0: Event is only generated with the TR is complete<br/>1: Event is generated when the second inner most loop (ICNT1) is decremented by 1.<br/>2: Event is generated when the third inner most loop (ICNT2) is decremented by 1.<br/>3: Event is generated when the outer most loop (ICNT3) is decremented by 1.</p>                                                                                                                    |
| 8-9   | <b>TRIGGER0</b>      | <p>This is one of two selectable triggers. The receipt of this trigger will enable the TR to be active for enough data transfer as specified by the TRIGGER0_TYPE Field.</p> <p>0: No Trigger<br/>1: Global Trigger 0 for the channel<br/>2: Global Trigger 1 for the channel<br/>3: Local Event for the channel</p>                                                                                                                                                                                     |
| 10-11 | <b>TRIGGER0_TYPE</b> | <p>This is the type of data transfer that will be enabled by receiving a trigger.</p> <p>0: The second inner most loop (ICNT1) will be decremented by 1.<br/>1: The third inner most loop (ICNT2) will be decremented by 1.<br/>2: The outer most loop (ICNT3) will be decremented by 1.<br/>3: The entire TR will be allowed to complete.</p>                                                                                                                                                           |
| 12-13 | <b>TRIGGER1</b>      | <p>This is one of two selectable triggers. The receipt of this trigger will enable the TR to be active for enough data transfer as specified by the TRIGGER1_TYPE Field.</p> <p>0: No Trigger<br/>1: Global Trigger 0 for the channel<br/>2: Global Trigger 1 for the channel<br/>3: Local Event for the channel</p> <p>This field is reserved for a Direct TR.</p>                                                                                                                                      |

**Table 11-43. FLAGS Field Descriptions (continued)**

| Bit   | Field                        | Description                                                                                                                                                                                                                                                                                                                      |
|-------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14-15 | TRIGGER1_TYPE                | This is the type of data transfer that will be enabled by receiving a trigger.<br>0: The second inner most loop (ICNT1) will be decremented by 1.<br>1: The third inner most loop (ICNT2) will be decremented by 1.<br>2: The outer most loop (ICNT3) will be decremented by 1.<br>3: The entire TR will be allowed to complete. |
| 16-23 | Reserved                     | Reserved for Future use.                                                                                                                                                                                                                                                                                                         |
| 24-31 | Configuration Specific Flags | These are flag bits that can be specified by the specific BCDMA configuration. These bits will remain undefined in the global TR format to allow for customization requirements that might be required in the specific BCDMA implementation.                                                                                     |

The following sections expand on each of these fields.

#### 11.1.3.3.4.1 Type: TR Type Field

The TR Type field gives the size of the TR and which fields are expected in the TR. Based on the type the number of words required to be sent to complete the TR can be decreased. The tables below show the minimum size for each TR as well if any fields will be treated as reserved.

**Table 11-44. Transfer Request Minimum Size Type 0 One Dimensional Transfer**

|       |       |      |                       |      |      |      |      |      |      |      |      |      |      |      |      |
|-------|-------|------|-----------------------|------|------|------|------|------|------|------|------|------|------|------|------|
| word  | word  | word | word                  | word | word | word | word | word | word | word | word | word | word | word | word |
| 0     | 1     | 2    | 3                     | 4    | 5    | 6    | 7    | 8    | 9    | 10   | 11   | 12   | 13   | 14   | 15   |
| FLAGS | ICNT0 | ADDR | RESERVED/NOT REQUIRED |      |      |      |      |      |      |      |      |      |      |      |      |

**Table 11-45. Transfer Request Minimum Size Type 1 Two Dimensional Transfer**

|       |         |      |      |                       |      |      |      |      |      |      |      |      |      |      |      |
|-------|---------|------|------|-----------------------|------|------|------|------|------|------|------|------|------|------|------|
| word  | word    | word | word | word                  | word | word | word | word | word | word | word | word | word | word | word |
| 0     | 1       | 2    | 3    | 4                     | 5    | 6    | 7    | 8    | 9    | 10   | 11   | 12   | 13   | 14   | 15   |
| FLAGS | ICNT0/1 | ADDR | DIM1 | RESERVED/NOT REQUIRED |      |      |      |      |      |      |      |      |      |      |      |

**Table 11-46. Transfer Request Minimum Size Type 2 Three Dimensional Transfer**

|       |         |      |      |       |      |                       |      |      |      |      |      |      |      |      |      |
|-------|---------|------|------|-------|------|-----------------------|------|------|------|------|------|------|------|------|------|
| word  | word    | word | word | word  | word | word                  | word | word | word | word | word | word | word | word | word |
| 0     | 1       | 2    | 3    | 4     | 5    | 6                     | 7    | 8    | 9    | 10   | 11   | 12   | 13   | 14   | 15   |
| FLAGS | ICNT0/1 | ADDR | DIM1 | ICNT2 | DIM2 | RESERVED/NOT REQUIRED |      |      |      |      |      |      |      |      |      |

**Table 11-47. Transfer Request Minimum Size Type 3 Four Dimensional Transfer**

|       |         |      |      |         |      |      |                       |      |      |      |      |      |      |      |      |
|-------|---------|------|------|---------|------|------|-----------------------|------|------|------|------|------|------|------|------|
| word  | word    | word | word | word    | word | word | word                  | word | word | word | word | word | word | word | word |
| 0     | 1       | 2    | 3    | 4       | 5    | 6    | 7                     | 8    | 9    | 10   | 11   | 12   | 13   | 14   | 15   |
| FLAGS | ICNT0/1 | ADDR | DIM1 | ICNT2/3 | DIM2 | DIM3 | RESERVED/NOT REQUIRED |      |      |      |      |      |      |      |      |

**Table 11-48. Transfer Request Minimum Size Type 15 Four Dimensional Block Copy with Repacking and Indirection Support**

| w0    | word 1  | word 2 | word 3 | word 4  | word 5 | word 6 | word 7    | word 8 | word 9 | word 10 | word 11 | word 12   | word 13   | word 14 | word 15 |
|-------|---------|--------|--------|---------|--------|--------|-----------|--------|--------|---------|---------|-----------|-----------|---------|---------|
| FLAGS | ICNT0/1 | ADDR   | DIM1   | ICNT2/3 | DIM2   | DIM3   | RESE RVED | DDIM1  | DADDR  | DDIM2   | DDIM3   | DICNT 0/1 | DICNT 2/3 |         |         |

**11.1.3.3.4.2 EVENT\_SIZE: Event Generation Definition**

The BCDMA allows for an event to be generated at specified intervals for each TR. As the TR passes through the various loops in the addressing algorithm it will generate an event that then can be routed to other event receivers, such as other channels or interrupts to processors.

**Table 11-49. Event Size Encoding**

| Value | Event Type       | When it Fires                                                                                                 |
|-------|------------------|---------------------------------------------------------------------------------------------------------------|
| 0     | Completion Event | When the TR is complete and all status for the TR has been received.                                          |
| 1     | ICNT1 Decrement  | Type 0: When the last data transaction is sent for the TR.<br>Type 1-11: When ICNT1 is decremented            |
| 2     | ICNT2 Decrement  | Type 0 – 1,10-11: When the last transaction is sent for the TR.<br>All Other Types: When ICNT2 is decremented |
| 3     | ICNT3 Decrement  | Type 0 – 2,10-11: When the last transaction is sent for the TR.<br>All Other Types: When ICNT3 is decremented |

**11.1.3.3.4.3 TRIGGER\_INFO: TR Triggers**

The TR allows for two different triggers to be set to allow for the data transfer to be prevented or halted through the process of transferring the data. The triggers are specified by selecting a type of trigger and the size of the transfer that can be allowed for the receipt of a given trigger. The triggers themselves in the BCDMA are collected on a per channel basis and for each of three sources. Anytime the trigger event is received the internal counter is incremented. The trigger event will not be cleared until the specified block has started its transfer and it will **only** clear the triggers that are active.

**CAUTION**

This does allow for one TR in the channel to use global event 0 and the next TR to use global event 1. If while the first TR is running global event 0 can increment and will decrement each time the TR reaches the specified level. At the same time global event 1 will be incremented whenever it is received but it will not decrement until the next TR runs. If the global event 1 counter reaches overflows then an error event will NOT be generated but the event will be lost.

**11.1.3.3.4.4 TRIGGERX\_TYPE: Trigger Type**

The trigger type sets the value of TR\_TRIGX as shown in the addressing algorithm description. The TR\_TRIGX value allows for the temporary halting of the TR until the expected event has been received. After the given loop has been entered the selected trigger will be decremented.

#### 11.1.3.3.4.5 TRIGGERX: Trigger Selection

The TR is able to select up to 2 of 3 trigger sources for a given TR. The events can come from the dedicated local event on the BCDMA itself or from two assigned global events that come from the PSI-L interface on the BCDMA. The trigger counters are always enabled so that events can be received prior to the TR getting loaded. The trigger counters are only decremented when the trigger is active and the TR has scheduled the first transfer of the transaction.

#### 11.1.3.3.4.6 Configuration Specific Flags Definition

The configuration specific flags are specific to a given TR type. If a TR type does not require additional flags the field should be filled with 0's. Currently only Types 0-4 and Type 15 support the following configuration specific flags:

| Bit | Field           | Description                                                                                                                                                                                                                                          |
|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | <b>ISA</b>      | Indirect Source Address<br>0: Source address in TR is a directly usable pointer to the data<br>1: Source address in TR is a pointer to a 64-bit location that contains the actual pointer to the data                                                |
| 1   | <b>IDA</b>      | Indirect Destination Address<br>0: Destination address in TR is a directly usable pointer to the data<br>1: Destination address in TR is a pointer to a 64-bit location that contains the actual pointer to the data                                 |
| 2   | <b>SUPR_EVT</b> | Suppress Event Output:<br>0 = Output events will be generated according to FLAGS.EVENT_SIZE field<br>1 = No output events will be generated for the duration of this TR execution<br>This field is only valid on split and type 15 TRs (Type 0-3,15) |
| 3   | <b>Reserved</b> | Reserved for Future use.                                                                                                                                                                                                                             |

| Bit | Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | <b>EOL</b> | <p>This field is only valid on split TRs (Type 0-3). On source (Read) split TRs, this field specifies whether or not the EOL delimiters should be produced on the Tx PSI-L bus. The encodings of this field for source split TRs is as follows:</p> <p>0 = SOL/EOL match SOP/EOP<br/> 1 = SOL/EOL boundaries are each ICNT0 bytes<br/> 2 = SOL/EOL boundaries are each ICNT0*ICNT1 bytes<br/> 3 = SOL/EOL boundaries are each ICNT0*ICNT1*ICNT2 bytes<br/> 4 = SOL/EOL boundaries are each ICNT0*ICNT1*ICNT2*ICNT3 bytes</p> <p>On destination (Write) split TRs, this field specifies how to handle EOL delimiters when they are encountered on the Rx (write) side of a TR. EOL delimiters can be produced from the Tx (read) side of a block copy operation or from a remotely paired peripheral when operating in split TR mode. The encodings of this field are as follows:</p> <p>0: Ignore EOL<br/> 1: Line length is icnt0 bytes. Clear any remaining ICNT0 bytes and increment ICNT1 by 1<br/> 2: Line length is icnt0*icnt1 bytes. Clear any remaining ICNT0/1 bytes and increment ICNT2 by 1<br/> 3: Line length is icnt0*icnt1*icnt2 bytes. Clear any remaining ICNT0/1/2 bytes and increment ICNT3 by 1<br/> 4: Line length is icnt0*icnt1*icnt2*icnt3 bytes. Move on to next TR<br/> 5-7: RESERVED</p> |
| 7   | <b>EOP</b> | <p>This TR should generate an EOP on the streaming interface for any downstream packet oriented consumers to denote that a 'packet' of data is complete</p> <p>0: No EOP flag will accompany the last PSI-L data phase associated with transfers from this TR</p> <p>1: On egress the DMA will set the EOP flag coincident with transferring the last of the data for this TR. If the TR data does not complete an entire PSI-L data phase then the remaining bytes in the data phase will be skipped and the internal FIFO pointer will be updated to begin packing new data on a new data phase boundary.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 11.1.3.3.5 TR Address and Size Attributes

The fields described below all describe the data transfer that needs to be made as described in the Linear Memory Addressing Block Move Algorithm.

##### 11.1.3.3.5.1 ICNT0

The ICNT0 is the number of elements to transfer in the inner loop of the TR. If the TR type does not contain a FMTFLAGS field then this count is assumed to be the number of bytes to transfer. If the FMTFLAGS field is included in the types then the number of bytes to be transferred will be ICNT0 times the Element size rounded up to the nearest byte.

##### 11.1.3.3.5.2 ICNT1

The ICNT1 field is the loop count for the second innermost loop count as defined in the Addressing algorithm.

##### 11.1.3.3.5.3 ADDR

The address location is the initial address that will be accessed at the start of the transfer. All of the dimensions will also be based off of this value. This address can either physical or virtual based upon settings in the DMA channel Configuration register.

While the ADDR field is 64 bits wide, the usable extent of the address is up to 48 bits of absolute offset plus a 4-bit address space selector which indicates 1 of 16 different orthogonal address spaces that the pointer is referencing within. The format of the ADDR field is given as follows:

| Bits  | Subfield             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:52 | Reserved             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 51:48 | Address Space Select | Effectively bits 51:48 of the address. The value given in this field will be output by the DMA initiators on the casel pin which is used by the infrastructure as an identifier for which address space this particular memory region is located within. Address space 0 is the default unified address space for a given device. Address spaces 1-15 are used for alternate address maps which may be external to the device (PCIe/Hyperlink) or in other 'tiles' on large devices.                 |
| 47:0  | Address              | The 48-bit source or source starting address for the transfer. This address is assumed to be a physical address.<br><br>The actual width implemented for the address field on any given DMA instance may be adjusted to the needs of each specific KSLC SoC. 48 bits is just the maximum size which is envisioned to be supported. Some systems may have address widths as low as 32 or 36 bits. The HW implementation may choose to provide address width configurability in order to reduce costs. |

##### 11.1.3.3.5.4 DIM1

This is the offset of the address from the initial address for the first access of the second loop. This will be added to the address from the loop before. This is a signed value so that the address can be both above and below the initial address.

#### **11.1.3.3.5.5 ICNT2**

This is the count for the third innermost loop in the addressing algorithm.

#### **11.1.3.3.5.6 ICNT3**

This is the count for the outermost loop in the addressing.

#### **11.1.3.3.5.7 DIM2**

This is the offset of the address from the initial address to the next address in the third innermost loop. This is a signed value so that the address can be both above and below the previous address.

#### **11.1.3.3.5.8 DIM3**

This is the offset of the address from the initial address to the next address in the outermost loop. This is a signed value so that the address can be both above and below the previous address.

#### **11.1.3.3.5.9 DDIM1**

This is the offset of the destination address from the initial destination address for the first access of the second loop. This will be added to the destination address from the loop before. This is a signed value so that the destination address can be both above and below the initial destination address.

#### **11.1.3.3.5.10 DADDR**

The destination address location is the initial destination address that will be accessed at the start of the transfer. All of the dimensions will also be based off of this value. This address can either physical or virtual based upon settings in the DMA channel Configuration register

While the DADDR field is 64 bits wide, the usable extent of the address on a KSLC system is up to 48 bits of absolute offset plus a 4 bit address space selector which indicates 1 of 16 different orthogonal address spaces that the pointer is referencing within. The format of the DADDR field is given as follows:

| Bits  | Subfield             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:52 | Reserved             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 51:48 | Address Space Select | Effectively bits 51:48 of the address. The value given in this field will be output by the DMA initiators on the casel pin which is used by the infrastructure as an identifier for which address space this particular memory region is located within. Address space 0 is the default unified address space for a given device. Address spaces 1-15 are used for alternate address maps which may be external to the device (PCIe/Hyperlink) or in other 'tiles' on large devices.     |
| 47:0  | Address              | The 48-bit starting destination address for the transfer. This address is assumed to be a physical address. The actual width implemented for the address field on any given DMA instance may be adjusted to the needs of each specific KSLC SoC. 48 bits is just the maximum size which is envisioned to be supported. Some systems may have address widths as low as 32 or 36 bits. The HW implementation may choose to provide address width configurability in order to reduce costs. |

#### 11.1.3.3.5.11 DDIM2

This is the offset of the destination address from the initial destination address for the first access of the third loop. This will be added to the destination address from the loop before. This is a signed value so that the destination address can be both above and below the initial destination address.

#### 11.1.3.3.5.12 DDIM3

This is the offset of the destination address from the initial destination address for the first access of the outer loop. This will be added to the destination address from the loop before. This is a signed value so that the destination address can be both above and below the initial destination address.

#### 11.1.3.3.5.13 DICNT0

This is the number of elements to use in the destination if the TR is repacking the data. This number reflects the number of elements to be transferred.

#### 11.1.3.3.5.14 DICNT1

This is the number of times to execute the second loop to use in the destination transfer.

#### 11.1.3.3.5.15 DICNT2

This is the number of times to execute the third loop to use in the destination transfer.

#### 11.1.3.3.5.16 DICNT3

This is the number of times to execute the fourth loop to use in the destination transfer. The value of DICNT0 x DICNT1 x DICNT2 x DICNT3 must equal ICNT0 x ICNT1 x ICNT2 x ICNT3. If any of the values are zero they are NOT included in the multiplication.

#### 11.1.3.4 Transfer Response Record

Upon completing a TR, the BCDMA will send back a TR Response. The BCDMA TR response format is a single 32 bit word as shown in the [Table 11-51](#) below.

**Table 11-50. Transfer Request Response Template STATUS FLAGS Field**

|                               |             |    |             |
|-------------------------------|-------------|----|-------------|
| 31                            | 24          | 23 | 16          |
| CONFIGURATION SPECIFIC STATUS | RESERVED    |    |             |
| 15                            | 8           | 7  | 7 4 3 0     |
| RESERVED                      | STATUS_INFO |    | STATUS_TYPE |

**Table 11-51. STATUS FLAGS Field Descriptions**

| Bit   | Field       | Description                                                  |
|-------|-------------|--------------------------------------------------------------|
| 3:0   | STATUS_TYPE | The completion status of the TR.                             |
| 7:4   | STATUS_INFO | Information that is unique based on the STATUS_TYPE returned |
| 15:8  | Reserved    | Reserved for Future use                                      |
| 23:16 | Reserved    | Reserved for Future use                                      |

**Table 11-51. STATUS FLAGS Field Descriptions (continued)**

| Bit   | Field                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | <b>Configuration Specific Flags</b> | <p>These are flag bits that can be specified by the specific BCDMA configuration. These bits will remain undefined in the global TR format to allow for customization requirements that might be required in the specific BCDMA implementation.</p> <p>For BCDMA channels which are capable of interfacing to endpoint peripherals (or via a PDMA) the format of these flags are as follows:</p> <p>31:28 error_flags – the error_flags field as is provided across PSI-L</p> <p>27:24 ps_flags – the ps_flags field as is provided across PSI-L</p> |

#### 11.1.3.4.1 STATUS Field Definition

The Status field is made up of two sub-fields STATUS\_TYPE and STATUS\_INFO. A value of 0 means it completed as requested any other value means an error has occurred. The Table below states the legal STATUS\_TYPES and the use of the STATUS\_INFO in each case.

##### 11.1.3.4.1.1 STATUS\_TYPE Definitions

The STATUS\_TYPE field is used to determine what type of status is being returned. Depending on the type of Status it might additionally have information in the STATUS\_INFO to give more details about the specific reason why the status was returned.

**Table 11-52. STATUS\_TYPE Encoded Values**

| Value | Error Type          | Completion      | STATUS INFO Definition           |
|-------|---------------------|-----------------|----------------------------------|
| 0     | None                | Complete        | None                             |
| 1     | Transfer Error      | None to Partial | CBA Non-Complete Status Received |
| 2     | Aborted Error       | None to Partial | None                             |
| 3     | Submission Error    | None            | Submission Error Type            |
| 4     | Unsupported Feature | None            | Feature Type                     |
| 5     | Transfer Exception  | Partial         | Exception Type                   |
| 6     | Teardown Flush      | None            | None                             |
| 7-15  | Reserved            | Unknown         | Reserved                         |

##### 11.1.3.4.1.1.1 Transfer Error

A transfer error occurs anytime that one of the CBA transactions performed by the BCDMA returns a status other than complete. The BCDMA may continue the transfer or may abort the transfer and return back to an IDLE state. Once the transfer is finished (aborted or complete) the BCDMA will send back the TR Response with the STATUS\_TYPE of Transfer Error. The STATUS\_INFO will contain the 3 bit CBA Status field the upper bit specifies if it was a read status (1) or a write status (0).

##### 11.1.3.4.1.1.2 Aborted Error

An aborted error occurs if the PSI-L interface asserts the drop signal prior to the completion of the TR. The BCDMA will return back to an IDLE state and send back the TR Response with the STATUS\_TYPE. If the

BCDMA receives a transfer error after receiving the abort the transfer error should be reported instead of the abort error.

#### 11.1.3.4.1.1.3 Submission Error

A submission error is returned for a TR that is received that cannot be run. The STATUS\_INFO field specifies the type of submission errors.

**Table 11-53. Submission Error STATUS\_INFO Encodings**

| Value | Submission Error Type                                                                                      |
|-------|------------------------------------------------------------------------------------------------------------|
| 0     | ICNT0 was 0                                                                                                |
| 1     | Channel FIFO was full when TR received                                                                     |
| 2     | Channel is not owned by the submitter. Either CC submitting to Direct or Direct submitting to a CC channel |
| 3     | Reserved                                                                                                   |
| 4     | Reserved                                                                                                   |
| 5     | Bad descriptor type                                                                                        |
| 6-15  | Reserved                                                                                                   |

#### 11.1.3.4.1.1.4 Unsupported Feature

An unsupported feature error is returned for a TR that is received that cannot be run because it specifies a feature that is optional and not supported by the BCDMA that received the TR. The STATUS\_INFO specifies the feature that was not supported. If it specifies multiple features that were not supported the BCDMA implementation can determine which type it wants to return.

**Table 11-54. Unsupported Feature STATUS\_INFO Encodings**

| Value | Submission Error Type                |
|-------|--------------------------------------|
| 0     | TR Type not supported                |
| 1     | STATIC not supported                 |
| 2     | EOL not supported                    |
| 3     | CONFIGURATION SPECIFIC not supported |
| 4     | AMODE not supported                  |
| 5     | ELTYPE not supported                 |
| 6     | DFMT not supported                   |
| 7     | SECTR not supported                  |
| 8     | AMODE SPECIFIC Field not supported   |
| 9-15  | Reserved                             |

#### 11.1.3.4.1.1.5 Transfer Exception

A transfer exception is returned for a TR that completed but experienced a known exception during reception. The STATUS\_INFO field specifies the type of transfer exception that was encountered.

**Table 11-55. Transfer Exception STATUS\_INFO Encodings**

| Value | Transfer Exception Type                                                |
|-------|------------------------------------------------------------------------|
| 0     | EOP on incoming data stream was encountered prematurely (short packet) |
| 1     | EOP on incoming data stream was encountered late (long packet)         |

**Table 11-55. Transfer Exception STATUS\_INFO Encodings (continued)**

| Value | Transfer Exception Type |
|-------|-------------------------|
| 2-15  | Reserved                |

#### 11.1.3.4.1.1.6 Teardown Flush

Split mode BCDMA Rx channels (write channels) can respond with a teardown flush in the case that they have received a teardown message, all data has been transferred, and TRs have been prefetched (in anticipation of more data being received). In this case, the BCDMA will simply return the prefetched TR to the completion queue with the status type set to teardown flush.

#### 11.1.3.5 Channels

Each DMA controller instance contains one or more channels. A channel represents a single thread of strongly ordered operations whose purpose is to move data from one interface to another. Operations between channels are orthogonal and have no assumption of ordering but operations within a channel must be completed in order. The DMA controller uses time division multiplexing to allow work from channels to momentarily use shared data transfer units and data paths.

#### 11.1.3.6 Flows

Each DMA channel will provide one or more flows which allow communication with one or more SW hosts. Each flow contains a single queue pair implemented within a shared circular buffer (ring) in memory. One queue provides uni-directional communication from SW to the DMA while the other queue provides uni-directional communication from the DMA back to SW. Flows are intended to allow traffic which is produced or consumed by a different Host SW process or traffic which is on different priorities to share a single physical DMA channel. A DMA channel will perform time division multiplexing between flows on specific work boundaries. Once a channel is in work on a specific flow, that entire unit of work will be completed before allowing work from a different flow to begin.

#### 11.1.3.7 Queues

Queues are used to hold either values or references that need to be passed between SW and HW components in the system. Queues are implemented in the PKTDMA and BCDMA modules using memory mapped rings. Each ring is comprised of a single contiguous memory block which contains an array of elements. Each element is 8 bytes. The size of the ring is selectable from 1 entry up to 64K entries with single entry granularity. Each ring is used to implement a forward and a reverse queue which share the same data elements but which have independent pointers and occupancies. The forward queue is used to pass work from SW to HW and the reverse queue is used to pass completed work back from HW to SW. A doorbell MMR is provided per ring to allow SW to add elements to the forward queue. A separate doorbell MMR is provided per ring to allow SW to acknowledge the popping of elements from the reverse queue. An occupancy MMR is provided for the reverse queue so that SW can know how many entries are currently completed. Entries are returned on the reverse queue in the exact same order and in the exact same index as the work was provided on the forward queue and because of this, the DMA controllers do not actually modify the ring entry for completion operations (the only exception being for acknowledgement of a teardown operation). Completion is indicated by incrementing of the reverse occupancy only.

#### 11.1.3.7.1 Queue Types

##### 11.1.3.7.1.1 Transmit Queues

Tx channels use packet queues referred to as “transmit queues” to store the packets that are waiting to be transmitted. Tx Queues only pass a pointer to a descriptor. For the PKTDMA, Tx Queues contain pointers to Host descriptors. For the BCDMA, pass Tx Queues contain a pointer to a TR packet descriptor. Transmit Queues are implemented as the forward queue on the shared ring structure for a Tx flow.

#### 11.1.3.7.1.2 Transmit Completion Queues

Tx channels also use packet queues referred to as “transmit completion queues” to return packets to the host after they are transmitted. A Tx Completion Queue is provided for each Tx Queue. The DMA controllers do not actually write anything back to completion queues (except for a teardown acknowledgement) but instead just increment the reverse occupancy. Transmit completion queues are implemented as the reverse queue on the shared ring structure for a Tx flow.

#### 11.1.3.7.1.3 Free Descriptor / Buffer Queues

Free descriptor/buffer queues pass an empty list of pre-chained descriptors, each pointing to a single buffer, from SW to the DMA to use for receiving incoming packets. Free Descriptor/Buffer Queues are implemented as the forward queue on the shared ring structure for an Rx flow.

#### 11.1.3.7.1.4 Receive Queues

Rx queues pass a packet which has been received from the DMA back to the SW. Receive queues are implemented as the reverse queue on the shared ring structure for an Rx flow.

#### 11.1.3.7.1.5 Ring Based Queues Implementation

Work packets which are stored in a queue are shown in the following diagram:



Figure 11-3. Ring Based Queue Structure

### 11.1.4 Operational Description

#### 11.1.4.1 Resource Allocation

Rings, memory, interrupts, DMA channels, and flow table entries are shared resources within the data movement architecture and their ownership and use must be managed in order to provide stable, safe, and secure operation. The DMSS provides channelized firewalls which can be used to protect arrayed resources (like rings, channel control MMRs, etc.) from unwanted/unauthorized use as well as restricted access to the firewall configurations themselves. It is outside the scope of this document to define how the resource management system functions but it is assumed that all of these resources are isolate-able and secure-able.

#### 11.1.4.2 PKTDMA/BCDMA - Ring Operation

##### 11.1.4.2.1 Queue Initialization

The base address and size for each ring must be initialized via the provided MMRs prior to using the ring. Ring initialization is typically done only on channel / flow setup as once initialized the rings can be used indefinitely.

##### 11.1.4.2.2 Queueing Entries

Entries can only be queued by SW onto the forward queue of a ring. To queue an entry the producer will write the entry contents (typically a pointer to the Packet Descriptor or a TR) to the memory location pointed to by the current write pointer and will decrement its internally maintained free entry occupancy. After the producer has confirmed that the data has actually landed in memory, it will then write to the forward doorbell register (RINGRT[a].RT\_FDB) for the ring to increment the pending forward occupancy count for the ring.

More than one entry can be queued with a single doorbell write as the entry count in the doorbell write indicates how many entries have been queued.

##### 11.1.4.2.3 De-queueing Entries

Entries can only be de-queued by SW from the reverse queue of a ring. The consumer (entity which is going to de-queue an entry from the ring) maintains a current read pointer for each ring it controls. To de-queue an entry the consumer will read the occupancy from the reverse occupancy register (RINGRT[a].RT\_ROCC) and will then read the entry contents from the memory location pointed to by the current read pointer. The consumer will then write a decrement value to the reverse doorbell register (RINGRT[a].RT\_ROCC) for the ring to decrement the waiting occupancy count for the reverse queue within the ring and will increment its internally maintained free entry occupancy for the ring.

#### 11.1.4.3 PKTDMA/BCDMA - Output Event Generation

Each channel and flow within a DMA has the ability to generate specific types of events which can be routed to the IA in the system and from there re-routed to any event consumer. Events are output from the DMA controllers using a simple integer encoding. Up to 4 events can be generated from any given channel but only event types which have functional value are supported on each specific type of channel. The DMA channel event types are listed as follows:

**Table 11-56. Per-Channel/Flow Event Support and Encoding**

| Name                     | Description                                                                                                                                                                        | Per  | BCDMA<br>BC | BCDMA<br>Tx | BCDMA<br>Rx | PKTDMA<br>Tx | PKTDMA<br>Rx |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|-------------|-------------|--------------|--------------|
| Ring Entry Zero/Non-zero | Asserts an up event anytime the ring transitions to a non-zero occupancy / teardown state. Asserts a down event anytime the ring transitions to a zero occupancy / teardown state. | Flow | X           | X           | X           | X            | X            |

Table 11-56. Per-Channel/Flow Event Support and Encoding (continued)

| Name             | Description                                                                                                                                                                                                                      | Per     | BCDMA BC                   | BCDMA Tx                   | BCDMA Rx                   | PKTDMA Tx                  | PKTDMA Rx                  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
| Channel Error    | Asserts an up event anytime an error occurs on the channel. Asserts a down event when the channel error bit is cleared.                                                                                                          | Channel | First flow in channel only |
| Rx Starvation    | Asserts an up event when starvation occurs on a flow. Asserts a down event when entries are added to the ring for that flow.                                                                                                     | Flow    |                            |                            |                            |                            | First flow in channel only |
| RX Flow FW Error | Asserts an up event when a flow id arrives on the RX interface that is not between the flowid_start and flowid_end values for the channel. Asserts a down event when the RX Flow ID Firewall Status Register pend bit is cleared | Pktdma  |                            |                            |                            |                            | X                          |
| Data Events      | Asserts an up event when the selected loop counter has decremented. If the suppress event bit is not set in the TR                                                                                                               | Channel | X                          | X                          | X                          |                            |                            |

Each BCDMA/PKTDMA instance will provide an event transport-lane (ETL) interface to pass outgoing events. The index field on this ETL will be calculated based on the event type and channel or flow offset. Each PKTDMA or BCDMA instance is configured with base values to which a channel or flow index is added for each type of event which can be generated. These base index values are listed in the specification for that specific instantiation of each DMA and are named as follows:

**Table 11-57. BCDMA/PKT DMA Event Base Index Parameters**

| DMA    | Event Base Parameter Name | Function                                                             | Offset            |
|--------|---------------------------|----------------------------------------------------------------------|-------------------|
| PKTDMA | tcomp_evtbase             | Base index for Tx flow reverse ring completion events                | Tx flow number    |
|        | rcomp_evtbase             | Base index for Rx flow reverse ring completion events                | Rx flow number    |
|        | terr_evtbase              | Base index for Tx channel error events                               | Tx channel number |
|        | rerr_evtbase              | Base index for Rx channel error events                               | Rx channel number |
|        | rstarve_evtbase           | Base index for Rx flow starvation events                             | Rx flow number    |
|        | rflowfw_evtbase           | Base index for Rx Flow Firewall event                                | None              |
| BCDMA  | tcomp_evtbase             | Base index for split Tx flow reverse ring completion events          | Tx flow number    |
|        | rcomp_evtbase             | Base index for split Rx flow reverse ring completion events          | Rx flow number    |
|        | bcomp_evtbase             | Base index for normal Block Copy flow reverse ring completion events | BC flow number    |
|        | terr_evtbase              | Base index for split Tx channel error events                         | Tx channel number |
|        | rerr_evtbase              | Base index for split Rx channel error events                         | Rx channel number |
|        | berr_evtbase              | Base index for normal Block Copy channel error events                | BC channel number |
|        | tdcomp_evtbase            | Base index for Tx channel TR data completion events                  | Tx channel number |
|        | rdcomp_evtbase            | Base index for Rx channel TR data completion events                  | Tx channel number |
|        | bdcomp_evtbase            | Base index for Block Copy channel TR data completion events          | BC channel number |

Example:

The producer event map is set up so that the Tx flows from a PKTDMA instance are to start at 64 and proceed upward from there. The tcomp\_evtbase for that PKTDMA instance is set to 64. In this configuration, the reverse ring entry completion event for flow 0 will produce an event on index 64, flow 1 will produce an event on index 65, etc. The terr\_evtbase for the same PKTDMA instance is set to 128. In this configuration, error events for channel 2 would produce events with an index of 130.

#### 11.1.4.4 PKTDMA - Transmit Channel Setup

This section describes the setup procedure for Tx channels within the PKTDMA. After a reset or a previous teardown operation but before queuing packets to a channel the host must initialize the channel's Tx Port DMA State. The host initializes the channel Tx Port DMA State by configuring all of the Tx flow entries for the channel and then writing to the Tx Channel Configuration Register A (TCHAN[a]\_TCFG). The Host may choose to write

the enable bit in the Tx Channel Configuration Register A (TCHAN[a]\_TCFG) at the same time or after it has written all of the channel parameters but note that every write to the Tx Channel Configuration Registers will overwrite the channel state for all bytes that are enabled for the write transaction.

After a Transmit channel has been set up, packets can be added to the Queues for the channel to begin the transmit operation. The following sections describe how the transmit operations are performed for the various descriptor types.

#### 11.1.4.5 PKTDMA - Transmit Channel Pause

Setting the tx\_pause bit in the Tx Channel N Real-time Control Register (<TCHANRT[a]\_TRT\_CTL > [29] TX\_PAUSE) will suspend the channel from arbitration resulting in a halting of the flow of data. Clearing this bit will cause the channel to be added back into the arbitration list. Pausing a channel has no other destructive side effects (other than potential underrun/overrun conditions from a downstream data sink or upstream data source).

#### 11.1.4.6 PKTDMA - Transmit Channel Teardown

This section describes the teardown procedure for internal Tx channels within the PKTDMA. A Tx channel teardown is initiated by the host by writing the tx\_teardown bit in the Tx Channel N Real-time Control Register (<TCHANRT[a]\_TRT\_CTL > [30] TX\_TEARDOWN).

Once the host has written the tx\_teardown bit, the PKTDMA will do the following:

1. Stops performing any additional descriptor fetches for the channel.
2. Completes any packets normally for which a pointer/descriptor/TR fetch has already been performed.
3. Sets the tdown bit on the EOP data phase of the last packet to be sent (if any traffic was pending when teardown was initiated) or sends a zero byte packet with the tdown, sop, and eop bits asserted. This signals the destination thread that all of the data has been sent.
4. Clears the channel enable in the Tx Channel N Global Configuration Register (<TCHANRT[a]\_TRT\_CTL> [31] TX\_ENABLE).
5. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
6. Sets bit 31 of the Tx Flow Reverse Ring Occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) to indicate that a teardown has completed.
7. If the current Tx reverse ring occupancy is 0, issues an Tx reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.
8. If the current TX Reverse ring occupancy is not 0 then a write to the doorbell with a negative value of the current occupancy will clear any remaining work but the forward ring pointer will remain the same. If the ring pointer needs to be reset then perform a write to any of the ring configuration registers.
9. The host may issue a teardown on any channel at any time, regardless of whether the channel is actively receiving a packet or not.

The Host can determine that a teardown is complete by using either of the following methods:

1. Periodically polling the teardown and enable bits for the channel
2. Waiting for an interrupt and observing the teardown complete bit is set in the channel's default flow (first flow in channel) reverse occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) for the channel.

#### 11.1.4.7 PKTDMA - Transmit Operation

After a channel has been set up it can begin to be used to transmit packets. Packet transmission involves the following steps:

1. The Host is made aware of one or more chunks of data in memory that need to be transmitted as a packet. This may involve directly sourcing data from the Host or it may involve data which has been forwarded from another data source in the system.
2. The Host allocates and populates a host packet descriptor. The host will initialize the following fields within the packet descriptor:
  - a. Descriptor Type (set to Host).

- b. Packet Length indicating the total number of bytes that are to be read from all of the buffers for this packet.
  - c. Source Tag.
  - d. Destination Tag.
  - e. Packet Type.
  - f. Any protocol specific flags for the given packet type.
  - g. Buffer Pointer with the byte aligned address of the first chunk of buffer data.
  - h. Buffer Length with the number of bytes in the first chunk of buffer data.
  - i. The Next Descriptor Pointer with the 16-byte aligned address of the next descriptor in this packet. If this is the last chunk of data in the packet, this field must be set to zero.
  - j. Any protocol specific descriptor sections that are required for the given packet type or system configuration.
3. The Host allocates and populates host buffer descriptors as necessary to point to any remaining chunks of data that belong to this packet. The host will initialize the following fields within the host buffer descriptor:
- a. Buffer Pointer with the byte aligned address of the given chunk of buffer data.
  - b. Buffer Length with the number of bytes in the given chunk of buffer data.
  - c. The Next Descriptor Pointer with the 16-byte aligned address of the next descriptor in this packet. If this is the last chunk of data in the packet, this field must be set to zero.
4. The Host writes queues the packet onto one of the Transmit Queues for the desired DMA channel. Channels may provide more than one Tx Queue (if more than 1 flow is provided) and may provide a particular prioritization policy between the queues. This behavior is application specific and is controlled by the DMA controller / scheduler implementation.
5. The PKTDMA internally generates a level sensitive status signal for the queue which indicates if any packets are currently pending. This level sensitive status line is sent to the hardware block which is responsible for scheduling DMA operations.
6. The PKTDMA Tx engine is eventually brought into context for the corresponding channel and begins to process the packet.
7. The PKTDMA reads the packet descriptor pointer from the memory mapped ring for that channel/flow.
8. The PKTDMA reads the packet descriptor from memory.
9. The PKTDMA empties each buffer in sequence by transmitting the contents in one or more block data moves. The size of these blocks is application specific. The PKTDMA module specification is intended to document the block size used by a given implementation. As each buffer is emptied, the PKTDMA will read the next buffer descriptor to obtain the pointer and size of the data buffer as well as the pointer to the next descriptor in the chain.
10. When all data for the packet has been transmitted as specified in the packet size field, the DMA will increment the occupancy of the reverse queue (Tx Completion Queue).
11. After the occupancy is incremented, the PKTDMA will indicate the status of the Tx Completion Queue by sending an up event.
12. The Interrupt Aggregator receives the up event and sets the corresponding bit in the interrupt status register (VINT[a]\_STATUS\_SET) as programmed in the interrupt mapping registers. This in turn causes an interrupt to the Host to be generated.
13. The Host responds to the status change from the PKTDMA (via the Interrupt Aggregator) and performs garbage collection as necessary for the packet.
14. During garbage collection the Host will write to the reverse queue Doorbell register (RINGRT[a]\_RT\_RDB) for the channel/flow to acknowledge the popping of those completed packets. The doorbell writes eventually cause the queue to become empty.
15. The PKTDMA will send a down event to the Interrupt Aggregator which will clear the corresponding bit in the Interrupt Status Register (VINT[a]\_STATUS) and potentially de-assert the interrupt line.

#### **11.1.4.8 PKTDMA - Receive Free Descriptor / Buffer Queue Setup**

The Host is ultimately responsible for providing all of the free descriptors and buffers that the port uses as it receives packets. Each entry on the Rx Free Descriptor/Buffer Queue consists of one or more descriptors chained together with each descriptor also pointing to a single contiguous buffer. Each entry on the Rx Free

Descriptor/Buffer queue is intended to receive one packet of data. All chaining of descriptors within a packet is performed prior to placing the Rx resources onto the free queues.

Before the Host adds each Rx buffer descriptor chain to the queue, it must first initialize the Rx buffer descriptor values as follows:

- Write the Buffer Pointer with the byte aligned address of the buffer data
- Write the Buffer Size
- Write the next descriptor pointer to the next descriptor in the chain (non-eop) or to 0x0 (eop)

All other fields in the Descriptor do not need to be initialized as they will be overwritten by the Port on reception.

#### 11.1.4.9 PKTDMA - Receive Channel Setup

After a reset or a previous teardown operation but before receiving packets on a channel the host must initialize the channel's Rx Port DMA State. The host initializes the channel Rx Port DMA State by writing to the Rx Channel Configuration Registers. The Host may choose to write the enable bit in the Rx Global Channel Configuration Register (<RCHANRT[a]\_RRT\_CTL> [31] RX\_ENABLE) at the same time or after it has written all of the channel parameters but note that every write to the Rx Channel Configuration Registers will overwrite the channel state for all bytes that are enabled for the write transaction.

#### 11.1.4.10 PKTDMA - Receive Channel Teardown

An Rx channel teardown is intended to be initiated at the data source (the source thread). Initiation is commanded by the host by writing the teardown bit in the PSI-L source thread register 0x408. This will cause the source of the data to gracefully terminate any packet that is in flight and send a PSI-L data phase with the tdown signal asserted. When the PKTDMA receives a data phase with the tdown attribute asserted it will immediately set the internal rx\_teardown bit in the Rx Channel N Real-time Control Register (<RCHANRT[a]\_RRT\_CTL> [30] RX\_TEARDOWN).

Once a teardown has been initiated, the PKTDMA will do the following:

1. Completes any packets normally which may be pending in the ingress port buffers (what the port considers as pending packets is application specific).
2. Clears the channel enable in the Rx Channel Global Configuration Register (<RCHANRT[a]\_RRT\_CTL> [31] RX\_ENABLE).
3. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
4. Sets bit 31 of the Rx Flow Reverse Ring Occupancy register to indicate that a teardown has completed (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE).
5. If the current Rx reverse ring occupancy is 0, issues an Rx reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.
6. If the current RX Reverse ring occupancy is not 0 then a write to the doorbell with a negative value of the current occupancy will clear any remaining work but the forward ring pointer will remain the same. If the ring pointer needs to be reset then perform a write to any of the ring configuration registers.

The host may issue a teardown on any channel at any time, regardless of whether the channel is actively receiving a packet or not. The normally intended method of issuing a teardown on a packet mode channel is to initiate the teardown at the remote PSI-L data source and allow it to flow into the PKTDMA. If that is not possible, the host may write the rx\_teardown bit directly to a 1.

The Host determines that a teardown is complete by using either of the following methods:

1. Periodically polling the teardown and enable bits for the channel
2. Waiting for an interrupt and observing the teardown complete bit is set in the channel's default flow (first flow in channel) reverse occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) for the channel.

#### 11.1.4.11 PKTDMA - Receive Channel Pause

Setting the rx\_pause bit in the Rx Channel N Control Register (<RCHANRT[a]\_TRT\_CTL> [29] RX\_PAUSE) will suspend the channel from arbitration resulting in a halting of the flow of data. Clearing this bit will cause the channel to be added back into the arbitration list. Pausing a channel has no other destructive side effects (other than potential underrun/overrun conditions from a downstream data sink or upstream data source).

#### 11.1.4.12 PKTDMA - Receive Operation

When packet reception begins on a given channel, the port will begin by fetching the descriptor and buffer from the ring for the channel / flow. If the SOP Buffer Offset in the Rx Flow Table entry is nonzero, then the port will begin writing data after the offset number of bytes in the SOP buffer. The port will then continue filling that buffer and will fill additional descriptors + buffers as needed using the pre-linked buffers in the packet.

A detailed summary is as follows:

1. Host allocates, populates, and places pointers to free descriptor/buffer structures onto Rx Free Descriptor/ Buffer Queues
2. PKTDMA fetches packet descriptor pointer from forward queue of ring for specified channel.
3. PKTDMA reads the packet descriptor to obtain the packet info, buffer pointer, buffer size, and next descriptor pointer.
4. PKTDMA fills the buffer with received data

If packet is not complete and the rx\_chan\_type field in the Rx Channel Configuration Register (<RCHAN[a]\_RCFG> [19:16] RX\_CHAN\_TYPE) is set to 2 (Normal Rx Host Mode). The machine will proceed to step 5 and will repeat steps 5-6 until all packet data is received at which point the Rx engine proceeds to step 8. If the rx\_desc\_type is set to 3 (Single Buffer Packet Host Mode) the Rx engine will proceed directly to step 7 regardless of whether or not an end of packet terminator has been reached on the incoming data stream. The current packet will be completed following the sequence through step 12 and a new packet will be started back at step 1.

5. PKTDMA fetches next buffer descriptor using next descriptor pointer obtained from previous descriptor.
6. PKTDMA fills the buffer with received data.

The PKTDMA performs the following operations when the entire packet has been received:

7. PKTDMA writes the packet descriptor to memory. This includes the following fields:
  - a. Descriptor Type (set to Host)
  - b. Packet Length indicating the total number of bytes that are to be read from all of the buffers for this packet.
  - c. Source Tag
  - d. Destination Tag
  - e. Packet Type
  - f. Any protocol specific flags for the given packet type
  - g. Any protocol specific words that are required for the given packet type
  - h. Extended Packet Information (optional)
8. PKTDMA increments the occupancy of the reverse queue for the channel / flow.
9. Once the occupancy is incremented it will send an up event to the Interrupt Aggregator
10. The Interrupt Aggregator upon receiving the up event will set the appropriate bit in the Interrupt Status Register (VINT[a]\_STATUS\_SET) indicated by the interrupt mapping table which will cause an interrupt to be asserted to the Host
11. The Host will pop the packet pointer from the Rx Queue by reading the ring contents and then pushing a decrement to the reverse occupancy for the ring.

12. If the pop causes the queue to become empty, the PKTDMA will send a down event to the Interrupt Aggregator thus causing the associated bit to be cleared and also potentially clearing the interrupt to the Host.

#### 11.1.4.13 BCDMA - Block Copy Channel Setup

This section describes the setup procedure for channels within the BCDMA. After a reset or a previous teardown operation but before queuing packets to a channel the host must initialize the channel's Port DMA State. The host initializes the channel Port DMA State by initializing all of the channel flow entries and then writing to the Block Copy Channel Configuration Register A (BCHANRT[a]\_TRT\_CTL). The Host may choose to write the enable bit in the Block Copy Channel Configuration Register A (<BCHANRT[a]\_TRT\_CTL> [31] TX\_ENABLE) at the same time or after it has written all of the channel parameters but note that every write to the Channel Configuration Registers will overwrite the channel state for all bytes that are enabled for the write transaction.

After a channel has been set up, packets can be added to the Queues for the channel to begin the copy operation.

For general purpose block copy channels, only the Block Copy DMA configuration, flow, and real-time registers will be present. For split mode channels, separate Tx and Rx configuration, flow, and real-time registers are provided. In all cases, configuration of all fields must be completed before a channel is enabled.

#### 11.1.4.14 BCDMA - Block Copy Channel Pause

Setting the pause bit in the Channel N Control Register (<BCHANRT[a]\_TRT\_CTL> [29] TX\_PAUSE) will suspend the channel from arbitration resulting in a halting of the flow of data. Clearing this bit will cause the channel to be added back into the arbitration list. Pausing a channel has no other destructive side effects (other than potentially overflowing trigger events).

#### 11.1.4.15 BCDMA - Block Copy Channel Teardown

This section describes the teardown procedure for generic block copy channels within the BCDMA. A channel teardown is initiated by the host by writing the teardown bit in the Channel N Real-time Control Register (<BCHANRT[a]\_TRT\_CTL> [30] TX\_TEARDOWN). When the host initiates teardown, it can choose to perform either a graceful (no data loss) or forced teardown of the channel depending on the setting of the forced\_teardown bit in the Channel N Real-time Control Register (<BCHANRT[a]\_TRT\_CTL> [28] TX\_FORCED\_TEARDOWN).

If the forced\_teardown bit is clear, a normal teardown has been initiated. In this case, the BCDMA will do the following:

1. Stops performing any additional fetches for the channel.
2. Completes any packets normally for which a pointer/descriptor/data fetch has already been performed
3. Sets the tdown bit on the EOP data phase of the last packet to be sent (if any traffic was pending when teardown was initiated) or sends a zero byte packet with the tdown, sop, and eop bits asserted. This signals the destination thread that all of the data has been sent.
4. Clears the channel enable in the Channel N Global Configuration Register (<BCHANRT[a]\_TRT\_CTL> [31] TX\_ENABLE).
5. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
6. Sets bit 31 of the BC Flow Reverse Ring Occupancy register to indicate that a teardown has completed.
7. If the current BC reverse ring occupancy is 0, issues an BC reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.
8. If the current BC Reverse ring occupancy is not 0 then a write to the doorbell with a negative value of the current occupancy will clear any remaining work but the forward ring pointer will remain the same. If the ring pointer needs to be reset then perform a write to any of the ring configuration registers.
9. If the forced\_teardown bit is set, a destructive teardown has been initiated. In this case, the BCDMA will do the following:
  - a. Suspends any triggers to allow the channel to operate even if the trigger source is no longer functioning.
  - b. Completes any packets which have been fetched with or without transferring any data or generating events (the implementation has the option of doing whichever is simplest for that implementation).

- c. Clears the channel enable in the Channel Global Configuration Register.
- d. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
- e. Sets bit 31 of the BC Flow Reverse Ring Occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) to indicate that a teardown has completed.
- f. If the current BC reverse ring occupancy is 0, issues an BC reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.

The host may issue a teardown on any channel at any time, regardless of whether the channel is actively transferring data or not.

The Host determines that a teardown using either of the following methods:

- a. Periodically polling the teardown and enable bits for the channel
- b. Waiting for an interrupt and observing the teardown complete bit is set in the channel's default flow (first flow in channel) reverse occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) for the channel.

Note that the teardown message will actually be written to the next available location in the ring following the last completed packet.

#### **11.1.4.16 BCDMA - Block Copy Operation (TR Packet)**

Packet transmission in TR Packet mode involves the following steps:

1. The Host allocates and populates a type 15 TR packet descriptor. The host will initialize the following fields within the packet descriptor:
  - a. Descriptor Type (set to TR)
  - b. Reload Enable to 1 if looping is required, otherwise 0
  - c. Reload Index to an appropriate offset if Reload Enable set, otherwise 0
  - d. Last Entry to TR count minus 1
  - e. TR Nominal Element Size to a value that is as large as required for any given TR in the buffer
  - f. A set of one or more valid Transfer Request records whose quantity matches the last index specified previously.
2. The Host queues the packet onto one of the Block Copy Queues for the desired BCDMA channel. Channels may provide more than one Queue (1 queue per provided flow) and may provide a particular prioritization policy between the queues. This behavior is application specific and is controlled by the DMA controller/scheduler implementation.
3. The BCDMA internally provides a level sensitive status signal for the queue which indicates if any work is currently pending. This level sensitive status line is sent to the hardware block which is responsible for scheduling DMA operations.
4. The DMA controller is eventually brought into context for the corresponding read channel and begins to process the packet.
5. The DMA controller reads the packet descriptor pointer from the ring in memory.
6. The DMA controller reads the packet descriptor from memory
7. The DMA controller sequentially empties the data region in the descriptor by reading the contents in one or more nominal TR sized block data moves. As a TR is read from the descriptor, it is stored in the internal state of the DMA channel until it is completed.
8. All of the data transfers specified in a TR will be completed as a series of reads followed later on by a set of corresponding writes (which may or may not be the same size based on the parameters in the block copy TR).
9. The BCDMA will wait until write status returns for the final write operation that was initiated for each TR. When the final write status is returned within each TR, the BCDMA will write the response into the TR buffer in the Transfer Response records array. Each response is written into an array index which directly matches the index of the request record to which it corresponds.

10. When all Transfer Requests in the packet have been processed and all Transfer Responses have been written back and confirmed to have landed in memory, the BCDMA will increment the reverse occupancy for the channel/flow.
11. After the occupancy is incremented, the BCDMA will indicate the status of the Tx Completion Queue by sending an up event.
12. The Interrupt Aggregator receives the up event and sets the corresponding bit in the interrupt status register (VINT[a]\_STATUS\_SET) as programmed in the interrupt mapping registers. This in turn causes an interrupt to the Host to be generated.
13. The Host responds to the status change from the BCDMA (via the Interrupt Aggregator) and performs garbage collection as necessary for the packet.
14. During garbage collection the Host will write to the reverse queue Doorbell register (RINGRT[a]\_RT\_RDB) for the channel/flow to acknowledge the popping of those completed packets. The doorbell writes eventually cause the queue to become empty.
15. The BCDMA will send a down event to the Interrupt Aggregator which will clear the corresponding bit in the Interrupt Status Register (VINT[a]\_STATUS) and potentially de-assert the interrupt line

#### 11.1.4.17 BCDMA - Block Copy Error/Exception Handling

There are 3 specific errors which may be encountered during generic block copy operation and which are trapped by the BCDMA. The following table lists the errors and how the BCDMA will process them:

**Table 11-58. BCDMA Generic Block Copy Mode Error / Exception Handling**

| Condition           | Pauses Channel            | Error Flag Set in Channel | Data Transfer | TR Flush     | Outputs Transfer Events |
|---------------------|---------------------------|---------------------------|---------------|--------------|-------------------------|
| TR null icnt0       | Selectable <sup>(1)</sup> | Yes                       | No            | Just that TR | No                      |
| Unsupported TR Type | Selectable <sup>(1)</sup> | Yes                       | No            | Just that TR | No                      |
| Bus Errors          | Selectable <sup>(1)</sup> | Yes                       | Yes           | No           | Yes                     |

(1) If pause\_on\_error bit is set in channel configuration

##### 11.1.4.17.1 Null Icnt0 Error

The icnt0 parameter in a TR is never allowed to be 0 as this would cause zero byte count transactions to be issued on the bus and is unproductive wrt completion of any useful work. The Block Copy engine in the BCDMA will trap any TR for which the icnt0 is zero and will immediately return a transfer response with the TR icnt0 error conditions set without performing any data transfer and without outputting any events (including end of TR event).

##### 11.1.4.17.2 Unsupported TR Type

If a TR is provided to a channel which is of a type which is not supported by the channel, the Block Copy engine in the BCDMA will trap that TR and immediately return a transfer response with the Unsupported TR error conditions set without performing any data transfer and without outputting any events (including end of TR event).

##### 11.1.4.17.3 Bus Errors

If a bus error is encountered during transmit the BCDMA will log the error by asserting the tx\_error bit for the channel (and optionally sending an error event if enabled) but the DMA will continue to attempt to complete the transfer using the returned (and potentially incorrect) data.

#### 11.1.4.18 BCDMA - Split Transmit Channel Setup

This section describes the setup procedure for split Tx channels within the BCDMA. After a reset or a previous teardown operation but before queuing packets to a channel the host must initialize the channel's Tx Port DMA State. The host initializes the channel Tx Port DMA State by configuring all of the Tx flow entries for the channel and then writing to the Tx Channel Configuration Register A (TCHANRT[a]\_TRT\_CTL). The Host may choose to write the enable bit in the Tx Channel Configuration Register A (<TCHANRT[a]\_TRT\_CTL> [31] TX\_ENABLE) at

the same time or after it has written all of the channel parameters but note that every write to the Tx Channel Configuration Registers will overwrite the channel state for all bytes that are enabled for the write transaction.

After a Transmit channel has been set up, packets can be added to the Queues for the channel to begin the transmit operation. The following sections describe how the transmit operations are performed for the various descriptor types.

#### 11.1.4.19 BCDMA - Split Transmit Operation Pause

Setting the pause bit in the Channel N Control Register (<TCHANRT[a]\_TRT\_CTL> [29] TX\_PAUSE) will suspend the channel from arbitration resulting in a halting of the flow of data. Clearing this bit will cause the channel to be added back into the arbitration list. Pausing a channel has no other destructive side effects (other than potentially overflowing trigger events).

#### 11.1.4.20 BCDMA - Split Transmit Channel Teardown

This section describes the teardown procedure for split mode Tx channels within the BCDMA. A Tx channel teardown is initiated by the host by writing the tx\_teardown bit in the Tx Channel N Real-time Control Register (<TCHANRT[a]\_TRT\_CTL> [30] TX\_TEARDOWN). When the host initiates teardown, it can choose to perform either a graceful (no data loss) or forced teardown of the channel depending on the setting of the tx\_forced\_teardown bit in the Tx Channel N Real-time Control Register (<TCHANRT[a]\_TRT\_CTL> [28] TX\_FORCED\_TEARDOWN).

If the tx\_forced\_teardown bit is clear, a normal teardown has been initiated. In this case, the DMA will do the following:

1. Stops performing any additional descriptor fetches for the channel.
2. Completes any packets normally for which a pointer/descriptor/TR fetch has already been performed
3. Sets the tdown bit on the EOP data phase of the last packet to be sent (if any traffic was pending when teardown was initiated) or sends a zero byte packet with the tdown, sop, and eop bits asserted. This signals the destination thread that all of the data has been sent.
4. Clears the channel enable in the Tx Channel N Global Configuration Register (<TCHANRT[a]\_TRT\_CTL> [31] TX\_ENABLE).
5. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
6. Sets bit 31 of the Tx Flow Reverse Ring Occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) to indicate that a teardown has completed.
7. If the current Tx reverse ring occupancy is 0, issues a Tx reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.
8. If the current TX Reverse ring occupancy is not 0 then a write to the doorbell with a negative value of the current occupancy will clear any remaining work but the forward ring pointer will remain the same. If the ring pointer needs to be reset then perform a write to any of the ring configuration registers.
9. If the tx\_forced\_teardown bit is set (only valid on BCDMA), a destructive teardown has been initiated. In this case, the BCDMA will do the following:
  1. Suspends any triggers to allow the channel to operate even if the trigger source is no longer functioning.
  2. Completes any packets which have been prefetched with or without transferring any data or generating events (the implementation has the option of doing whichever is simplest for that implementation).
  3. Clears the channel enable in the Tx Channel Global Configuration Register (<TCHANRT[a]\_TRT\_CTL> [31] TX\_ENABLE).
  4. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
  5. Sets bit 31 of the Tx Flow Reverse Ring Occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) to indicate that a teardown has completed.
  6. If the current Tx reverse ring occupancy is 0, issues a Tx reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.

The host may issue a teardown on any channel at any time, regardless of whether the channel is actively receiving a packet or not.

The Host determines that a teardown using either of the following methods:

1. Periodically polling the teardown and enable bits for the channel
2. Waiting for an interrupt and observing the teardown complete bit is set in the channel's default flow (first flow in channel) reverse occupancy register (RINGRT[a]\_RT\_ROCC) for the channel.

#### **11.1.4.21 BCDMA - Split Transmit Operation (TR Packet)**

Packet transmission in TR Packet mode involves the following steps:

1. The Host allocates and populates a TR packet descriptor. The host will initialize the following fields within the packet descriptor:
  - a. Descriptor Type (set to TR)
  - b. Reload Enable to 1 if looping is required, otherwise 0
  - c. Reload Index to an appropriate offset if Reload Enable set, otherwise 0
  - d. Last Entry to TR count minus 1
  - e. TR Nominal Element Size to a value that is as large as required for any given TR in the buffer
  - f. A set of one or more valid Transfer Request records whose quantity matches the last index specified previously.
2. The Host queues the packet onto one of the Transmit Queues for the desired BCDMA channel. Channels may provide more than one Queue (1 queue per provided flow) and may provide a particular prioritization policy between the queues. This behavior is application specific and is controlled by the DMA controller/scheduler implementation.
3. The BCDMA internally provides a level sensitive status signal for the queue which indicates if any work is currently pending. This level sensitive status line is sent to the hardware block which is responsible for scheduling DMA operations.
4. The DMA controller is eventually brought into context for the corresponding read channel and begins to process the packet.
5. The DMA controller reads the packet descriptor pointer from the ring in memory.
6. The DMA controller reads the packet descriptor from memory
7. The DMA controller sequentially empties the data region in the descriptor by reading the contents in one or more nominal TR sized block data moves. As a TR is read from the descriptor, it is stored in the internal state of the DMA channel until it is completed.
8. All of the data transfers specified in a TR will be completed as a series of reads.
9. The BCDMA will wait until data returns for each read operation that has been initiated. When the final read operation is returned within each TR, the BCDMA will write the response into the TR buffer in the Transfer Response records array. Each response is written into an array index which directly matches the index of the request record to which it corresponds.
10. When all Transfer Requests in the packet have been processed and all Transfer Responses have been written back and confirmed to have landed in memory, the BCDMA will increment the reverse occupancy for the channel / flow.
11. After the occupancy is incremented, the BCDMA will indicate the status of the Tx Completion Queue by sending an up event.
12. The Interrupt Aggregator receives the up event and sets the corresponding bit in the interrupt status register (VINT[a]\_ENABLE\_SET) as programmed in the interrupt mapping registers. This in turn causes an interrupt to the Host to be generated.
13. The Host responds to the status change from the BCDMA (via the Interrupt Aggregator) and performs garbage collection as necessary for the packet.
14. During garbage collection the Host will write to the reverse queue Doorbell register (RINGRT[a]\_RT\_RDB) for the channel/flow to acknowledge the popping of those completed packets. The doorbell writes eventually cause the queue to become empty.
15. The BCDMA will send a down event to the Interrupt Aggregator which will clear the corresponding bit in the Interrupt Status Register (VINT[a]\_STATUS) and potentially de-assert the interrupt line.

#### **11.1.4.22 BCDMA - Split Transmit Error / Exception Handling**

There are 3 specific errors which may be encountered during Tx split operation and which are trapped by the BCDMA. The following table lists the errors and how the BCDMA will process them:

**Table 11-59. BCDMA Tx Error / Exception Handling**

| Condition           | Pauses Channel            | Error Flag Set in Channel | Data Transfer | TR Flush     | Outputs Transfer Events |
|---------------------|---------------------------|---------------------------|---------------|--------------|-------------------------|
| TR null icnt0       | Selectable <sup>(1)</sup> | Yes                       | No            | Just that TR | No                      |
| Unsupported TR Type | Selectable <sup>(1)</sup> | Yes                       | No            | Just that TR | No                      |
| Bus Errors          | Selectable <sup>(1)</sup> | Yes                       | Yes           | No           | Yes                     |

(1) If pause\_on\_error bit is set in channel configuration

#### 11.1.4.22.1 Null Icnt0 Error

The icnt0 parameter in a TR is never allowed to be 0 as this would cause zero byte count transactions to be issued on the bus and is unproductive wrt completion of any useful work. The Block Copy engine in the BCDMA will trap any TR for which the icnt0 is zero and will immediately return a transfer response with the TR icnt0 error conditions set without performing any data transfer and without outputting any events (including end of TR event).

#### 11.1.4.22.2 Unsupported TR Type

If a TR is provided to a channel which is of a type which is not supported by the channel, the Block Copy engine in the BCDMA will trap that TR and immediately return a transfer response with the Unsupported TR error conditions set without performing any data transfer and without outputting any events (including end of TR event).

#### 11.1.4.22.3 Bus Errors

If a bus error is encountered during transmit the BCDMA will log the error by asserting the tx\_error bit for the channel (and optionally sending an error event if enabled) but the DMA will continue to attempt to complete the transfer using the returned (and potentially incorrect) data.

#### 11.1.4.23 BCDMA - Split Receive Channel Setup

After a reset or a previous teardown operation but before receiving packets on a channel the host must initialize the channel's Rx Port DMA State. The host initializes the channel Rx Port DMA State by writing to the Rx Channel Configuration Registers. The Host may choose to write the enable bit in the Rx Global Channel Configuration Register (<RCHANRT[a]\_RRT\_CTL > [31] RX\_ENABLE) at the same time or after it has written all of the channel parameters but note that every write to the Rx Channel Configuration Registers will overwrite the channel state for all bytes that are enabled for the write transaction.

#### 11.1.4.24 BCDMA - Split Receive Channel Pause

Setting the pause bit in the Channel N Control Register (<RCHANRT[a]\_RRT\_CTL > [29] RX\_PAUSE) will suspend the channel from arbitration resulting in a halting of the flow of data. Clearing this bit will cause the channel to be added back into the arbitration list. Pausing a channel has no other destructive side effects (other than potentially overflowing trigger events).

#### 11.1.4.25 BCDMA - Split Receive Channel Teardown

An Rx channel teardown is intended to be initiated at the data source (the source thread). Initiation is commanded by the host by writing the teardown bit in the PSI-L source thread register 0x408. This will cause the source of the data to gracefully terminate any packet that is in flight and send a PSI-L data phase with the tdown signal asserted. When the BCDMA receives a data phase with the tdown attribute asserted it will immediately set the internal rx\_teardown bit in the Rx Channel N Real-time Control Register (<RCHANRT[a]\_RRT\_CTL > [30] RX\_TEARDOWN).

Upon seeing the rx\_teardown bit asserted the port can perform either a graceful (no data loss) or forced teardown of the channel depending on the setting of the rx\_forced\_teardown bit in the Rx Channel N Real-time Control Register (<RCHANRT[a]\_RRT\_CTL > [28] RX\_FORCED\_TEARDOWN).

If the rx\_forced\_teardown bit is clear, a normal teardown has been initiated. In this case, the BCDMA will do the following:

1. Stops performing any additional prefetches for the channel (TR mode channels)
2. Completes any packets normally which may be pending in the ingress port buffers (what the port considers as pending packets is application specific).
3. Clears the channel enable in the Rx Channel Global Configuration Register (<RCHANRT[a]\_RRT\_CTL> [31] RX\_ENABLE).
4. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
5. Sets bit 31 of the Rx Flow Reverse Ring Occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) to indicate that a teardown has completed.
6. If the current Rx reverse ring occupancy is 0, issues an Rx reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.
7. If the current RX Reverse ring occupancy is not 0 then a write to the doorbell with a negative value of the current occupancy will clear any remaining work but the forward ring pointer will remain the same. If the ring pointer needs to be reset then perform a write to any of the ring configuration registers.
8. If the rx\_forced\_teardown bit is set, a destructive teardown has been initiated. In this case, the BCDMA will do the following:
  - a. Suspends any triggers to allow the channel to operate even if the trigger source is no longer functioning.
  - b. Completes any packets which may be pending in the ingress port buffers with or without transferring any data or generating events (the implementation has the option of doing whichever is simplest for that implementation). Packets will be drained from the Rx FIFO either using 'null' write transfers or real transfers and the Packet Descriptors will be returned with an accurate accounting of actual bytes transferred.
  - c. Clears the channel enable in the Rx Channel Global Configuration Register (<RCHANRT[a]\_RRT\_CTL> [31] RX\_ENABLE).
  - d. Resets the channel state (including scoreboards, FIFOs, counters, statistics, etc.) to their after reset values.
  - e. Sets bit 31 of the Rx Flow Reverse Ring Occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) to indicate that a teardown has completed.
  - f. If the current Rx reverse ring occupancy is 0, issues an Rx reverse ring completion up event which is then routed to an IA and can be further routed to any event consumer.

The host may issue a teardown on any channel at any time, regardless of whether the channel is actively receiving a packet or not. The normally intended method of issuing a teardown on a packet mode channel is to initiate the teardown at the remote PSI-L data source and allow it to flow into the BCDMA. If that is not possible, the host may write the rx\_teardown bit directly to a 1.

The Host determines that a teardown using either of the following methods:

1. Periodically polling the teardown and enable bits for the channel
2. Waiting for an interrupt and observing the teardown complete bit is set in the channel's default flow (first flow in channel) reverse occupancy register (<RINGRT[a]\_RT\_ROCC> [31] TDOWN\_COMPLETE) for the channel.

#### **11.1.4.26 BCDMA - Split Receive Operation (TR Packet)**

Packet reception in TR Packet mode involves the following steps:

1. The Host allocates and populates a TR packet descriptor. The host will initialize the following fields within the packet descriptor:
  - a. Descriptor Type (set to TR)
  - b. Reload Enable to 1 if looping is required, otherwise 0
  - c. Reload Index to an appropriate offset if Reload Enable set, otherwise 0
  - d. Last Entry to TR count minus 1
  - e. TR Nominal Element Size to a value that is as large as required for any given TR in the buffer

- f. A set of one or more valid Transfer Request records whose quantity matches the last index specified previously.
2. The Host queues the packet onto one of the Rx TR Queues for the desired BCDMA channel. Channels may provide more than one Rx TR Queue (one per flow) and may provide a particular prioritization policy between the queues. This behavior is application specific and is controlled by the DMA controller / scheduler implementation.
  3. The Ring Accelerator provides a level sensitive status signal for the queue which indicates if any packets are currently pending. This level sensitive status line is sent to the hardware block which is responsible for scheduling DMA operations.
  4. The DMA controller is eventually brought into context for the corresponding channel and begins to process the packet.
  5. The DMA controller reads the packet descriptor pointer from the ring in memory.
  6. The DMA controller reads the packet descriptor from memory
  7. The DMA controller empties the data region in the descriptor by reading the contents in one or more nominal TR sized block data moves.
  8. All of the data transfers specified in a TR will be completed as a series of writes and a Transfer Response will be returned indicating the completion and status of the transfer.
  9. The BCDMA will wait until Transfer Responses have been returned for each Transfer Request that it issued. As each Transfer Response is returned, the BCDMA will write the response into the TR buffer in the Transfer Response records array. Each response is written into an array index which directly matches the index of the request record to which it corresponds.
  10. When all Transfer Requests in the packet have been processed and all Transfer Responses have been written back and confirmed to have landed in memory, the DMSS will write the pointer to the packet descriptor to the queue specified in the return queue number fields of the packet descriptor.
  11. After the Packet Descriptor pointer has been written, the Ring Accelerator indicates the status of the Rx Completion Queues to other ports / processors / prefetcher blocks using events sent to the Interrupt Aggregator. These events are then converted into standard interrupts.

#### 11.1.4.27 BCDMA - Split Receive Error / Exception Handling

Several types of errors/exceptions may be encountered during reception of split Rx data. The following table outlines the various errors and exceptions that can occur:

**Table 11-60. Rx Error / Exception Handling**

| Condition                       | Channel Type         | Severity  | Pauses Channel            | Error Flag Set | Data Transfer          | Data Flush | TR Flush     | Event Output |
|---------------------------------|----------------------|-----------|---------------------------|----------------|------------------------|------------|--------------|--------------|
| Descriptor Starvation           | All Packet           | Exception | No                        | No             | Option                 | Option     | -            | No           |
| Protocol Errors                 | All Packet           | Info      | No                        | No             | Normal                 | No         | -            | No           |
| Drop                            | Host – normal        | Exception | No                        | No             | Partial <sup>(1)</sup> | Until EOP  | -            | No           |
| EOP Asserted Late (Long Packet) | BCDMA – single ended | Exception | No                        | No             | Partial                | Excess     | No           | Yes          |
| TR null icnt0                   | All BCDMA            | Error     | Selectable <sup>(1)</sup> | Yes            | No                     | No         | Just that TR | No           |
| Unsupported TR Type             | All BCDMA            | Error     | Selectable <sup>(1)</sup> | Yes            | No                     | No         | Just that TR | No           |

(1) Data will not be transferred after drop is detected. All data after that point is guaranteed to be flushed and some data prior to the exact data phase on PSI-L where drop was asserted may also be flushed since data is constantly accumulated so it can be transferred in chunks.

#### 11.1.4.27.1 PKTDMA Exception Conditions

There are a few cases which can occur when processing incoming packets which are not considered errors but which will require handling in order to avoid locking up the PKTDMA engines.

Packet mode channel exceptions include:

- Descriptor Starvation
- Protocol Errors
- Dropped Packets
- Long Packets

##### 11.1.4.27.1.1 Descriptor Starvation

Descriptor starvation occurs when the Port needs to fetch a free descriptor from the RX ring and none are available. When the port detects that descriptor starvation has occurred it will react based on the value of the rx\_error\_handling bit which was programmed into the Rx Flow N Configuration Register A (<RFLOW[a]\_RFA> [28] RX\_ERROR\_HANDLING).

If the rx\_error\_handling bit is cleared:

- The Port will increment an internal per-channel starvation counter and will then flush the packet.

If the rx\_error\_handling bit is set:

- The Port will assert a RX descriptor starvation event (which may cause an interrupt to the Host) and will then wait for the doorbell for the selected flow to be written with a positive value. Note that the intention is that the port will wait for an entry to be added to the ring. It is assumed that when in this mode, if data loss is not desired that the host will guarantee that a chain of buffers will be provided that can receive the entire packet.

##### 11.1.4.27.1.2 Protocol Errors

Protocol errors occur when the port logic detects that the received packet did not pass protocol specific criteria that was checked during reception of the packet. Examples of protocol errors include packet length errors, CRC errors, or alignment errors.

When protocol errors are detected, the port may choose whether or not it will drop the packet. The mechanism that is used to determine which packets to drop and which to forward is application specific. If the port determines that it needs to forward the packet to the Host, it will set the Packet Error bit in the Descriptor indicating that this is a packet which experienced a protocol related error. The type of protocol related error is generally indicated in either the Protocol Specific bits in the Host descriptor or in the Protocol Specific bytes region. The packet length information and certain portions of the Protocol Specific region may not be correct for packets which encounter errors.

##### 11.1.4.27.1.3 Dropped Packets

Packets can be dropped within an Rx Port for any number of reasons which with the exception of the starvation case which was covered above are application specific.

When a Port determines that it needs to drop a packet after reception of the packet has begun, it must flush the remainder of the packet, increment the dropped packets statistic, and rewind any fetched descriptor/buffer chain so that it can be used the same descriptor/buffer chain on the next packet.

##### 11.1.4.27.1.4 Long Packet

For Rx channels which are not configured in single buffer mode, if the host provides a buffer chain whose total length is insufficient to receive the entire packet, whatever portion of the packet which has not been received will be flushed until an end of packet indicator is received on the PSI-L interface. This behavior will occur regardless of which error handling mode has been selected for the channel.

#### **11.1.4.27.2 BCDMA Exception Conditions**

Since the TR mode engine performs transfer sequencing using a count based mechanism it is susceptible to becoming out of synchronization if the source of the data and the destination for the data do not exactly match in their expectations for how much data will be transferred. The following sections outline these scenarios.

TR mode channel exceptions include:

- Reception of EOL delimiter
- Short Packets
- Long Packets
- Descriptor Starvation

##### **11.1.4.27.2.1 Reception of EOL Delimiter**

If an end of line delimiter is received by the Rx (write) side of the BCDMA the EOL\_ADV field in the TR application specific flags field is used to advance the appropriate indices of the TR to the next level. Each EOL that is received will cause the TR to advance to the next specified loop iteration breaking as many intermediate loops as are required.

##### **11.1.4.27.2.2 EOP Asserted Prematurely (Short Packet)**

Split TR mode channels can experience an incoming packet whose length is shorter than what was expected based on one or more TRs which form the control description for the expected packet. If an EOP is received for a TR and the TR has not been completely executed, the port is required to receive as much data as is actually provided in the incoming data placing it in accordance with the instructions in the TR and the to continue executing any remaining TR(s) such that the required events are produced to keep downstream consumers in sync. In this case, no data will be transferred to the buffers described by the TR beyond what was provided in the incoming packet.

##### **11.1.4.27.2.3 EOP Asserted Late (Long Packets)**

Split TR mode channels can experience an incoming packet whose length is longer than what was expected based on one or more TRs which form the control description for the expected packet. If a TR completes and is marked as EOP but the incoming packet is not finished, then the port must throw away any additional received data until the incoming packet reaches an EOP condition. At this point, reception will start with a new TR and a new incoming packet.

##### **11.1.4.27.2.4 Descriptor Starvation**

Descriptor starvation occurs when the Port receives enough data for a burst but the ring for the channel is currently empty. This causes push back on the receive port and can cause lost data.

The Port will assert a starvation bit in the RX Receive Channel Status register (RCHANRT[a]\_RRT\_STATUS[1-0]). When the doorbell register (RINGRT[a]\_RT\_DB) is written to populate the ring the starvation bit will clear. Note that the intention is that the port will wait for an entry to be added to the ring. It is assumed that if data loss is not desired that the host will guarantee that a descriptor is present.

## 11.2 Data Movement Subsystem (DMSS)

This chapter describes the Data Movement Subsystem (DMSS) module in the device.

### 11.2.1 Data Movement Subsystem (DMSS)

This chapter describes the features and functions of the Data Movement Subsystem (DMSS) hardware modules in the device.

#### 11.2.1.1 DMSS Overview

The DMSS module on AM62x provides data movement (DMA) and bridges between the CBA switched interconnect and the packet streaming fabric (network on chip) on the device.

The Data Movement Subsystem (DMSS) consists of DMA/Queue Management components and Peripherals:

- Packet DMA
- Block Copy DMA
- Ring Accelerator
- Packet Streaming Interface (PSILSS)
- Infrastructure components such as CBASS, secure proxy, and an interrupt aggregator



dmss\_spruiem\_001

**Figure 11-4. DMSS Top-Level Block Diagram**

**Table 11-61. DMSS Allocation Within Device Domains**

| Module Instance | Domain |         |
|-----------------|--------|---------|
|                 | MCU    | MAIN    |
| DMSS0           | -      | ✓(DMSS) |

**Note**

Some features may not be available. See *Module Integration* for more information.

**11.2.1.2 DMSS Functional Description**

See Section [Chapter 11](#), DMSS Architecture, for the TI AM62x Data Movement Architecture (DMA) specification.

See the following sections for the respective module description:

- PKTDMA - [Section 11.1.1.4](#)
- BCDMA - [Section 11.1.1.5](#)
- Ring Accelerator - [Section 11.1.1.1](#)
- Infrastructure Components:
  - CBASS - Chapter 3
  - Secure Proxy - [Section 11.1.1.2](#)
  - Interrupt Aggregator - [Section 11.1.1.3](#)

**11.2.1.3 DMSS Interrupt Configuration**

This section describes the actions needed to configure interrupts within the DMSS.

**Table 11-62. DMSS Parameters**

| Parameter   | Value DMSS                        | Description                                                                                  |
|-------------|-----------------------------------|----------------------------------------------------------------------------------------------|
| RA_RING_CNT | 20                                | Number of total rings supported (specific to each ring accelerator)                          |
| IA_SEVI     | 1536                              | Interrupt Aggregator Source Event Input (SEVI) count (specific to each interrupt aggregator) |
| IS_VINTR    | 184                               | Interrupt Aggregator Virtual Interrupt (VINTR) count (specific to each interrupt aggregator) |
| EO          | See Table 10-98, Global Event Map | Event offset                                                                                 |

[Table DMSS Software Variables](#) lists software-configurable variables used in the examples and descriptions.

**Table 11-63. DMSS Software Variables**

| Variable | Valid Range                       | Description                            |
|----------|-----------------------------------|----------------------------------------|
| R#       | 0 – RA_RING_CNT-1                 | Ring number                            |
| E#       | 0 – (destination module specific) | Event number                           |
| GE#      | = EO + E#                         | Global event number                    |
| SB#      | 0 – IA_SEVI-1                     | Interrupt aggregator status bit number |
| VI#      | 0 – IA_VINTR-1                    | Virtual interrupt number               |

#### 11.2.1.3.1 DMSS Event and Interrupt Flow

Figure [DMSS Interrupt Flow](#) illustrates the event and interrupt flow within the DMSS and output interrupts to a CPU.



**Figure 11-5. DMSS Interrupt Flow**

#### 11.2.1.3.1.1 DMSS Interrupt Description

This section describes the interrupt-related information that flows within DMSS and how this information is configured or generated.

1. Ring Number (R#)
  - Data is read from and written to a specific Ring Accelerator ring using direct ring-mode, or secure proxy access
  - The Ring Accelerator has specific ring number ranges for specific purposes. The R# must match the intended purpose of the ring (see Table 10-578, RINGACC Ring Mapping)
2. Global Event and Event Numbers (GE# and E#)
  - GE# = EO + E#
  - EO determines the destination module for the event. The PSILSS will route the GE# to the destination module per the DMSS event mapping, removing EO in the process. The destination module sees only E#. See [Global Event Map](#) in *Module Integration* for details.
  - For the INTAGGR module, E# ranges from 0 to (IA\_SEVI - 1)
3. Virtual Interrupt (VI#)
  - The INTAGGR maps E# (via software configuration) to any SB#
  - ranges from 0 to (IA\_SEVI - 1)
  - Each VI# (0 – (IA\_VINTR-1)) is driven by a group of 64 contiguous SB# numbers (VI# driven by SB#'s  $VI\# \times 64 - (VI\# \times 64) + 63$ )

### 11.2.2 Ring Accelerator (RINGACC)

This chapter describes the RINGACC module, part of the DMSS.

#### Note

Not all of the RINGACC Functions specified in the document are supported in the device. Updates will be included in the next revision to reflect only supported modes of operation.

#### 11.2.2.1 RINGACC Overview

The Ring Accelerator (RINGACC or RA) provides hardware acceleration to enable straightforward passing of work between a producer and a consumer.

**Table 11-64. RINGACC Allocation Within Device Domains**

| Module Instance | Domain |         |
|-----------------|--------|---------|
|                 | MCU    | MAIN    |
| DMSS0_RINGACC0  | -      | ✓(DMSS) |



**Figure 11-6. RINGACC Overview**

#### 11.2.2.1.1 RINGACC Features

- Ring Accelerator implementation
  - Supports up to 32 independent memory mapped ring structure
  - Supports various modes for each ring based on usage and compatibility
  - Provides single word deep shared incoming Transfer Response FIFO
  - Optionally supports dynamic clock gating
  - Provides bit wide source VBUSM read/write target interface for accesses from DMA controller entities
    - Provides 2 word deep command FIFO
    - Provides 2 word deep write data FIFO

- Provides 2 word deep read data FIFO
- Provides 2 word deep write status FIFO
- Provides bit wide destination VBUSM read/write initiator interface for accesses to ring structures in memory
- Supports up to 16 outstanding writes
- Supports up to 16 outstanding reads
- Provides 2 word deep command FIFO
- Provides 2 word deep write data FIFO
- Provides 2 word deep read data FIFO
- Provides 2 word deep write status FIFO
- Source interface provides an array of 32x512-byte long address windows (four for each ring) which are packed into a single contiguous address range.
- Read and write addresses which target a specific window are mangled to redirect the read or write transaction to an effective address calculated from the base address for the ring plus current ring offset.
- Each read or write access presented on VBUSM target interface is modified and bridged onto the VBUSM initiator interface.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### 11.2.2.1.2 RINGACC Parameters

Table *RINGACC Configuration Parameters* shows the RINGACC configuration parameters in this SoC

**Table 11-65. RINGACC Configuration Parameters**

| Module Instance | Parameters |                    |                   |
|-----------------|------------|--------------------|-------------------|
|                 | Ring Count | Number of Monitors | Proxy Target Base |
| DMSS0_RINGACC0  | 32         | 0                  | 0x4e000000        |

### 11.2.2.2 RINGACC Functional Description

The Ring Accelerator (RINGACC) converts constant-address read and write accesses to equivalent read or write accesses to a circular data structure in memory. The RINGACC eliminates the need for each DMA controller which needs to access ring elements from having to know the current state of the ring (base address, current offset). The DMA controller performs a read or write access to a specific address range (which maps to the source interface on the RINGACC) and the RINGACC replaces the address for the transaction with a new address which corresponds to the head or tail element of the ring (head for reads, tail for writes). Since the RINGACC maintains the state, multiple DMA controllers or channels are allowed to coherently share the same rings as applicable. The RINGACC serves a very similar function to the Queue Manager in the earlier SoCs. The RINGACC uses less memory and is able to place data which is destined towards software into cached memory directly.

#### 11.2.2.2.1 Block Diagram

Figure *Ring Accelerator Block-Diagram* shows ring accelerator's main internal components.



Figure 11-7. Ring Accelerator Block-Diagram

#### 11.2.2.2.1 Configuration Registers

The Configuration Registers block is responsible for providing memory mapped registers for configuration of the RINGACC functions. The configuration registers are divided into:

- Static configuration fields , which are typically initialized and then left at specified values for long time periods (or until a reset occurs)
- Real-time (RT) registers , which are modified frequently during runtime. Configuration registers are listed and described in *RINGACC Registers*.

#### **11.2.2.2.1.2 Source Command FIFO**

The Source Command FIFO buffers VBUSM command phases which are accepted from the VBUSM source interface.

#### **11.2.2.2.1.3 Source Write Data FIFO**

The Source Write Data FIFO buffers VBUSM write data phases which are accepted from the VBUSM source interface.

#### **11.2.2.2.1.4 Source Read Data FIFO**

The Source Read Data FIFO buffers VBUSM read data phases which have been returned from the VBUSM destination interface (via the main state machine) and which are to be output on the VBUSM source interface.

#### **11.2.2.2.1.5 Source Write Status FIFO**

The Source Write Status FIFO buffers VBUSM write status data phases which have been returned from the VBUSM destination interface and which are to be output on the VBUSM source interface.

#### **11.2.2.2.1.6 Main State Machine**

The Main State Machine (MSM) block implements all of the control logic which is necessary to accept a command from the source interface, perform a lookup into the ring state RAM, determine the effective address for the destination interface transaction, modify the address (and byte count for reads) for the transaction, and place that modified transaction into the outgoing destination FIFOs. The MSM block is also responsible for updating the ring index and occupancy values and for producing output status to indicate changes to the ring state. The MSM also modifies the ring state whenever the read data or write status for a previous ring transaction return and forwards those responses back to the originating initiator.

#### **11.2.2.2.1.7 Destination Command FIFO**

The Destination Command FIFO stores VBUSM transaction commands which are output from the MSM as modified versions of transactions that were popped from the Source Command FIFO. The Destination command FIFO allocates a new command ID for each read or write command that is pushed to the FIFO. Read IDs are allocated from a scoreboard maintained in the Destination Read Data FIFO. Write IDs are allocated from a scoreboard maintained in the Destination Write Status FIFO. When a new command is allocated, the Destination Command FIFO also pushes the original cid and rrouteid values from the source side transaction into a scoreboard in either the Destination Read Data or Destination Write Status FIFOs depending on the applicable transaction direction. The read interface of the Destination Command FIFO directly drives commands onto the destination VBUSM command interface.

#### **11.2.2.2.1.8 Destination Write Data FIFO**

The Destination Write Data FIFO stores write data phases for write commands that are passing through the RINGACC towards memory. The write interface of the Destination Write Data FIFO is directly connected to the read interface of the Source Write Data FIFO and the read interface directly drives write data onto the destination VBUSM write data interface.

#### **11.2.2.2.1.9 Destination Read Data FIFO**

The Destination Read Data FIFO provides a read command translation scoreboard and also stores read data phases that are passing through the RINGACC towards the originating DMA controller. The write interface of the Destination Read Data FIFO is directly connected to the destination VBUSM read data interface. As read data passes through the Destination Read Data FIFO, the *rid* and *rrouteid* are changed back to their original values using information which was stored in read command translation scoreboard.

#### **11.2.2.2.1.10 Destination Write Status FIFO**

The Destination Write Status FIFO provides a write command translation scoreboard and also stores write status phases that are passing through the RINGACC towards the originating DMA controller. The write interface of the Destination Writes Status FIFO is directly connected to the destination VBUSM write status interface. As write

status words pass through the Destination Write Status FIFO, the *sid* and *srouteid* are changed back to their original values using information which was stored in the write command translation scoreboard.

#### 11.2.2.2.2 RINGACC Functional Operation

##### 11.2.2.2.2.1 Queue Modes

Each ring or queue can be in one of four modes that determines how it must be accessed and the compatibility it has with hardware and software.

###### 11.2.2.2.2.1.1 Ring Mode

Ring mode is used when software owns one side of the ring, and hardware or another software owns the other side. This mode allows the software that owns a side of the ring to control that side including accessing the memory directly rather than going through hardware, and software updates the hardware on any changes through the Doorbell registers. These doorbell accesses indicate when software has pushed or popped entries, allowing the entity on the other side of the ring to know when there are elements ready. The ring mode has limitations that the exposed side of the ring is completely under software control, and any atomicity needed must also be performed by software, which is why the exposed side of a ring is usually owned by a single thread of software. This limitation also means that any hardware configuration that would normally access the same ring for both pushes and pops cannot use ring mode as hardware cannot access the exposed side of the ring, such as free queues that are normally read by hardware but could also be pushed by hardware on an error.

When software is popping from the ring, it must guarantee that it never pops more elements through the Doorbell register (RINGRT[a]\_RT\_DB) than what is valid in the Ring Occupancy (RINGRT[a]\_RT\_OCC) register, which holds how many elements are ready for software consumption. There could be some elements which have data written to memory but have not received status back from memory and those are not considered ready to pop yet as the ring status has not fully updated. Therefore, just reading from memory to determine the number of elements to pop is not sufficient. If software attempts to pop more than the RINGRT[a]\_RT\_OCC register value, then the occupancies could go negative resulting in missed down events and spurious interrupts. An optimization for software is to read the RINGRT[a]\_RT\_OCC register less frequently and keep a local copy which guarantees the maximum number of allowed pops. When the software copy of RINGRT[a]\_RT\_OCC reaches 0, or periodically, the software can read the register to refresh the value. This must reduce the frequency of register reads instead of reading the register for every software pop.

###### 11.2.2.2.2.1.2 Messaging Mode

Messaging mode requires that all accesses to the queue must go through RINGACC so that all accesses to the memory are controlled and ordered. RINGACC then controls the entire state of the queue, and software has no direct control, such as through doorbells and cannot access the storage memory directly. This is particularly useful when more than one software or hardware entity can be the producer and/or consumer at the same time. Software must access the data through bus accesses to the RINGACC. As with the earlier example, if there are free queues that need the hardware to both push and pop, then they must be configured as at least messaging mode (or a later mode) and not ring mode.

###### 11.2.2.2.2.1.3 Credentials Mode

Credentials mode adds per element credentials storage to messaging mode. This allows multiple producers with their own credentials to have those credentials stored with the element. This allows the consumer to inherit the credentials of each element rather than a single set for the entire queue, such as for DMA TR credential inheritance. This mode requires each operation to use two elements of storage since the credentials are stored in the second element, so the element count must be scaled appropriately. The credentials field is located in the same location as all modes, the word just before the first word of the message.

###### 11.2.2.2.2.1.4 Peek Support

All modes except ring mode allow the peek operations so that software can view the next element without actually popping it from the queue. This is done by reading from a different offset from the normal pop operation. All the same fields are read but the element is not actually popped off of the queue. This is useful for algorithms

that need to know about the overall queue and head element to make decisions but have not yet decided to pop from the queue.

#### 11.2.2.2.1.5 Index Register Operation

In ring mode, the Index (RINGRT[a]\_RT\_INDX) register follows the software control of the ring through the doorbell registers, while the hardware index (RINGRT[a]\_RT\_HWINDEX) register follows the hardware access of the ring through bus transactions. It works for a ring in either direction as the doorbell register (RINGRT[a]\_RT\_DB) update indicates whether elements were produced or consumed. But in the other queue modes, there is no simple manner to determine which index is for software or hardware since they both use bus transactions which the module cannot differentiate. So for these other queue modes, the index register is always the read index, and the hardware index register is the write index.

#### 11.2.2.2.2 VBUSM Target Ring Operations

Each ring contains four memory spaces on the VBUSM target bus for access, each of which is 512 bytes long, with a total of 4 kB per ring. Each ring space starts immediately after the preceding ring. The allocation per ring is as in [Table 11-66](#).

**Table 11-66. Ring Memory Partition**

| Offset         | Operation                                 | Supported Ring Modes                                                       |
|----------------|-------------------------------------------|----------------------------------------------------------------------------|
| 0x0 - 0x1FF    | Reads pop from head. Writes push to head. | Read supported in all modes, write supported in all modes except Ring mode |
| 0x200 - 0x3FF  | Writes push to tail. Reads pop from tail. | Write supported in all modes, read supported in all modes except Ring mode |
| 0x400 - 0x5FF  | Reads peek from head. Writes ignored.     | All modes except for Ring mode.                                            |
| 0x600 - 0x7FF  | Reads peek from tail. Writes ignored.     | All modes except for Ring mode.                                            |
| 0x800 - 0xFFFF | Reserved                                  | Reserved                                                                   |

Within each 512-byte (0x200) space, the message data is right justified so that the last byte is always the 511-th byte. The element size of the ring defines which words are valid. The word just before the first valid message word is the credentials field. Access must not be made before the credentials register (CRED[a]\_CRED).

#### 11.2.2.2.3 VBUSM Initiator Interface Command ID Selection

The RINGACC keeps a transaction command scoreboard for reads and writes. Each scoreboard tracks which command indexes are currently outstanding from the RINGACC and which are free to use. When a read or write is requested by the Main State Machine, the scoreboard corresponding to the specified direction (read/write) is queried starting at index 0 and extending up to the maximum index for that scoreboard. The lowest index that is found and which is not currently allocated is selected and is directly used as the command ID (*cid*) for the outgoing transaction on the destination interface. 15 is the maximum index value for each scoreboard. Entries are freed for re-use in a write scoreboard when write status responses are received which account for all of the outstanding write data. Entries are freed for re-use in the read scoreboard only when all data has been returned for the read.

#### 11.2.2.2.4 Ring Push Operation (VBUSM Write to Source Interface)

The following sequence will occur for each VBUSM write which is sent to the source interface:

1. RINGACC extracts ring number from incoming write transaction address
2. RINGACC looks up ring state using *ring number*
3. RINGACC calculates effective write address using *ring base + ring\_index*
4. RINGACC re-evaluates pending bit for ring
5. RINGACC increments HW index and HW occupancy for ring
6. RINGACC allocates *cid* from scoreboard and places original *routeid*, *cid*, and *ring number* into scoreboard
7. RINGACC pushes altered *caddress*, *cid* and unaltered remainder of command attributes to output FIFO (note *routeid* is not included)

At a later time when write status returns:

1. RINGACC recovers original *cid*, *routeid*, and *ring number* from scoreboard
2. RINGACC increments SW index and occupancy for ring
3. RINGACC pushes restored *routeid*, *sid*, and unaltered write status to output write status FIFO

#### **11.2.2.2.5 Ring Pop Operation (VBUSM Read from Source Interface)**

The following sequence will occur for each VBUSM read which is sent to the source interface:

1. RINGACC extracts ring number from incoming read transaction address
2. RINGACC looks up ring state using *ring number*
3. RINGACC calculates effective read address using *ring base + ring\_index*
4. RINGACC increments HW index and decrements HW occupancy for ring
5. RINGACC re-evaluates pending bit for ring
6. RINGACC munges *cid* to add indicator in 4 MSBs to reconstitute *routeid* for returning read data
7. RINGACC pushes altered *caddress*, *cid* and unaltered remainder of command attributes to output FIFO (note *routeid* is not included)

At a later time when read data returns:

1. RINGACC recovers original *cid*, *routeid*, and *ring number* from scoreboard
2. RINGACC increments SW index and decrements SW occupancy for ring
3. RINGACC pushes restored *routeid*, *rid*, and unaltered read data, status, and other control signals to output read FIFO

#### **11.2.2.2.6 Host Doorbell Access**

The following sequence will occur for each VBUSP write to the doorbell register (RINGRT[a]\_RT\_DB) for a ring:

1. RINGACC extracts ring number from config address
2. RINGACC looks up ring state using ring number
3. RINGACC adds doorbell ring value to both HW and SW occupancies for ring
4. RINGACC re-evaluates pending bit for ring

#### **11.2.2.2.7 Queue Push Operation (VBUSM Write to Source Interface)**

The following sequence will occur for each VBUSM write which is sent to the source interface:

1. RINGACC extracts ring number from incoming write transaction address
2. RINGACC looks up ring state using *ring number*
3. RINGACC calculates effective write address using *ring base + ring\_index*
4. RINGACC re-evaluates pending bit for ring
5. RINGACC increments WR index and RD and WR occupancy for ring
6. RINGACC allocates *cid* from scoreboard and places original *routeid*, *cid*, and *ring number* into scoreboard
7. RINGACC pushes altered *caddress*, *cid* and unaltered remainder of command attributes to output FIFO (note *routeid* is not included)

At a later time when write status returns:

1. RINGACC recovers original *cid*, *routeid*, and ring number from scoreboard
2. RA pushes restored *routeid*, *sid*, and unaltered write status to output write status FIFO

#### **11.2.2.2.8 Queue Pop Operation (VBUSM Read from Source Interface)**

The following sequence will occur for each VBUSM read which is sent to the source interface:

- RINGACC extracts ring # from incoming read transaction address
- RINGACC looks up ring state using *ring number*
- RINGACC calculates effective read address using *ring base + ring\_index*
- RINGACC increments RD index and decrements RD and WR occupancy for ring
- RINGACC re-evaluates pending bit for ring
- RINGACC munges *cid* to add indicator in 4 MSBs to reconstitute *routeid* for returning read data

- RINGACC pushes altered *caddress*, *cid* and unaltered remainder of command attributes to output FIFO (note *routeid* is not included)
- 1. At a later time when read data returns:
  - RINGACC recovers original *cid*, *routeid*, and *ring number* from scoreboard
  - RINGACC pushes restored *routeid*, *rid*, and unaltered read data, status, and other control signals to output read FIFO

#### **11.2.2.2.9 Mismatched Element Size Handling**

When less data is written than defined by the element size for the ring for RING or MESSAGE modes, only the written data is stored in the memory and any remaining bytes maintain their old values. The index and occ are still incremented normally, and any special fields that are unwritten are assumed to be 0 (such as the length for QM mode rings).

Writing less data for CREDENTIALS mode is illegal, as those types need the full data to append the additional words to the correct offsets in memory.

When more data is written than defined by the element size for the ring, it will be an error and the write will be ignored and no index or occ increments occur. The only exception is for writes to an 8 byte element size ring, where the additional fields up to another 8 bytes are allowed but not written (for old Queue Manager compatibility).

When less data is read than defined by the element size for the ring, only the read data is fetched from memory, and any remaining bytes are lost. The index and occ are still incremented normally.

When more data is read than defined by the element size for the ring, it will be an error and the read will not affect the ring, the read data will be 0s, and no index or occ decrements occur. Access beyond the credentials word should not be attempted and can result in unpredictable behavior.

All accesses must be for multiples of 32 bit words, and partial bytes are not supported for all ring modes.

#### **11.2.2.3 Events**

The module outputs events about queue levels that can be used by an external module for statistics or interrupts.

Each queue has:

- an up event when the queue goes from 0 elements to 1 or more elements
- and a down event when the queue goes from 1 or more elements to 0 elements. The event number is programmable per queue in the RING[a]\_EVT register. This event occurs when the state machine updates the final occupancy for the queue. In ring mode this is when the response from the memory access returns, while in other queue modes this is when the operation is processed.

An event number programmed to 0xFFFF indicates to not produce an event for that ring when an event is not necessary. The register event number fields reset to 0xFFFF, so they must be programmed to a valid value before events will be generated. This applies to the monitor event number fields as well.

#### **11.2.2.4 Bus Error Handling**

If a bus error is detected on a response to a ring memory transaction, an error event is triggered to alert software. Since the ring contents may be corrupted as the push or pop was not completed correctly, software should consider resetting the ring and any software or hardware elements using the ring. A log register (RINGACC\_ERROR\_LOG) captures the ring that had the error and whether it was from a push or pop, and an error up event is sent to the programmed event number. After an error is logged, another will not be captured until the first is read out. When read, if an error is pending an error down event is sent to clear any interrupt, and then the next bus error log can be captured. A read of the RINGACC\_ERROR\_LOG register when there is no error log pending will not produce any down events. The event that is triggered is also programmable. Only

legal push and pop operations will capture this error, and not for any peek, emudbg read, flush command, or any operations that is illegal and causes the resulting memory access to be flushed.

#### **11.2.2.2.5 Monitors**

Monitors can be configured that allow various functions to be tracked of programmed queues. Each monitor is programmed to monitor a particular queue, the function to provide, and the data source to operate on. The supported functions are: to check the queue against programmed thresholds, to keep track of watermarks of the queue, to keep track of starvation occurrences (a read of an empty queue), or statistics capture. The supported data sources are: the queue element count, the head element size value, or the accumulated size value. Each monitor can also be programmed to produce an event should it have a triggering condition.

##### **11.2.2.2.5.1 Threshold Monitor**

A threshold monitor uses a programmed low threshold value and a programmed high threshold value to track the data source in the queue and cause an interrupt or status when a threshold is broken, either below the low value or above the high value. This is useful for software to replenish empty buffers when a queue has too few, or for a queue to accumulate enough elements so that software must start processing them, or for debug. The threshold being broken will cause the up or down event.

##### **11.2.2.2.5.2 Watermark Monitor**

A watermark monitor tracks the low and high values of the data source since the last read of the monitor. After initial setup or clearing, the watermark values will load the current value of the data source as the low and high. Then for successive operations if the resulting data source of the queue is below the low watermark, or above the high watermark, the associated watermark will be updated. When the monitor value registers are read, the value is cleared and starts tracking again using the current data source value. This can be useful for tracking low and high values of queue element counts or sizes for data tracking, debug or future optimizations, such as allocating items to a queue or buffer sizes based on counts.

##### **11.2.2.2.5.3 Starvation Monitor**

A starvation monitor tracks the number of starvation events (a read to an empty queue) that occurred on the queue. The data source is ignored, and the starvation count is always incremented whenever there is a read to the queue and the queue is empty. The count is cleared when the monitor value is read. This can be useful to trigger if any starvation event occurs, or to track how many of these events occur in a timeframe, and can be used for future optimizations or debug.

##### **11.2.2.2.5.4 Statistics Monitor**

The statistics monitor can track some simple statistics on the queue operations. The data source is ignored. The first value is the count of the number of writes to the queue, and the second value is the count of the number of reads from the queue. The counts are cleared when the monitor values are read. This can be useful to track the activity on a queue, and can be used for future optimizations or debug.

##### **11.2.2.2.5.5 Overflow**

RINGACC provides an overflow function where a push to a full ring will result in a push to a special overflow ring, rather than just losing the pushed data. The overflow ring is defined through RINGACC\_OVERFLOW register, and that ring must be defined with a large enough element size to cover the element size of any other ring, as well as enough elements to hold enough overflow data (as an overflow to the overflow ring will be lost). When there is a push to a full ring, there will be two elements written to the overflow ring, first the push data, and then the ring number that was full. A supervisor entity can own the overflow ring and perform what actions are needed from the overflow data. The size of the overflow ring must be an even number since two elements will be pushed for each overflow event. The overflow ring must be configured in ring or message modes.

An overflow queue value of 0xFFFF will disable the overflow function and will not record queue overflows.  
(SR2.0)

#### 11.2.2.2.5.6 Ring Update Port

To enhance performance for DMAs, the RINGACC provides a bus that indicates when ring updates occur, allowing the DMA to track their own rings and detect updates before the responses arrive. The bus will go valid whenever there is an update to the state of a ring, which can be from a push, pop, or doorbell write. It will not go valid for a peek, an emudbg pop, or a push to a full ring, as those do not update the ring state. When the bus is valid, the other signals are valid and indicate whether the operation was a push or a pop, whether the resulting state of the ring is empty, the ring number, and the number of elements updated to the ring (the push determines whether it is subtracted or added to the current count). One special case is a pop from an empty ring, which indicates an update but the element count is 0 since no items were actually popped, but a DMA using the cnt to add or subtract must handle this correctly by default. The bus will go valid once the operation command has been completed, and not after the response has been received, even for ring mode rings, allowing the DMA to see the update as soon as it is known by the RINGACC even before it is known to software.

#### 11.2.2.2.5.7 Tracing

This module provides a trace output of all operations so that the traffic can be viewed at a later time. The trace uses a simple write-only 32-bit VBUSP bus, with a defined packet header. The msgtype field defines the type of operation, and the message data is simply the data involved in the operation. It is likely the trace output will be read slower than new operations could provide data, so there will be a trace buffer able to hold two complete messages plus trace headers. If a new operation starts while the trace buffer does not have enough space, then that trace message will not be sent. And RINGACC\_TRACE\_CTL register controls whether to enable the trace output, whether to trace a single queue or all queues, and whether to include the message data in the trace output.

Table 11-67 shows the trace message for a push.

**Table 11-67. Trace Message for a Push**

| Word | Bits  | Data         | Comment                                                          |
|------|-------|--------------|------------------------------------------------------------------|
| 1    | 31:16 | 0x0          | Time to be replaced by trace hardware                            |
| 1    | 15:9  | 0x1          | Msgtype for push                                                 |
| 1    | 8:0   | 0x009        | Standard Trace Header                                            |
| 2    | 31    | push_to_head | Push to head flag, 0 = to tail, 1 = to head                      |
| 2    | 30:16 | 0x0          | Unused                                                           |
| 2    | 15:0  | queue        | Queue for push                                                   |
| 3-N  | 31:0  | message data | Optional message data for push, length dependent on message size |

Table 11-68 shows the trace message for a pop.

**Table 11-68. Trace Message for a Pop**

| Word | Bits  | Data  | Comment                                 |
|------|-------|-------|-----------------------------------------|
| 1    | 31:16 | 0x0   | Time to be replaced by trace hardware   |
| 1    | 15:9  | 0x2   | Msgtype for pop                         |
| 1    | 8:0   | 0x009 | Standard Trace Header                   |
| 2    | 31    | empty | empty pop, 0 = valid message, 1 = empty |
| 2    | 30:16 | 0x0   | unused                                  |

**Table 11-68. Trace Message for a Pop (continued)**

| Word | Bits | Data         | Comment                                                         |
|------|------|--------------|-----------------------------------------------------------------|
| 2    | 15:0 | queue        | queue for pop                                                   |
| 3-N  | 31:0 | message data | Optional message Data for pop, length dependent on message size |

Table 11-69 shows the trace message for a peek

**Table 11-69. Trace Message for a Peek**

| Word | Bits  | Data         | Comment                                                          |
|------|-------|--------------|------------------------------------------------------------------|
| 1    | 31:16 | 0x0          | Time to be replaced by trace hardware                            |
| 1    | 15:9  | 0x3          | Msgtype for peek                                                 |
| 1    | 8:0   | 0x009        | Standard Trace Header                                            |
| 2    | 31    | empty        | empty peek, 0 = valid message, 1 = empty                         |
| 2    | 30:16 | 0x0          | unused                                                           |
| 2    | 15:0  | queue        | queue for peek                                                   |
| 3-N  | 31:0  | message data | Optional message Data for peek, length dependent on message size |

### 11.2.3 Secure Proxy (SEC\_PROXY)

This chapter describes the Secure Proxy (SEC\_PROXY) module in the DMSS.

#### 11.2.3.1 Secure Proxy Overview

The Secure Proxy module provides proxy buffers for hosts that need to create large data bursts but can only perform small accesses.

##### 11.2.3.1.1 Secure Proxy Features

Secure Proxy supports the following features:

- Provides proxy function to store large data bursts that a host can only access in smaller amounts
- Supports a configurable number of threads, where each has their own independent proxy function
- Keeps the large data burst coherent until the complete data has been accessed
- Allows for interleaved access between multiple hosts or tasks using multiple proxy threads
- Supports a configurable target resource. The target has a configurable number of channels, size of each channel and base address
- Supports a programmable fixed queue for each proxy thread
- Supports multiple producers all writing to the same queue
- Supports a max message count for outbound proxy threads limiting the number of messages a thread can produce
- Supports programmable thresholds for when to generate events
- Optionally supports dynamic clock gating

**Table 11-70. Secure Proxy Allocation Within Device Domains**

| Module Instance  | Domain |         |
|------------------|--------|---------|
|                  | MCU    | MAIN    |
| DMSS0_SEC_PROXY0 | -      | ✓(DMSS) |

##### 11.2.3.1.2 Secure Proxy Parameters

[Table Secure Proxy Configuration Parameters](#) shows the Secure Proxy configuration parameters set during SoC design.

**Table 11-71. Secure Proxy Configuration Parameters**

| Module Instance  | Parameters             |                             |               |                         |                      |
|------------------|------------------------|-----------------------------|---------------|-------------------------|----------------------|
|                  | Proxies <sup>(1)</sup> | Message Size <sup>(2)</sup> | Target        | Channels <sup>(3)</sup> | Sizes <sup>(4)</sup> |
| DMSS0_SEC_PROXY0 | 76                     | 64                          | DMSS0_RINGACC | 20                      | 4096                 |

(1) Number of proxy threads supported. Can be read off from the SEC\_PROXY\_CONFIG read-only register

(2) Number of bytes for message. Can be read off from the SEC\_PROXY\_CONFIG read-only register

(3) Number of channels for the target

(4) Number of bytes per channel supported for the target

#### Note

Some features may not be available. See [Module Integration](#) for more information.

### 11.2.3.2 Secure Proxy Functional Description

This module provides proxy functions for hosts that need to create large data bursts but can only perform small accesses. Examples of this need are:

- large messages (for power control, security control, or IPC)
- data descriptors that are more than a pointer
- DMA Transfer Requests (TR)

All of these require larger data sets, from 12 to 128 bytes, and the storage hardware requires the entire data on the bus in a single burst. Unfortunately, many CPUs cannot produce bursts to device memory, such as registers, and the largest CPU access is typically 8 bytes. So the proxy provides the ability to access the hardware with a single burst, and at the same time allows the CPU to access the same data in smaller accesses. The proxy itself does not contain the resources, but will front other hardware that do contain the resources. The proxy will access this other hardware with the entire data in a single burst, once the host has completed the data.

Figure [Secure Proxy Block Diagram](#) describes Secure Proxy major building block



Figure 11-8. Secure Proxy Block Diagram

#### 11.2.3.2.1 Targets

##### 11.2.3.2.1.1 Ring Accelerator

The RINGACC provides four distinct offsets to use per ring/queue shown in [Table RINGACC Offset per Ring/Queue](#), totaling 4 KB space per ring/queue.

Secure Proxy always writes to tail, which is the offsets from 0x200 to 0x3FF. Secure Proxy always reads from the head, which is the offsets from 0x000 to 0x1FF. The latter two offsets in RINGACC are not used by this proxy. And if the proxy message size is less than 512 bytes, then it always accesses the upper bytes of those regions, so that the message always ends on the last byte of each region, byte 511.

**Table 11-72. RINGACC Offsets per Ring/Queue**

| Offset         | Operation                                 |
|----------------|-------------------------------------------|
| 0x0 - 0x1FF    | Reads pop from head. Writes push to head. |
| 0x200 - 0x3FF  | Writes push to tail. Reads pop from tail. |
| 0x400 - 0x5FF  | Reads peek from head. Writes ignored.     |
| 0x600 - 0x7FF  | Reads peek from tail. Writes ignored.     |
| 0x800 - 0xFFFF | Reserved.                                 |

This means that target writes will use the following calculation:

target base address + (queue  $\times$  4KB) + 0x400 - msg\_size (17), and burst until offset 0x3FF.

And target reads will use the following calculation:

target base address + (queue  $\times$  4KB) + 0x200 - msg\_size (18), and burst until offset 0x1FF.

#### 11.2.3.2.2 Buffers

The proxy does not store all the buffers internally. It is programmed with a buffer base address (SEC\_PROXY\_BUFFER\_L, SEC\_PROXY\_BUFFER\_H), and all accesses to the buffer are made through the output VBUSM port using that base. The external buffer must be enough to store one msg\_size per proxy thread. The proxy only includes a small temporary buffer to save one entire message when accessing the target. Otherwise all host accesses are made to the external buffer. This buffer storage must be considered private for the proxy hardware, so any other access can cause unpredictable results.

#### 11.2.3.2.3 Proxy Credits

To support outbound proxy limits, the proxy will use internal credits for tracking resource usage.

SEC\_PROXY\_THREAD[a].CTL register sets the max credits each outbound proxy thread contains. When a proxy thread sends a message, the current credit count (SEC\_PROXY\_THREAD[a].STATUS) decrements by 1. If the current credit count is 0, then the proxy thread is not allowed to send any more messages, and they just remain inside the proxy (so that the host can come back later when a credit has become available and quickly send the same message). When a message that was send by this proxy thread is read by an inbound proxy thread then the credit is returned to this proxy thread and the current credit count increments by 1.

For inbound proxy threads, the credits are used to track pending messages. When an outbound proxy thread sends a message that is read by this proxy thread, then the current credit count of this proxy thread is incremented by 1. A current credit count that is non zero indicates a message is pending and can be read. When the proxy thread completes the read of a message the current credit count is decremented by 1. If the current credit count is zero, then the proxy thread will read an empty message where all the data is 0s. The credit count saturates at 255, so if there can be more messages in the system for that proxy thread than 255 then multiple proxy threads should be used, or the count can become mismatched after a saturate.

#### 11.2.3.2.4 Proxy Private Word

To support tracking of credits from each proxy thread, the proxy will extract the first word from the total message size for private tracking usage. This will include saving the proxy thread ID used within the proxy. This is necessary so that when a proxy reads a new message from the target it can inspect this word and return the credit to the source proxy thread. This allows the outbound proxy threads to have a set number of message credits, which decrement when a new message is written, and increment when a message from that proxy thread is read, thus keeping the credits in the system coherent. Any data written to this first word of the message will be ignored, so software should not write to the first word of messages through the proxy. Consumer software can use the first word to identify the source proxy thread of the message (SEC\_PROXY\_DATA\_j).

#### 11.2.3.2.5 Completion Byte

The proxy completes a message when the completion byte is accessed. This completion byte is the final byte in the full size of the message. This byte can be written by any size access, whether byte, 32-bit, or 64-bit word. The write of a message is not complete until this final byte of the message is written, and only then will the message be sent to the target. The read of a message is not complete until this final byte of the message is read by the host, and only then will reading a new message be allowed. Even if the final byte of the message is not needed, it must be accessed to complete the message inside the proxy hardware.

#### 11.2.3.2.6 Proxy Thread Sizes

There are a configurable number of proxy threads in the module. Each thread has its own address space to the module and determining which proxy thread is being accessed is simply based on the address bits above the final size of each proxy thread space. Since each proxy thread will be programmed to a single resource, the only space requirement is that for using 4 KB to match typically used MMU page sizes. Only the first N bytes, matching the target channel size, is usable.

#### 11.2.3.2.7 Proxy Thread Interleaving

Each proxy thread must have a single owner, as each proxy thread only has a single buffer to work on the current data. If there are multiple owners in the system, they must each use their own proxy thread. Then they will have their own buffer and each can access a different resource at the same time. Each proxy thread is completely independent and kept coherent regardless of accesses to other proxy threads or regardless of the order of accesses. So the proxy support interleaving of multiple hosts' accesses.

#### 11.2.3.2.8 Proxy States

Each proxy thread uses a simple state machine to track the currently usage by that host. This state machine is used to track when a proxy thread is in use or not, but also for error detection. The proxy thread always starts in idle state, when there is no currently activity. There is a write state for when the proxy thread has been written and contains data that has yet to be written to a resource. There is a read state for when the proxy thread has read data from a resource and that entire data has not been fully read by the host. When a proxy thread access completes, final write or final read, then the state will go back to idle. The following sections show the utilization of these states.

#### 11.2.3.2.9 Proxy Host Access

A proxy thread begins in an idle state, where there is no data in the buffer. In this state the proxy thread will accept an access to the resource.

#### 11.2.3.2.10 Proxy Host Writes

The first write to an idle proxy thread puts the proxy thread into write mode for the selected channel. Further legal writes are stored in the buffer for the enabled bytes and offset within the buffer. A write to a previously written location will overwrite the previous data. The buffer is not cleared initially, so if a byte is not written, the message will include previous buffer data. When there is a legal write to the last byte of the resource, then the entire data is written by the proxy to the target and channel as a single write burst. The proxy will wait for the write status from the target write before it sends the write status for this final byte host write. This allows the host to use the write status to guarantee the entire write data from the proxy has landed at the target. The proxy thread is then put back into idle state. A write completion when there are no credits available results in the message not being written to the resource and the proxy thread remains in write mode (so that the message can be quickly completed when a credit becomes available).

#### 11.2.3.2.11 Proxy Host Reads

When in idle state, the first read to the proxy thread will put the proxy into read state, and the proxy will read the target and channel requested in a single burst of the target's channel size. When the data is returned it is stored in the buffer and the accessed part is returned to the host. Further legal reads are allowed and return the accessed data in the buffer. When there is a legal read to the last byte of the resource, the accessed data is returned, and the proxy thread is put back into idle state. If an initial read is made and there are no pending messages, the proxy thread will return an empty message, where the data is all 0s.

#### **11.2.3.2.12 Buffer Accesses**

Each read or write will actually trigger a read or write to the external buffer space allocated for that proxy thread, where the real message data is stored. In addition, when a write message completes, the external buffer will be read for the entire message for that proxy thread so that it can then be written to the target. Similarly, after a read causes a read from the target to get a new message, the entire message is written to the external buffer to store the message to the buffer.

#### **11.2.3.2.13 Target Access**

After the write has completed and the external buffer read for the entire message, the entire message is then written to the target as a single burst. Similarly, for a read that needs a new message, the target is read for a full message as a single burst.

#### **11.2.3.2.14 Error State**

If an error is detected in a proxy thread, the proxy will put that proxy thread into error state, and the current buffer will be lost. A status bit will be set that indicates the proxy thread is in error. All accesses to that proxy thread will be ignored until the status bit is cleared. Once cleared the proxy thread is put back into idle state. Errors are an access to an offset beyond the length of the message, or a mismatch in the direction of access against what was programmed such as reading an outbound thread or writing an inbound thread.

#### **11.2.3.2.15 Permission Inheritance**

The proxy will automatically inherit the permissions from the access and pass these to the target upon the target burst access. The exact transactions that are inherited from are the final byte write or the first read, and these exact permissions are used on the output bus transaction that accesses the target.

#### **11.2.3.2.16 Resource Association**

Each proxy thread has a register (SEC\_PROXY\_THREAD[a].CTL) to define the resource within the target that the proxy thread is mapped to. The host has no ability to access any other resource in the target. This allows the setup of the proxy to determine the resources that all the hosts use.

#### **11.2.3.2.17 Direction**

Each proxy thread has a register (SEC\_PROXY\_THREAD[a].CTL) to define the direction for access. It can either be an outbound proxy thread for writing messages to resources. Or it can be an inbound proxy thread for reading messages from resources. The host must match the direction programmed or it will result in a proxy thread error.

#### **11.2.3.2.18 Threshold Events**

Each proxy thread can produce events based on the state of the resource it uses. For outbound proxy threads, a threshold can be set so that an event is produced when there are now at least N messages available to write. For inbound proxy threads, a threshold can be set so that an event is produced when there are now at least N messages available to read. These threshold values are programmed in SEC\_PROXY\_EVT\_MAP[j], allowing the host to determine how often it gets events. Programming the count values while the threshold is set to 0 will not trigger events, but if the threshold is not 0 then programming the counts will trigger events based on whether the threshold is reached or not. No event is generated if the event is programmed to 0xFFFF.

#### **11.2.3.2.19 Error Events**

Each proxy thread can produce an event when it has detected an error. This error occurs when the host violates the programmed setup of the proxy thread or accesses beyond the message size. There is a separate status bit per proxy thread for these errors. No event is generated if the event is programmed to 0xFFFF.

#### **11.2.3.2.20 Bus Error and Credits**

If a target read for a message returns a bus error, this indicates the read was bad and the data is corrupt and usually 0s. Because the private word is contained in the message, if the private word is corrupted then the source proxy thread is not valid and the credit return will not be correct. Since the data is usually 0, this means the credit would be returned to proxy thread 0 incorrectly most of the time. And the credit will be lost for the

actual source proxy thread of the message that was not read correctly. The hardware has no way to correct for this, as the message from the target is corrupt so it does not know the correct owner of the credit. If software detects that a read message is corrupt, it can attempt to correct the situation by resetting the affected proxy threads using that queue, to restore their credit counts back to the default. Software may also want to reset proxy thread 0 since it may be getting extra credits.

#### 11.2.3.2.21 Debug

When the transaction has the emudbg set for a read, all side effects will not occur. This means that the read will not cause a target read since that would affect the target, and instead current buffer will be read even if the previous message has completed.

### 11.2.4 Interrupt Aggregator (INTAGGR)

This chapter describes the INTAGGR module, part of DMSS

#### 11.2.4.1 INTAGGR Overview

The Interrupt Aggregator (INTAGGR or INTA) provides a centralized machine which handles the termination of system events to that they can be coherently processed by the host(s) in the system. The main function of the module is to convert between 'global events' (assertion and de-assertion events transmitted on the event-transport-lane (ETL) bus) and 'local events' (level sensitive signals on output, and level or edge sensitive signals on input).

**Table 11-73. INTAGGR Allocation Within Device Domains**

| Module Instance | Parameters |         |
|-----------------|------------|---------|
|                 | MCU        | MAIN    |
| DMSS0_INTAGGR0  | -          | ✓(DMSS) |

#### 11.2.4.1.1 INTAGGR Features

The DMSS0\_INTAGGR0 supports the following features:

- 64-bit VBUSP target using 64-bit registers
- Provides a set of TI Interrupt Architecture compliant interrupt status and mask register sets which are used to pass specific event status to one or more Host blocks.
  - Maps a collection of DMA Messaged Events which are input through an Event Transport Lane into specific bit locations in one or more interrupt cause registers
  - Mapping is performed based on a programmable table which provides a single location for each ordinal input event number (0 through sevt\_cnt-1)
    - Table specifies a specific bit in a specific cause register that the event should set or clear depending on the type of event (up vs down)
    - Tracks a single 'event up' / 'event down' condition. There is no event counting. (The 'cnt' field of the ETL is ignored.)
  - Tracked status interrupts are presented to the user through a standard interrupt register interface.
    - Provides separate 'enable set' and 'enable clear' registers.
    - Provides both masked and unmasked interrupt status.
    - Interrupt status bits can be manually cleared using 'write 1 to clear'.
- Provides an optional set of Unmapped Event (UNMAP) which can take an 'unmapped' event from the ingress ETL and generate a Global event on the egress Event Transport Lane (ETL) interface.
  - Each ingress event can generate an egress Global event on the egress ETL, controllable through a mapping register.
  - Each mapping register has the option of alternatively directly setting an interrupt status bit.
- Provides an optional set of Global Event Input (GEVI) counters which can count events which were delivered via an ingress Event Transport Lane (ETL).
  - Each counted event provides an MMR by which the count can be read and an MMR by which a specified amount can be decremented by the host.
  - Each counted event generates an egress Global event on a zero to non-zero and non-zero to zero transition, controllable through a mapping register.
  - Each mapping register has the option of alternatively directly setting an interrupt status bit.
- Provides an optional set of Global Event Input (GEVI) 'Multicast' registers which can take a Global event from an ingress ETL and generate two egress Global events on the egress ETL interface.
  - Each mapping register has the option of alternatively directly setting an interrupt status bit.

- Provides an optional set of Local Event Input (LEVI) to Global event registers which can be used to convert pulsed discrete interrupt inputs or clock synchronous rising edge events into Global events on an egress ETL.
  - Each ingress event index provides a configurable 'pulse' or 'rising edge' bit, plus the configurable index of the generated Global event.
- Supports dynamic clock gating via

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### 11.2.4.1.2 INTAGGR Parameters

Table *Interrupt Aggregators Parameters* shows the Interrupt Aggregator 0, parameters set during design time.

**Table 11-74. Interrupt Aggregators Parameters**

| Module Instance | Parameters         |                   |                   |                   |                   |
|-----------------|--------------------|-------------------|-------------------|-------------------|-------------------|
|                 | VINTR <sup>1</sup> | SEVI <sup>2</sup> | GEVI <sup>3</sup> | LEVI <sup>4</sup> | MEVI <sup>5</sup> |
| DMSS0_INTAGGR0  | 184                | 1536              | 256               | 32                | 128               |

(1) VINTR – Number of Virtual Interrupt outputs. These are connected to the interrupt router inputs. Value can be read from INTAGGR\_INTCAP register.

(2) SEVI – Number of Main (Steerable) Events. Value can be read from INTAGGR\_INTCAP register.

(3) GEVI – Number of Countable Events. Value can be read from INTAGGR\_AUXCAP register.

(4) LEVI – Number of Local Event inputs. Value can be read from INTAGGR\_AUXCAP register.

(5) MEVI – Number of Multicast Events. Value can be read from INTAGGR\_AUXCAP register.

#### 11.2.4.2 INTAGGR Functional Description

The Interrupt Aggregator (INTAGGR) provides a centralized machine which handles the termination of system events to that they can be coherently processed by the Host(s) in the system. Both the signaling and content of TI system events are incompatible with standard interrupt controllers. The INTAGGR provides mechanisms which convert the TI proprietary system events to standard level sensitive pending bits which can be used by all downstream interrupt infrastructure. Events can be presented to the INTAGGR in two different forms:

- Events may be active high pulses, or clock synchronous rising edges, which are input on separate orthogonal pins. These are called 'Local Events'.
  - Local event signals that are used in pulse counting mode must be sourced by the same clock as the interrupt aggregator.
  - Local event signals that are used in edge counting mode must be sourced by pseudo-synchronous sources (and be a slower clock multiple) to the interrupt aggregator clock, and they must remain high for at least 1 'slow' clock cycle.
- Events may be messages which are input in time division multiplexed sequential order from an Event Transport Lane. These are called 'Global Events'.

In both cases, these events need to be conditioned to transition them from a transient indicator that something occurred to a persistent and reliable indication of the current state of the system. The IA is architected to perform this conversion in an efficient and cost effective manner.

##### 11.2.4.2.1 Submodule Descriptions

###### 11.2.4.2.1.1 Status/Mask Registers

The Status and Mask Registers block is responsible for providing persistent storage for the interrupt status and mask bits and for formatting those in a way that is compliant to the TI Interrupt Architecture requirements. These requirements include the ability to set and clear bits orthogonally and to provide a masked version of the status register that corresponds to the supplied bit mask for each register.

###### 11.2.4.2.1.2 Interrupt Mapping Block

The Interrupt Mapping Block accepts ordinally numbered events (0-N) and converts those ordinal event numbers into a status register number and bit number pair that is then used to manipulate the specified bit in the Status Registers block.

###### 11.2.4.2.1.3 Global Event Input (GEVI) Counters

The GEVI Counters block is responsible for accepting an Event Transport Lane events and summing the total message counts for each received event index. The module creates global egress events for zero to non-zero 'count up' events and non-zero to zero 'count down' events. The egress global event index is configured via GEVI[a]\_MCMAP register, so count status egress events can optionally be fed back into the INT\_AGGR, via the ETL switch fabric.

###### 11.2.4.2.1.4 Local Event Input (LEVI) to Global Event Conversion

The Local to Global event block is responsible for accepting an array of input pins and independently counting the number of cycles for which those pins are asserted high, or by counting individual clock synchronous rising edge events. The counting mode is configurable on a 'per pin' basis. The events are converted to egress Global events on an egress ETL. Global events can optionally be fed back into the INT\_AGGR, via the ETL switch fabric.

###### 11.2.4.2.1.5 Global Event Multicast

The Global event multicast block takes an ingress global event from an ingress ETL, and maps it into two egress Global events on two egress ETL interfaces. Global events can optionally be fed back into the INT\_AGGR, via the ETL switch fabric.

##### 11.2.4.2.2 General Functionality

#### 11.2.4.2.2.1 Event to Interrupt Bit Steering

Each time an event message is received on the Main Event Transport Lane interface, the interrupt mapping block performs a direct lookup into an SRAM using the event number as the address. The SRAM stores a corresponding interrupt status (INTR\_STATUSM) register and bit number within that register (VINT[a]\_STATUS\_MSKD) which are to be manipulated anytime a message is received indicating something occurred on that specific event. When an up event is received, the specified bit in the [a] Status register will be set. When a down event is received, that same bit will be cleared. This block is what allows flexible aggregation of various system events into an array of bits in the interrupt status registers. It is intended that this mapping is essentially static - set up when a resource is allocated and left untouched until the resource is no longer needed. Note that the 'cnt' field of the ETL is ignored and no interrupt counting is performed here. When 'UpDn=1', the interrupt flag bit is set, and when 'UpDn=0', the flag bit is cleared.

#### 11.2.4.2.2.2 Interrupt Status

The event messages which are generated from the event to interrupt bit steering logic are input to the Interrupt Status registers. Each time an event is received, the interrupt status registers machine will assert or de-assert the specified bit in the specified register. The assertion and de-assertion in the interrupt status register is unaffected by the interrupt enable state. When an up event is received, the corresponding bit is set and when a down event is received, the corresponding bit is cleared. Some sources of input events will not include the ability to send a down event. In these cases, the interrupt router provides the ability to clear the status bits through the Interrupt Source Clear register (VINT[a]\_STATUS). The host will write a one to the specific bit in the register which is to be cleared and the interrupt status machine will clear the bit internally. It is not intended that the Host directly clear bits which are automatically cleared via down events from the source itself.

#### 11.2.4.2.2.3 Interrupt Masked Status

Interrupt enable bits are used in conjunction with the interrupt status bits to create the interrupt masked status register values. The interrupt masked status register (VINT[a]\_STATUS\_MSKD) contains the value of the interrupt status ANDed with the value of the interrupt enable register (VINT[a]\_ENABLE\_SET). Each time a new event message is received from the event to interrupt bit steering logic or the interrupt enable register is modified, the interrupt masked status register is re-evaluated.

#### 11.2.4.2.2.4 Enabling/Disabling Individual Interrupt Source Bits

Separate (VINT[a]\_ENABLE\_SET and VINT[a]\_ENABLE\_CLR) registers are provided to allow individual enable bits to be enabled or disabled without the need for a read-modify-write operation. When the VINT[a]\_ENABLE\_SET register is written, all bits within written bytes which are 1 will cause corresponding bits in the internal enable register to be set. When the VINT[a]\_ENABLE\_CLEAR register is written, all bits within written bytes which are 1 will cause corresponding bits in the internal enable register to be cleared.

#### 11.2.4.2.2.5 Global Event Counting

When enabled, the INTAGGR will provide a set of counters which will track how many outstanding messages have been observed for each ingress event index from the ingress Counted Global Event Transport Lane (ETL) interface. For each message received where the 'UpDn' flag is set, the corresponding counter will be incremented by value of the 'cnt' field of ingress message. Events where the 'UpDn' flag is cleared are ignored. The counter is made visible to software in the GEVI[a]\_COUNT register. When software has read the count, it can acknowledge that count has been seen and processed by writing back an integer value specifying the amount by which the counter should be decremented, and the counter will subtract that value from the current count (which may have updated since it was read). The count will saturate at a value of 0xFFFFFFFF. Writing a count 'ack' value higher than the one read is not supported and will produce non-deterministic results.

When a count transitions from zero to a non-zero value, a Global Up 'UpDn=1' event is sent out an egress ETL interface. When a count transitions from a non-zero value to zero, a down 'UpDn=0' event will be sent. The index of the Global event is mappable on a 'per-counter' basis, using the GEVI[a]\_MAP register. The event may be mapped such that it then re-enters INTAGGR's 'Event to Interrupt Bit Steering Block' to generate an interrupt to the host. The event routing is handled by an external event switch fabric. Note that writing a new egress event index via the GEVI[a]\_MAP register does not alter the stored event count for the ingress event register index.

#### **11.2.4.2.2.6 Local Event to Global Event Conversion**

When enabled, the INTAGGR will provide a set of Local to Global event conversion registers. Local events may be discrete clock synchronous pulses or clock synchronous rising edges. The counting mode is configurable on a 'per pin' basis. In pulsed mode, the module will track how many outstanding clock cycle long pulses have been observed on each of the provided LEVI interface pins. For each cycle in which a LEVI input pending bit is asserted the corresponding counter will be incremented by 1. In 'rising edge' mode, the number of rising edge transitions on the pin is counted.

The module will generate egress Global events on its egress ETL, with a different global index configured for each ingress LEVI pin. The LEVI pins numbers (1-N) are converted to arbitrary global event indices via the global event mapping LEVI[a]\_MAP registers. The egress Global events can themselves be mapped to re-enter the INTAGGR's Global Event Counting block, so that the counts can then be made visible to software in the GEVI count registers as described in Section 10.2.7.3.1.3. The event routing is handled by an external event switch fabric.

#### **11.2.4.2.2.7 Global Event Multicast**

In DMSS0\_INTAGGR0, the INTAGGR will provide a set of Global event multicast (GEVI[a]\_MCMAP) registers. These registers allow an ingress Global event on its ingress ETL interface to be mapped into two egress Global events on two separate egress ETL interfaces. A set of registers map the ingress Global event index (1-N) into two arbitrary egress event indices.

### 11.2.5 Packet Streaming Interface Link (PSI-L)

This section describes the Packet Streaming Interface Link (PSI-L) for the device.

#### 11.2.5.1 PSI-L Overview

PSI-L is a packet based protocol used to transfer data between several device modules. Each transaction is routed based on thread ID value instead of physical address. All PSI-L interfaces are point to point direct connections to DMSS0. All switching functions among the PSI-L based interfaces are done inside DMSS0.

The PSI-L also has an event interface referred to as ETL, which is purely used to transfer event information.



psil\_spruim2\_001

**Figure 11-9. PSI-L Overview**

### 11.2.5.2 PSI-L Functional Description

#### 11.2.5.2.1 PSI-L Introduction

The PSI-L is used to transfer words of packet data and control information between two peer entities via direct connection. There are credits used for flow control to guarantee that blocking does not occur between threads. Multiple packet transfers can be ongoing simultaneously across a PSI-L interface each on a separate logical thread but all sharing a single data path through time division multiplexing. Each packet which is transferred is accompanied by a destination thread ID which indicates the logical destination thread to which the packet is being sent.

There is low level hardware handshake between PSI-L initiator and target used for transferring data. As it is blocking by nature, a higher level protocol is also used in which credits are maintained for each thread connection. Moments of non-readiness are allowed on the interface but there is no possibility that one thread can block another for an indefinite time since a thread must have credit for the destination before it is allowed to use the interface.

Figure *PSI-L Connection* illustrates the point to point PSI-L connection.



**Figure 11-10. PSI-L Connection**

PSI-L is intended to be a versatile interface which can carry various types of communications. The following table describes several types of threads which have been defined.

**Table 11-75. Types of PSI-L Threads**

| Type                            | Description                                                                                                 | Example Endpoints                                                          |
|---------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| Queue Management (QM) Messaging | Provides transport for queue push, pop, and divert messages to support distributed queue based work passing | Centralized queue manager or message manager and distributed DMA clients   |
| Direct IO                       | Allows for tunneling CBASS compatible bus transactions through a PSI interconnect                           | Module which has no CBASS initiator to a remote proxy block                |
| DMA Control Transport           | Provides transport for DMA transfer descriptions from a source thread to a destination thread               | DMA channel controller to DMA transfer controller                          |
| DMA Data Transport              | Provides transport for packed data from a source thread to a destination thread                             | Packet oriented module like networking adapters to or from centralized DMA |

Each thread on PSI-L is established between a single thread initiator and a single thread target using a connection oriented transfer mechanism. A thread initiator and a thread target are "paired" to create a logical connection between them referred to as a thread. Pairing is accomplished using a Pair Configuration Message which is valid in all thread types. Pairing can only occur between a thread initiator and a thread target of the same type.

#### 11.2.5.2.2 PSI-L Operation

The PSI-L allows multiple independent streams of packet data (threads) to share a single interface using data phase granularity time division multiplexing. This time division multiplexing is accomplished by dividing each stream into single data transfers. In this way a stream is comprised of a sequence of strongly ordered data transfers but packet transfers between different streams are allowed to be interleaved. Each data phase is qualified with a type identifier which indicates whether the data is packet info, direct IO write or read info, timestamp, software info, control data, payload data, or status.

#### 11.2.5.2.3 Event Transport

PSI-L provides a mechanism by which events can be transported within one or more optional subinterfaces on a link. These sub-interfaces are referred to as event transport lanes (ETLs) and are independent of any PSI-L packet or message transfers which may be ongoing on the other interfaces within the PSI-L. A maximum of one event can be transferred on each event transport lane in each clock cycle. The event transport protocol is a simple request-ready type of hardware handshake.

#### 11.2.5.2.4 Threads

A thread is a complete flow-controlled stream of communication. The PSI-L thread space is divided into a 32K contiguous region representing all of the source threads (0x0000 - 0x7FFF) and a 32K contiguous region representing all of the destination threads (0x8000 - 0x8FFF).

Source threads are responsible for sending request transactions, accepting response transactions, and sending data transfer transactions. Destination threads are responsible for accepting request transactions, sending response transactions, and accepting data transfer transactions. A given thread generally performs only a single class of transactions (see [Table PSI-L Defined Threads](#)). Both source and destination threads may act as initiators for transfers on one of the PSI-L write sub-interfaces but in this case source threads are actually initiating data transfers while destination threads are only responding to a previous request issued by a source request. Source threads only transfer to destination threads and destination threads only transfer to source threads. Transfers between same thread types do not occur.

The following types of message transfers always originate from source threads and terminate in destination threads:

- Configuration write message
- Configuration read message
- QM push message
- QM pop message
- QM divert message
- Direct read operation message
- Direct write operation message
- DMA transfer request message
- DMA data message

The following types of message transfers always originate in destination threads and terminate in source threads:

- Configuration write response message
- Configuration read response message
- QM push response message
- QM pop response message
- QM divert response message
- DMA transfer response message

#### 11.2.5.2.5 Arbitration Protocol

On each cycle, an arbiter built into the initiator side of each interface decides on which thread to transfer data in the next clock cycle. Both forward (from source threads) and reverse (from destination threads) direction

transfers can occur across the same physical interface so the arbiter must ensure that sustained blocking of any thread can occur.

The decision about which thread to allow using the interface is based on the following factors:

1. Whether data is ready at the source to be sent
2. Whether credit exists for the thread such that it is guaranteed there is a place for the data to land in the destination endpoint. For reverse direction transfers (response messages), it is assumed that credit always exists.
3. The relative priority of the traffic that the thread is carrying for the given packet duration
4. Whether the transfer is for a forward or reverse direction thread (requests versus responses).

No thread can be considered for inclusion in arbitration unless both data is available and credit exists in the destination endpoint. For each thread which can be considered in the current arbitration cycle, the arbiter should then pick the thread with the highest priority. Reverse transfers should be considered higher priority than forward transfers.

#### **11.2.5.2.6 Thread Configuration**

Each source thread has programmable registers for configuring the pairing with a corresponding destination thread and for enabling data flow. Each destination thread has programmable registers for reporting the buffering capability of the thread and for enabling data flow. These registers are accessed using configuration read and write messages from a configuration host.

Each configuration write message sent from a configuration host is acknowledged with a configuration write response message from the addressed endpoint. Each configuration read message sent from a configuration host is acknowledged with a configuration read response message from the addressed endpoint.

##### **11.2.5.2.6.1 Thread Pairing**

Depending on the type of traffic that each source thread carries it may or may not have a fixed pairing with a destination thread.

###### **11.2.5.2.6.1.1 Configuration Transaction Pairing**

Configuration write and read transactions are only initiated by a special module called configuration proxy (PSILCFG\_PROXY). Each configuration proxy in the system uses a single source thread which can initiate configuration write and read transactions to the configuration registers of every other source and destination thread in the PSI-L system. The PSILCFG\_PROXY registers are described in *DMASS\_PSILCFG\_0 Registers*.

Each source thread routes to a single target thread and this pairing is specified by programming a required pairing register set for each thread. A source has no ability to change what target thread it talks to. If a source must be able to talk to different targets (or target threads), then it can either have multiple threads or a streaming switch that can be programmed to route the transfers appropriately based on specific packet fields.

###### **11.2.5.2.6.2 Configuration Registers Region**

The configuration registers region contains static configuration information including the settings for linking a thread source to a thread destination. These registers are described in *PSI-L Configuration Registers*. The thread ID mapping is shown in the [PSI-L System Thread Map](#) in *Module Integration*.

## 11.3 Peripheral DMA (PDMA)

This chapter describes the PDMA architecture in the device.

### 11.3.1 PDMA Controller

#### 11.3.1.1 PDMA Overview

The Peripheral DMA is a simple DMA which has been architected to specifically meet the data transfer needs of peripherals, which perform data transfers using memory mapped registers (MMRs) accessed via a standard non-coherent bus fabric. The PDMA module is located close to one or more peripherals which require an external DMA for data movement and is architected to reduce cost by using VBUSP interfaces and supporting only statically configured transfer request (TR) operations.

The PDMA is only responsible for performing the data movement transactions which interact with the peripherals themselves. Data which is read from a given peripheral is packed by a PDMA source channel into a PSI-L data stream which is then sent to a remote peer DMSS destination channel which then performs the movement of the data into memory. Likewise, a remote DMSS source channel fetches data from memory and transfers it to a peer PDMA destination channel over PSI-L which then performs the writes to the peripheral.

The PDMA architecture is intentionally heterogeneous (DMSS + PDMA) to right size the data transfer complexity at each point in the system to match the requirements of whatever is being transferred to or from. Peripherals are typically FIFO based and do not require multi-dimensional transfers beyond their FIFO dimensioning requirements, so the PDMA transfer engines are kept simple with only a few dimensions (typically for sample size and FIFO depth), hardcoded address maps, and simple triggering capabilities.

Multiple source and destination channels are provided within the PDMA which allow multiple simultaneous transfer operations to be ongoing. The DMA controller maintains state information for each of the channels and employs round-robin scheduling between channels in order to share the underlying DMA hardware.

There are two PDMA modules in the device. [Table 11-76](#) shows PDMA allocation across device domains.

**Table 11-76. PDMA Allocation across Device Domains**

| PDMA Instance | Serviced Peripherals                           | Domain |      |
|---------------|------------------------------------------------|--------|------|
|               |                                                | MCU    | MAIN |
| PDMA0 - SPI   | SPI0, SPI1, SPI2, MCAN0                        | -      | ✓    |
| PDMA1 - UART  | UART0, UAR1, UART2, UART3, UART4, UART5, UART6 | -      | ✓    |
| PDMA2 - McASP | McASP0, McASP1, McASP2                         | -      | ✓    |

The PDMA is linked to the DMSS through a direct PSI-L connection. For more details, refer to *Packet Streaming Interface Link (PSI-L)*.

#### 11.3.1.1.1 PDMA Features

##### 11.3.1.1.1.1 PDMA0 - SPI Features

The PDMA0 - SPI module supports the following features:

- Implements CPPI 5.0 compliant third-party Unified Transfer Controller (UTC)
- Provides 1 memory write access unit(s)
  - Each unit supports write bursts up to 64 bytes (on selected channel types)
  - Write Unit 0
    - Provides a 32-bit wide VBUSP write-only initiator interface for peripheral accesses
- Provides 1 memory read access unit(s)
  - Supports 1 outstanding read per interface (VBUSP)
  - Supports read burst up to 64 bytes (on selected channel types)
  - Read Unit 0
    - Provides a 32-bit wide VBUSP read-only initiator interface for peripheral accesses
- Supports up to 15 simultaneous destination (Tx) channels
- Supports negative credit monitoring on Tx channels

- Supports up to 15 simultaneous source (Rx) channels
- Supports Static Transfer Requests Only
- Supports X-Y, MCAN, and AASRC transfer modes (as per configuration)
- Provides per-channel buffering:
  - Provides 8 128-bit word deep data FIFO for each destination channel
  - Provides 8 128-bit word deep data FIFO for each source channel
- Provides 128-bit wide PSI-L compliant data interface to and from DMSS endpoints and remote peripherals

#### **11.3.1.1.2 PDMA1 - UART Features**

The PDMA1 - UART module supports the following features:

- Implements CPPI 5.0 compliant third-party Unified Transfer Controller (UTC)
- Provides 1 memory write access unit(s)
  - Each unit supports write bursts up to 64 bytes (on selected channel types)
  - Write Unit 0
    - Provides a 32-bit wide VBUSP write-only initiator interface for peripheral accesses
- Provides 1 memory read access unit(s)
  - Supports 1 outstanding read per interface (VBUSP)
  - Supports read burst up to 64 bytes (on selected channel types)
  - Read Unit 0
    - Provides a 32-bit wide VBUSP read-only initiator interface for peripheral accesses
- Supports up to 7 simultaneous destination (Tx) channels
- Supports negative credit monitoring on Tx channels
- Supports up to 7 simultaneous source (Rx) channels
- Supports Static Transfer Requests Only
- Supports X-Y, MCAN, and AASRC transfer modes (as per configuration)
- Provides per-channel buffering:
  - Provides 8 128-bit word deep data FIFO for each destination channel
  - Provides 8 128-bit word deep data FIFO for each source channel
- Provides 128-bit wide PSI-L compliant data interface to and from DMSS endpoints and remote peripherals

#### **11.3.1.1.3 PDMA2 - McASP Features**

The PDMA2 - McASP module supports the following features:

- Implements CPPI 5.0 compliant third-party Unified Transfer Controller (UTC)
- Provides 1 memory write access unit(s)
  - Each unit supports write bursts up to 64 bytes (X-Y FIFO transfer mode only)
  - Write Unit 0
    - Provides a 32-bit wide VBUSP write-only initiator interface for peripheral accesses
- Provides 1 memory read access unit(s)
  - Supports 1 outstanding read per interface (VBUSP)
  - Supports read burst up to 64 bytes (X-Y FIFO transfer mode only)
  - Read Unit 0
    - Provides a 32-bit wide VBUSP read-only initiator interface for peripheral accesses
- Supports up to 3 simultaneous destination (Tx) channels
- Supports up to 3 simultaneous source (Rx) channels
- Supports Static Transfer Requests Only
- Supports X-Y, MCAN, and AASRC transfer modes (as per configuration)
- Provides per-channel buffering:
  - Provides 8 128-bit word deep data FIFO for each destination channel
  - Provides 8 128-bit word deep data FIFO for each source channel
- Provides 128-bit wide PSI-L compliant data interface to and from DMSS endpoints and remote peripherals

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

### 11.3.1.2 Functional Description - SPI

#### 11.3.1.2.1 Compliance to Standards

The PDMA complies fully to all standards listed in the previous section.

#### 11.3.1.2.2 Functional Operation

The Peripheral DMA is a simple, low cost implementation of the CPPI 5.0 Unified Transfer Controller. The PDMA module is required to be located close to one or more peripherals (both peripherals and PDMA direct connected to the SCR) which require an external DMA for data movement and is architected to reduce cost by using VBUSP interfaces and supporting only the static Transfer Request subset of UTC features which are useful for peripheral type transactions. Multiple source and destination channels are provided within the PDMA which allow multiple simultaneous transfer operations to be ongoing. The DMA controller maintains state information for each of the channels and employs time division multiplexing between channels in order to share the underlying DMA hardware. A scheduler is provided to control the ordering and rate at which this multiplexing occurs. A block diagram of the PDMA Controller is shown below.

#### 11.3.1.2.2.1 Submodule Descriptions

##### 11.3.1.2.2.1.1 Scheduler

The Scheduler block is responsible for monitoring the fullness level of the various FIFOs, monitoring input DMA triggering events, maintaining channel state information, and issuing credits to the Tx and Rx DMA units when it is time to perform each low level read or write operation.

##### 11.3.1.2.2.1.2 Tx Per Channel Buffers

The Tx Per Channel Buffers implement channelized FIFOs for each DMA channel. A single logical data FIFO is provided for each destination DMA channel that is used for buffering payload data that has been pushed into the PDMA from the Tx PSI-L interface. The Tx Per Channel Buffers are always written with full Tx PSI-L wide words (except for EOL/EOP data phases) but are read on byte granularity from the Tx DMA units.

##### 11.3.1.2.2.1.3 Tx DMA Unit

The Tx DMA Unit block implements all of the state machine functionality necessary to implement static TR type UTC destination channels. The Tx DMA unit waits until it is triggered by an incoming dma event and then writes data from the Tx Per Channel Data FIFO associated with the channel to an external memory mapped target via a VBUSP controller interface. The number and width of the writes that are performed is in accordance with the parameters which were programmed via PSI-L into the static TR for the channel.

##### 11.3.1.2.2.1.4 Rx Per Channel Buffers

Rx Per Channel Buffers implement a logical FIFO for each source DMA channel that is used for buffering payload data that has been fetched by the Rx DMA units. The buffers are byte oriented on write so that the data from the Rx DMA units which may not be full words can be packed properly. The buffers are word oriented on read in accordance with the transport mechanism outlined in the PSI-L Interface specification. Each channel in the Rx DMA controller maps directly onto a thread in the Rx PSI-L interface. The Rx Per Channel Buffer block outputs queue fullness information to the scheduler block which it then uses to determine when it should initiate DMA opportunities to backfill the buffers. The Rx Per Channel Buffer will initiate transfers to the remote paired thread whenever any data is available in each channel buffer and credits are available in the corresponding thread. The block will simultaneously monitor the status of all of the threads and will perform a round robin arbitration between the different threads for the use of the Rx PSI-L interface. Each thread for which the target is indicating it can accept data and which currently has data available in the channel buffer will be included in the arbitration.

#### 11.3.1.2.2.1.5 Rx DMA Unit

The Rx DMA Unit block implements all of the state machine functionality necessary to implement static TR type UTC source channels. The Rx DMA unit waits until it is triggered by an incoming DMA event and then reads data from an external memory mapped source via a VBUSP controller read interface into the Rx Per Channel Data FIFO associated with the channel. The number and width of the writes that are performed is in accordance with the parameters which were programmed via PSIL into the static TR for the channel.

#### 11.3.1.2.2.2 General Functionality (Applicable to All Functions/Modes)

##### 11.3.1.2.2.2.1 Operational States

At any given time, the PDMA can be in one of three different states, as shown in [Table 11-77](#).

**Table 11-77. Operational States**

| Operational State | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Init              | This is the initial state of the machine during and immediately after reset. During this state, all of the RAMs inside the PDMA will be initialized to known values including the ECC redundant parity bits. While in the init state, the DMA will de-assert all ready signals on all applicable target interfaces and will de-assert all request signals on all applicable controller interfaces. The PDMA will automatically transition out of the init state into the idle state when all of the RAM initialization has been completed. |
| Idle              | Once the PDMA leaves the Init state, it enters the Idle state whenever no outstanding transactions are pending on any of the PDMA interfaces (controller or target). The Idle state is generally a transient state and is used by the PDMA to determine when it is appropriate to allow the SoC power management complex to turn off the clock. For clock stop purposes, the module will only report idle if all DMA channels are disabled using the enable bit in PSIL register 2 for each channel.                                       |
| Active            | The PDMA enters the active state as soon as it issues a transaction or receives a transaction on any interface that uses a split protocol (expects a later response for a request). When all transactions have been accounted for (responses have all been either received or sent) the PDMA transitions to the Idle state.                                                                                                                                                                                                                |

##### 11.3.1.2.2.2.2 Clock Stop

The clock stop interface is a request/acknowledge interface used to coordinate the handshaking of properly stopping the main clock to the IP. Before attempting to perform a clock stop operation, software is required to teardown all active channels (via UDMAP 'real time' registers in the UDMAP, or PSIL register 0x408 in PSIL based peripherals), and after this is complete, also clear the global enable bit for all channels (via PSIL register 0x2 in both the UDMAP and PSIL based peripherals). Attempting a clock stop on the IP without first performing the channel teardowns or clearing of global enable bits will result in IP specific behavior that may be **UNDEFINED**.

The PDMA will not drive clock stop IDLE or clock stop ACK while the global enable (PSIL register 0x2) is set for any channel.

##### 11.3.1.2.2.2.3 Emulation Control

The emulation control input (susp\_emususp) and the per channel emulation control 'free' bit allow DMA operation to be suspended on a per channel basis. When the emulation suspend state is entered, the DMA will stop processing receive and transmit TRs for each channel at the next TR boundary. Any TR currently in reception or transmission will be halted at its next FIFO boundary as configured through the 'X' and 'Y' parameters in the static TR. Emulation control is implemented for compatibility with other peripherals. Each source and destination channel can be configured to either honor the suspend signal, or to 'free run' without regard to suspend. This is controlled via the 'free' bit in the channel Enable Register. Note the real time emulation suspend request signal is not supported.

##### 11.3.1.2.2.2.4 Dynamic Clock Gating

The PDMA includes up to two mid level clock gates using `ksdw_pm_clkgate()`. One is on the main clock of the PDMA while the other is on the interal `ecc_aggr` (when RAM is used). These clock gates turn off the clock to their corresponding IP under idle conditions, and then turn the clock back on when work is to be done. Detecting

work is done via internal state, or activity on the PSIL or DMA triggers. The DMA triggers are thus always monitored, even when the clocking to the rest of the IP is disabled.

The dynamic clock gating can be disabled through an external port called `pwr_disable_nogate`. No additional signaling is needed to support the dynamic clock gate, although the PDMA supports the 'early wake' pins on PSIL and VBUSP.

#### **11.3.1.2.2.3 Events and Flow Control**

The following sections describe the simplified mechanism that is provided on the Peripheral DMA for triggering.

##### **11.3.1.2.2.3.1 Channel Triggering**

Channels must be triggered in order for them to perform work. A local event input bus is provided on the peripheral DMA and each bit in the input bus corresponds to the trigger for the channel with the same channel index as the bit index in the bus (bit 0 triggers channel 0, bit 1 triggers channel 1, etc.). The event inputs for XY mode are triggered either via pulse, or by a clock synchronous rising edge. The counting mode is a design time configuration parameter. In MCAN mode, the inputs are expected to be single cycle pulses, synchronous with the PDMA clock.

- Event signals that are used in pulse mode must be sourced by the same clock as the PDMA.
- Event signals that are used in edge mode must be sourced by pseudo-synchronous sources (and be a slower clock multiple) to the PDMA clock, and they must remain high for at least 1 'slow' clock cycle.

The PDMA provides a 2 bit counter per event input to accommodate startup latency in the channel. (In AASRC mode, the signals are not counted, but latched whenever asserted.)

##### **11.3.1.2.2.3.2 Completion Events**

All transfers on PDMA are split TR in that they have a UDMA-P half and a (static) PDMA half. Completion events are designed to be triggered from the UDMA-P half of the split TR.

##### **11.3.1.2.2.3.3 Channel Types**

Each channel in the Peripheral DMA is configured at design time to be either standard X-Y FIFO mode or MCAN channel. The channel type is configured at design time, and can not be changed by software.

###### **11.3.1.2.2.3.3.1 X-Y FIFO Mode**

Most peripherals which are serviced by the Peripheral DMA follow the pattern of transferring X bytes from a fixed, non-changing address in a loop Y times for each triggering event that is received. The X parameter is typically 1-16 bytes and the Y parameter can be any integer up to 2048. If a peripheral can be serviced by this basic functionality then it is recommended to use this mode for the peripheral.

###### **11.3.1.2.2.3.3.2 MCAN Mode**

The MCANSS subsystem was found to require a few minor differences than standard X-Y mode. First, buffer ownership on transmit is different in that the DMA will start out owning the TX buffer space (instead of waiting for an initial DMA event from the MCAN). There is also a requirement to perform a write of a fixed value to a fixed address after each DMA event is serviced to pass ownership of a buffer back to the MCAN. Finally, MCAN packet fragmentation requirement to place an 8 byte header on each 64 byte chunk that is transmitted and to remove the header from each 64 byte chunk (other than the first block) that is received.

###### **11.3.1.2.2.3.3.3 AASRC Mode**

The AASRC mode of the PDMA is similar to the X-Y mode in that X specifies the sample width, any Y specifies the number of FIFO samples to transfer per DMA request, but in addition to this, a programmable FIFO list is supplied that allows a single PDMA channel to transfer data to multiple FIFOs. The FIFO list specifies which FIFOs to access, and in which order to access them. Both AASRC 'stream' and 'group' modes are supported in terms of DMA signalling and the FIFO memory map. When in AASRC mode, the entire PDMA operates exclusively in this mode. AASRC channels do not share the same PDMA as do XY and MCAN channels.

The following addition details apply to the PDMA in AASRC mode:

**Main Features:**

- Up to 16 independent RX channels and 16 TX channels
  - Each channel represents a different data stream to either the UDMA-P-P or a McASP PDMA
- Each channel can be configured to read or write any of the AASRC FIFOs in any order
- Packing support for 1, 2, 3, and 4 byte samples
  - Can directly talk to a McASP using any McASP data format
  - Packing sample size is fixed for a given channel
- Supports both Group and Stream AASRC signaling and FIFO memory maps
  - There is a single stream/group mode setting for each PDMA channel

**Additional details:**

- Each channel has a 'mask' of which DMA requests must fire to activate the channel
  - In stream mode, the mask specifies the all the FIFO DMA requests that must fire
  - In group mode, the mask specifies the one group DMA request that must fire
- Each channel specifies an ordered list of how FIFOs should be accessed
  - All channels use a common list, specifying a range of entry indices within that list. This allows each channel to use a varying number of list elements.
  - The order list can be processed multiple times per DMA request. The number of samples to be transferred per request must match the configured threshold for the DMA request in the AASRC.
- All FIFOs are specified by index only
  - In the TX ordering table, the indices are assumed to be TX FIFOs
  - In the RX ordering table, the indices are assumed to be RX FIFOs
  - If a DMA channel is in 'Group Mode', the PDMA assumes the indices referenced by that channel represent Group Mode FIFOs; otherwise, it assumes Stream Mode FIFOs.
- The PDMA has configured base addressed and inter-FIFO spans such that is can always convert from a FIFO index to the proper Stream or Group mode FIFO address.

**11.3.1.2.2.4 Transmit Operation**
**11.3.1.2.2.4.1 Destination (Tx) Channel Allocation**

A total of 15 destination channels are provided within the DMA for concurrent transfers from Tx per channel buffers to the various attached peripherals. Each Tx channel requires a single PSI-L thread. The Tx channels are allocated as in the following table.

**Table 11-78. Tx Channel Allocation**

| Tx DMA Channel | Function       | Channel Type | Trigger Mode | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 8000           | SPI 0 Tx Ch 0  | XY           | edge         | 000020100138      | 00000000000000     | 00000000000000       |
| 8001           | SPI 0 Tx Ch 1  | XY           | edge         | 00002010014C      | 00000000000000     | 00000000000000       |
| 8002           | SPI 0 Tx Ch 2  | XY           | edge         | 000020100160      | 00000000000000     | 00000000000000       |
| 8003           | SPI 0 Tx Ch 3  | XY           | edge         | 000020100174      | 00000000000000     | 00000000000000       |
| 8004           | SPI 1 Tx Ch 0  | XY           | edge         | 000020110138      | 00000000000000     | 00000000000000       |
| 8005           | SPI 1 Tx Ch 1  | XY           | edge         | 00002011014C      | 00000000000000     | 00000000000000       |
| 8006           | SPI 1 Tx Ch 2  | XY           | edge         | 000020110160      | 00000000000000     | 00000000000000       |
| 8007           | SPI 1 Tx Ch 3  | XY           | edge         | 000020110174      | 00000000000000     | 00000000000000       |
| 8008           | SPI 2 Tx Ch 0  | XY           | edge         | 000020120138      | 00000000000000     | 00000000000000       |
| 8009           | SPI 2 Tx Ch 1  | XY           | edge         | 00002012014C      | 00000000000000     | 00000000000000       |
| 800a           | SPI 2 Tx Ch 2  | XY           | edge         | 000020120160      | 00000000000000     | 00000000000000       |
| 800b           | SPI 2 Tx Ch 3  | XY           | edge         | 000020120174      | 00000000000000     | 00000000000000       |
| 800c           | MCAN 0 Tx Ch 0 | XY           | pulse        | 000002708000      | 0000027010D0       | 00000000000000       |
| 800d           | MCAN 0 Tx Ch 1 | XY           | pulse        | 000002708048      | 0000027010D0       | 00000000000000       |

**Table 11-78. Tx Channel Allocation (continued)**

| Tx DMA Channel | Function       | Channel Type | Trigger Mode | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 800e           | MCAN 0 Tx Ch 2 | XY           | pulse        | 000002708090      | 0000027010D0       | 000000000000         |

**11.3.1.2.2.4.2 Destination (Tx) Channel Out of Band Signals**

The following table shows how PSIL signals are handled for destination channels.

**Table 11-79. Tx Channel Out of Band Signals**

| PSI-L Signal | XY/AASRC Mode                                        | MCAN Mode                                            |
|--------------|------------------------------------------------------|------------------------------------------------------|
| sop          | ignored                                              | ignored                                              |
| eop          | ignored                                              | closes current MCAN packet                           |
| sol          | ignored                                              | ignored                                              |
| eol          | ignored                                              | ignored                                              |
| drop         | ignored                                              | ignored                                              |
| pkt_error    | ignored                                              | ignored                                              |
| tdown        | reflect in status, teardown when data marker reached | reflect in status, teardown when data marker reached |

**11.3.1.2.2.4.3 Destination Channel Initialization**

After reset, all threads/channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will need to first pair the channel with a remote data source (normally a UDMA-P channel), set up the static TR for the channel, and enable the thread.

**11.3.1.2.2.4.3.1 PSI-L Destination Thread Pairing Registers****11.3.1.2.2.4.3.1.1 Enable Register (PSIL Address 0x002)**

| Bits | Field  | Reset | Description                                                                                                                                                                                      |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the TX channel is disabled. When disabled, the channel discards all ingress data. A one to zero transition on this bit fully resets the channel. |
| 30:0 | -      | 0x0   | Reserved.                                                                                                                                                                                        |

**11.3.1.2.2.4.3.1.2 Local Capabilities Register (PSIL Address 0x040)**

| Bits  | Field            | Reset | Description                                                                                                                                       |
|-------|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | -                | 0x0   | Reserved.                                                                                                                                         |
| 28:24 | LocalThreadWidth | 0x2   | Read only element width for the local thread used for pairing purposes. This field is encoded as follows: 0 = 4 bytes, 1 = 8 bytes, 2 = 16 bytes. |
| 23:8  | -                | 0x0   | Reserved.                                                                                                                                         |
| 7:0   | LocalCreditCnt   | 0x7   | Read only local thread free entry count used for pairing purposes.                                                                                |

**11.3.1.2.2.4.3.2 PSI-L Destination Thread Pairing**

After reset, all threads on PSI-L are uninitialized and unpaired. The Host will pair each destination PDMA channel with (typically) a corresponding source channel in the UDMA-P. The PDMA thread is configured to point to the UDMA-P thread and the UDMA-P thread is configured to point to the PDMA thread. Once paired, the source channels in the UDMA-P will send all their data to the destination channel in the PDMA and the destination channel in the PDMA will never see any data other than data from the source channel in the UDMA-P.

### 11.3.1.2.2.4.3.3.3 PSI-L Destination Thread Realtime Enable/Count Registers

#### 11.3.1.2.2.4.3.3.1 RT Enable Register (PSIL Address 0x408)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the TX channel is disabled. When disabled, it discards all held data. It clears DMA event counts and ignores all future DMA events from the peripheral. It maintains data exchange with the UDMA-P so that credit handshake is not disrupted. A 'hard teardown' can be performed by directly clearing this bit. Note that this bit cannot be changed from 0 to 1 if the global enable bit in the peer enable register is 0.     |
| 30   | tdown  | 0x0   | When set, the channel will commence a TX channel teardown procedure. To perform a TX teardown, the teardown bit should be set in the UDMA-P and it will automatically propagate to this register bit with the normal flow of peripheral data. Once the channel is fully stopped and ready to be reused (including returning all credits), the enable bit is cleared.                                                                                                            |
| 29   | pause  | 0x0   | When set, the channel is in a paused state. It will stop on the next FIFO boundary. It continues to accept and count DMA events from the peripherals, but will not act on them. The pause bit can be cleared and data will resume.                                                                                                                                                                                                                                              |
| 28   | flush  | 0x0   | When set, causes all TX channel data to be discarded instead of being written to the peripheral. It essentially allows the TX engine to 'free run' without DMA requests from the peripheral (it will also override 'pause'). This bit should be set only when a channel fails to complete its teardown procedure normally, because a peripheral is no longer functioning or because data flow was halted on a boundary that is not compatible with the static TR configuration. |
| 27:3 | -      | 0x0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2    | error  | 0x0   | When set, the channel has encountered a PSIL protocol violation. The error bit can only be set by hardware, and can only be cleared by software. Once this bit is set, the channel should be fully reset and re-initialized via the PSIL pairing registers.                                                                                                                                                                                                                     |
| 1    | idle   | 0x0   | This is a read-only bit that signifies that the disabled channel is also idle. This bit is read only and can only become set if the enable bit in the RT enable register is cleared.                                                                                                                                                                                                                                                                                            |
| 0    | free   | 0x0   | When cleared, the channel honors the emudbg suspend signal. When set, the channel will free run, regardless of the value of emudbg suspend.                                                                                                                                                                                                                                                                                                                                     |

#### 11.3.1.2.2.4.3.3.2 Destination Thread Byte Count Register (PSIL Address 0x404)

| Bits | Field | Reset | Description                                                                                                                                                                                                                                                                                                   |
|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | bytes | 0x0   | This register contains the number of bytes that have been written to the VBUSP mapped peripheral. The register is write to decrement, so running counts can be tracked by reading register and then writing back the value that was read. It will wrap on overflow. It will reset to zero on a channel reset. |

#### 11.3.1.2.2.4.3.4 Static Transfer Request Setup

After reset, all channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will send configuration transactions across PSIL and will set up the static TR for each destination channel. The format of the TR is identical for each DMA mode, consisting of an X, Y, and Z parameter, but the field interpretation varies somewhat.

##### 11.3.1.2.2.4.3.4.1 X-Y FIFO Mode Static TR

In X-Y FIFO mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                       |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the XY burst description for more information.                                                                                                                            |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                     |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, 4 = 64 bits, and 5-7 = RESERVED |
| Y     | 0x400     | 11:0  | Element count. This field specifies how many elements to transfer each time a trigger is received on the channel.                                                                                                                 |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                          |

##### 11.3.1.2.2.4.3.4.2 MCAN Mode Static TR

In MCAN mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the MCAN burst description for more information.                                                                                                                                                                                                                                                                                                                                                                                                          |
| Acc32 | 0x400     | 30    | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| X     | 0x400     | 26:24 | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Y     | 0x400     | 11:0  | Buffer Size. This field specifies how many bytes should be written to an MCAN TX buffer. This field includes the 8 byte MCAN header on the initial packet fragment. The PDMA will break up the source packet into fragments of this buffer size, copying the 8 byte MCAN header for the initial fragment, and then skipping it for each additional fragment and thus reusing the header from the first fragment. A buffer size less than 16 is treated as 16, and a buffer size greater than 72 is treated as 72. |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

##### 11.3.1.2.2.4.3.4.3 AASRC Mode Static TR

AASRC mode is similar to X-Y FIFO mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description |
|-------|-----------|-------|-------------|
| Burst | 0x400     | 31    | Not used    |

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                                                                                                                                                                                                             |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, and 4-7 = RESERVED                                                                                                                                                                                                                                                                                      |
| Y     | 0x400     | 11:0  | FIFO element count. In AASRC mode, a channel can service multiple FIFOs using a list supplied in its FIFO configuration. This field specifies how many times to service the FIFO list, hence how many elements to transfer to each FIFO, each time a trigger is received on the channel. Note for each loop specified by the value of Y, the entire list is processed. For example, if the FIFO list is 0, 1, 2, 3, and Y is set to 2 loops, the FIFOs are serviced in the order: 0, 1, 2, 3, 0, 1, 2, 3. |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### 11.3.1.2.2.4.3.4.4 AASRC TxFifoConfig (PSIL Address 0x405)

This register describes the FIFO list to be processed for this TX channel.

| Bits  | Field       | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | GroupMode   | 0x0   | When set, the channel is in 'Group Mode'. It will look for Group Mode DMA requests, and access the Group Mode FIFOs. When clear, the channel is 'Stream Mode'. It will look for Stream FIFO DMA requests, and access the Stream Mode FIFOs.                                                                                                                                                                                                                                                                         |
| 30    | DmaReqReset | 0x0   | When set, resets any latched DMA request using the DmaReqMask. This bit is self-clearing. It should be used to synchronize the AASRC event status with the PDMA in the event that the AASRC has been previously used and it is not known if the PDMA may have latched, and is holding, previous DMA requests.                                                                                                                                                                                                       |
| 23:20 | LastSlot    | 0x0   | This is the index (0-15) of the last slot in the TX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                           |
| 19:16 | FirstSlot   | 0x0   | This is the index (0-15) of the first slot in the TX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                          |
| 15:0  | DmaReqMask  | 0x0   | This field holds a set of flags indicating which AASRC DMA requests must fire in order for this channel to activate.<br><br>In Steam Mode, these 16 flags correspond to the 16 DMA requests for each TX FIFO. The flags corresponding to all TX FIFOs involved with the channel should be set to 1.<br><br>In Group Mode, these flags indicate which Group Mode DMA requests must fire. In this case, only bits 3:0 are relevant and only one bit should be set to 1 as a DMA channel only services a single group. |

#### 11.3.1.2.2.4.3.4.5 AASRC TxOrderTable0 (PSIL Address 0x406)

This table is filled with FIFO index values. TX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all TX threads.

| Bits  | Field  | Reset | Description              |
|-------|--------|-------|--------------------------|
| 31:28 | Entry7 | 7     | TX FIFO Index for slot 7 |
| 27:24 | Entry6 | 6     | TX FIFO Index for slot 6 |
| 23:20 | Entry5 | 5     | TX FIFO Index for slot 5 |
| 19:16 | Entry4 | 4     | TX FIFO Index for slot 4 |
| 15:12 | Entry3 | 3     | TX FIFO Index for slot 3 |
| 11:8  | Entry2 | 2     | TX FIFO Index for slot 2 |
| 7:4   | Entry1 | 1     | TX FIFO Index for slot 1 |
| 3:0   | Entry0 | 0     | TX FIFO Index for slot 0 |

#### 11.3.1.2.2.4.3.4.6 AASRC TxOrderTable1 (PSIL Address 0x407)

This table is filled with FIFO index values. TX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all TX threads.

| Bits  | Field   | Reset | Description               |
|-------|---------|-------|---------------------------|
| 31:28 | Entry15 | 15    | TX FIFO Index for slot 15 |
| 27:24 | Entry14 | 14    | TX FIFO Index for slot 14 |
| 23:20 | Entry13 | 13    | TX FIFO Index for slot 13 |
| 19:16 | Entry12 | 12    | TX FIFO Index for slot 12 |
| 15:12 | Entry11 | 11    | TX FIFO Index for slot 11 |
| 11:8  | Entry10 | 10    | TX FIFO Index for slot 10 |
| 7:4   | Entry9  | 9     | TX FIFO Index for slot 9  |
| 3:0   | Entry8  | 8     | TX FIFO Index for slot 8  |

#### 11.3.1.2.2.4.3.5 PSI-L Destination Thread Enables

PSI-L destination threads must first be enabled in order to accept data. Threads are enabled or disabled by setting or clearing the enable bit in the PSI-L pairing registers for the thread. When a thread is disabled, it must drop any data phases which are sent but properly return the credits for the data phases which are dropped.

Once a thread is paired, the TR has been set up and the enable is asserted, the channel is armed and ready to be triggered to perform the specified set of write transactions.

#### 11.3.1.2.2.4.4 Data Transfer

Packet transmission is accomplished within the PDMA by unpacking and moving data from the Tx Per Channel FIFOs which were filled via the Transmit PSI-L Interface to specified memory mapped address ranges via the VBUSP controller interfaces. On the Tx side of the PDMA, these transfers are always writes. Each write transfer which is performed by the Tx DMA Unit is to a destination address that is hardcoded in the channel at design time and of a size as specified in the static Transfer Request.

The sequences of logical transactions that are performed by the PDMA on the Memory I/F during transmit is dependent on the channel type. The following sections describe what will happen for the different channel types.

##### 11.3.1.2.2.4.4.1 X-Y FIFO Mode Channel

The PDMA channel will remain idle until a pulse is detected on the associated input DMA request event pin. Once the pulse is detected, the DMA will sequentially issue a total of 'Y' parameter writes of 'X' parameter bytes to the data\_address specified in the tchan\_info parameter for the channel. Each write that the DMA performs

will be a single 'X' element in size (no large bursts). Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The write transfers that are performed will be accomplished as quickly as possible given availability of data in the Tx channelized FIFO and given the arbitration that may occur as a result of other channels also using the same write unit.

#### **11.3.1.2.2.4.4.1.1 X-Y FIFO Burst Mode**

The burst mode for XY is designed to allow the PDMA to burst across a FIFO region, while extracting out the 'sample size' from each data phase. So for example, it can read a "burst" of multiple 32-bit words from a McASP, and grab only 24-bits from each data phase.

It uses the same registers as standard XY mode, where X is the encoded sample size, and Y is the number of samples to read/write per DMA request. Setting bit 31 of the XY register enables burst.

The following are the rules for enabling burst mode. Incompatible peripherals do not need to enable burst, or can enable it on RX without enabling it on TX.

- The VBUSP address will increment throughout the burst
- Bursts will be sub-divided to fit into a 64 byte transfer window
- One sample is transferred for every bus data phase
  - Cannot burst one byte samples from a 16-bit peripheral on a 32-bit bus
  - Cannot burst 64-bit samples on a 32-bit bus (configure for 2 32-bit samples instead)
- PDMA will 'gap' the byte enables on writes as needed

#### **11.3.1.2.2.4.4.2 MCAN Mode Channel**

The PDMA channel will remain idle until data is received from the UDMA-P over the PSIL interface. At this time, the PDMA will immediately start copying packet bytes into the MCAN TX buffer corresponding the PDMA/MCAN channel. The number of bytes copied is smaller of the remaining bytes in the packet, or the value of the 'Y' parameter. Once a TX buffer has been filled, the PDMA will transfer ownership of the buffer to MCAN by performing an MCAN register write. The PDMA will then wait to regain ownership of the TX buffer by waiting for the corresponding MCAN TX event. At this time, the PDMA will continue with refilling the TX buffer for the next packet fragment. On subsequent fills (until the end of packet is reached), the PDMA will skip over the 8 byte MCAN header, leaving the original contents from the initial fragment copy in place.

#### **11.3.1.2.2.4.4.2.1 MCAN Burst Mode**

Since MCAN buffers are stored in linear memory, the burst mode for MCAN is a simple linear burst across the transfer window. The max burst size is set to the 72 byte size of the MCAN buffer. This will allow a full MCAN packet to be read out as a single burst.

#### **11.3.1.2.2.4.4.3 AASRC Channel**

The AASRC channel is controlled primarily via the channel's TxFifoConfig register. This register holds 3 basic pieces of information:

- Whether the channel uses AASRC Stream Mode or Group Mode
- The slot range in the order table used (from designated first slot to designated last slot)
- The AASRC DMA request event(s) that must fire before the channel becomes active

The channel will remain idle until a pulse is detected on ALL associated input DMA request event pins required by the TxFifoConfig setting. The pulses for the individual events are latched and held by the PDMA until they all arrive.

Once the channel activates, it will start reading FIFO index values from the TxOrderTable, starting at the configured 'First Slot' and ending with the 'Last Slot'. The actual FIFO indices used are obtained from the ordering table. For example, say FirstSlot=3 and LastSlot=5. If the first 6 slots of the ordering table were: 0, 2, 4, 6, 8, 10, the FIFOs written for the event would be 6, 8, and 10, because 'slot 3' of the table contains 6, and it would proceed through 'slot 5' of the table which contains 10.

The X and Y registers are still used as they are in a normal X-Y mode. When accessing each FIFO, the setting of X determines the sample byte width written to the FIFO. The value of 'Y' determines how many times the entire FIFO list is processed for each activation of the channel.

Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The write transfers that are performed will be accomplished as quickly as possible given availability of data in the TX channelized FIFO and given the arbitration that may occur as a result of other channels also using the same write unit.

#### **11.3.1.2.2.4.5 Transmit PSI-L Interface Transactions**

The PDMA will accept data across the Tx PSI-L Interface in accordance with the physical handshaking protocol as defined in the PSI-L Interface specification. The value sources for the output pins on the PSI-L interface are described in the following table.

| Pin              | Output Value / Source From PDMA                                                                    |
|------------------|----------------------------------------------------------------------------------------------------|
| strm_i_link      | This signal is asserted high to indicate the PSI-L link is valid.                                  |
| strm_i_ready     | This signal is asserted high anytime there is space in the PSI-L ingress fifo.                     |
| strm_i_sreq      | This signal is asserted high anytime there is credit return data waiting in the PSI-L status fifo. |
| strm_i_sthreadid | This is set to the local destination thread that is returning credit.                              |
| strm_i_sccnt     | This is set to the number of credits being returned, or 0 on a TX teardown acknowledgement.        |

#### **11.3.1.2.2.4.6 Tx Pause**

The Host initiates a channel pause by setting the pause bit in the RT enable register. The paused channel can be resumed by clearing the register bit.

#### **11.3.1.2.2.4.7 Tx Teardown**

The Host initiates a channel teardown by setting the tdown bit in the UDMA-P channel that is paired with the PDMA. The UDMA-P communicates the teardown state through the PSI-L data channel, to ensure that the teardown is not seen by the PDMA until all the previous UDMA-P data for the channel has been flushed.

At this time, the teardown state will be reflected in the PSI-L RT Enable register of the PDMA. Note that a non-synchronized teardown can also be initiated by directly clearing the enable bit in the PSI-L RT Enable register of the PDMA.

Once all data has been flushed from the PDMA to the peripheral, the enable state of the PDMA channel will be cleared in the PSI-L RT enable register, but the teardown bit will remain high. A teardown completion indication is sent back across the status pins of the PSI-L in the form of a credit response with sccnt=0. Upon completion, no further packet processing will occur until the Host re-configures the channel. If the channel fails to teardown because the peripheral has stopped responding, or if the UDMA-P transmission stops on a data boundary that is not compatible with the static TR configuration, the flush bit in the RT enable register can be set to guarantee that all data can be properly flushed from the internal pipe.

#### **11.3.1.2.2.4.8 Tx Channel Reset**

In the unlikely event that channel synchronization is corrupted, a channel may fail to teardown gracefully, even with flush enabled. If this occurs, the channel may be reset by clearing the enable bit in the PSI-L Enable register. This will cause a local reset of the entire channel, including TR and pairing registers. Note that it does not reset the UDMA-P peer. Resetting the UDMA-P peer is also required before re-initializing and re-pairing the channel.

#### **11.3.1.2.2.4.9 Tx Debug/State Register**

The debug/state registers are supplied to give software applications additional information about the PDMA than they would need in regular operation, but which may be useful in debug situations. The registers appear on the PSI-L bus, near the static TR registers. For transmit, they are defined as in the following table.

| Name     | PSIL Addr | Field | Description                                                                                                                                                                                                                                                   |
|----------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Y        | 0x402     | 15:0  | This field holds the current Y count. In X-Y FIFO mode, this is the number of X sized samples yet to write to the peripheral for the DMA event being serviced. In MCAN mode, this field holds the next write offset to use when writing to the CAN TX buffer. |
| InEvent  | 0x403     | 31    | When set, the PDMA is in the middle of processing a FIFO event.                                                                                                                                                                                               |
| Flush    | 0x403     | 30    | When set, the PDMA is processing in a flushing state, where it runs without waiting for DMA requests and without writing data to the peripheral. It is only operating its internal state machine to allow internal data pipes to drain properly.              |
| Pause    | 0x403     | 29    | When set, the PDMA waiting in a paused state. This bit will clear when data starts flowing again from the UDMA-P.                                                                                                                                             |
| Data     | 0x403     | 28    | When set, there is a non-zero amount of data still waiting to be written to the peripheral.                                                                                                                                                                   |
| XData    | 0x403     | 27    | When set, there is enough data still waiting to be written to the peripheral to start servicing a peripheral DMA event.                                                                                                                                       |
| State    | 0x403     | 23:20 | This code reflects the current state of the PDMA channel, and is specific to the current implementation.                                                                                                                                                      |
| EventCnt | 0x403     | 19:16 | This field holds the number of backlogged DMA events yet to be serviced.                                                                                                                                                                                      |

### 11.3.1.2.2.5 Receive Operation

#### 11.3.1.2.2.5.1 Source (Rx) Channel Allocation

A total of 15 source channels are provided within the DMA for concurrent transfers from the various attached peripherals into the Rx per channel buffers and on to the PSI-L Rx Interface. Each Rx channel requires a single PSI-L thread. The Rx channels are allocated as in [Table 11-80](#).

**Table 11-80. Rx Channel Allocation**

| Rx DMA Channel | Function       | Channel Type | Trigger Type | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 0              | SPI 0 Rx Ch 0  | XY           | edge         | 00002010013C      | 00000000000000     | 00000000000000       |
| 1              | SPI 0 Rx Ch 1  | XY           | edge         | 000020100150      | 00000000000000     | 00000000000000       |
| 2              | SPI 0 Rx Ch 2  | XY           | edge         | 000020100164      | 00000000000000     | 00000000000000       |
| 3              | SPI 0 Rx Ch 3  | XY           | edge         | 000020100178      | 00000000000000     | 00000000000000       |
| 4              | SPI 1 Rx Ch 0  | XY           | edge         | 00002011013C      | 00000000000000     | 00000000000000       |
| 5              | SPI 1 Rx Ch 1  | XY           | edge         | 000020110150      | 00000000000000     | 00000000000000       |
| 6              | SPI 1 Rx Ch 2  | XY           | edge         | 000020110164      | 00000000000000     | 00000000000000       |
| 7              | SPI 1 Rx Ch 3  | XY           | edge         | 000020110178      | 00000000000000     | 00000000000000       |
| 8              | SPI 2 Rx Ch 0  | XY           | edge         | 00002012013C      | 00000000000000     | 00000000000000       |
| 9              | SPI 2 Rx Ch 1  | XY           | edge         | 000020120150      | 00000000000000     | 00000000000000       |
| 10             | SPI 2 Rx Ch 2  | XY           | edge         | 000020120164      | 00000000000000     | 00000000000000       |
| 11             | SPI 2 Rx Ch 3  | XY           | edge         | 000020120178      | 00000000000000     | 00000000000000       |
| 12             | MCAN 0 Rx Ch 0 | XY           | pulse        | 000002708900      | 000002701098       | 00000000000000       |
| 13             | MCAN 0 Rx Ch 1 | XY           | pulse        | 000002708990      | 000002701098       | 00000000000000       |
| 14             | MCAN 0 Rx Ch 2 | XY           | pulse        | 000002708A20      | 000002701098       | 00000000000000       |

### 11.3.1.2.2.5.2 Source Channel Initialization

After reset, all threads/channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will need to first pair the channel with a remote data source (normally a UDMA-P channel), set up the static TR for the channel, and enable the thread.

#### 11.3.1.2.2.5.2.1 PSI-L Source Thread Pairing Registers

##### 11.3.1.2.2.5.2.1.1 Peer Thread ID Register (PSIL Address 0x000)

| Bits  | Field           | Reset | Description                                                                                                                                       |
|-------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | ThreadPriority  | 0x0   | This field is hard coded to 0x0 and is not writable                                                                                               |
| 28:24 | PeerThreadWidth | 0x0   | Datapath width of paired peer destination thread. This field is encoded as follows: 0 = 32-bit, 1 = 64-bit, 2 = 128 bit, 3 = 256 bit, 4 = 512 bit |
| 23:16 | -               | 0x0   | Reserved.                                                                                                                                         |
| 15:0  | Peer ThreadID   | 0x0   | Thread ID to which all non-Transfer Response, non-Config messages from this thread will be sent.                                                  |

##### 11.3.1.2.2.5.2.1.2 Peer Credit Register (PSIL Address 0x001)

| Bits | Field     | Reset | Description                                                                       |
|------|-----------|-------|-----------------------------------------------------------------------------------|
| 31:8 | -         | 0x0   | Reserved.                                                                         |
| 7:0  | CreditCnt | 0x0   | Free entries in destination thread. Legal range is 0 - 128 in number of elements. |

##### 11.3.1.2.2.5.2.1.3 Enable Register (PSIL Address 0x002)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                          |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the RX channel is disabled. When disabled, the channel ignores all credit returns, and will not generate egress data. A one to zero transition on this bit fully resets the channel. |
| 30:0 | -      | 0x0   | Reserved.                                                                                                                                                                                                                            |

#### 11.3.1.2.2.5.2.2 PSI-L Source Thread Realtime Enable/Count Registers

##### 11.3.1.2.2.5.2.2.1 RT Enable Register (PSIL Address 0x408)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | <p>When set, the channel is enabled. When cleared, the RX channel is disabled. When disabled, the channel ignores all DMA events from the peripheral. It maintains proper data transfers with the UDMA-P such that the credit handshake is not disrupted. However, unlike teardown, it does not close out the current open packet. Thus the teardown bit should always be used to disable an RX channel instead of manually clearing this bit. Failing to use teardown may result in stale data remaining in the internal RX FIFO, which would also prevent the channel from going idle without a channel reset.</p> <p>Note that this bit cannot be changed from 0 to 1 if the global enable bit in the peer enable register is 0.</p> |
| 30   | tdown  | 0x0   | <p>When set, the channel will commence a RX channel teardown procedure. It will stop on the next FIFO boundary. It then clears the DMA event count and ignores all future DMA events from the peripheral.</p> <p>After stopping peripheral reads, the PDMA sends a teardown message to the UDMA-P that also closes the current packet with an EOP. If no packet is open at the time of the teardown, the message also includes SOP. The EOP teardown message may or may not contain final packet data.</p> <p>Once the channel teardown is complete and ready to be reused, the enable bit is cleared.</p>                                                                                                                              |
| 29   | pause  | 0x0   | <p>When set, the channel is in a paused state. It will stop on the next FIFO boundary. It continues to accept and count DMA events from the peripherals, but will not act on them. The pause bit can be cleared and data will resume. Pause will not stop teardown from completing.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 28:2 | -      | 0x0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1    | idle   | 0x0   | <p>This is a read-only bit that signifies that the Paused or Disabled channel is also idle. This bit is read only and can only become set if pause is set or enable is cleared.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0    | free   | 0x0   | <p>Free Run: 0 = channel honors the emudbg suspend signal, 1 = channel will free run, regardless of the value of emudbg suspend.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 11.3.1.2.5.2.2.2 Source Thread Byte Count Register (PSIL Address 0x404)

| Bits | Field | Reset | Description                                                                                                                                                                                                                                                                                                         |
|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | bytes | 0x0   | <p>This register contains the number of bytes that have been read from the VBUSP mapped peripheral. The register is write to decrement, so running counts can be tracked by reading register and then writing back the value that was read. It will wrap on overflow. It will reset to zero on a channel reset.</p> |

### 11.3.1.2.2.5.2.3 PSI-L Source Thread Pairing

After reset, all threads on PSI-L are uninitialized and unpaired. The Host will pair each source PDMA channel with (typically) a corresponding destination channel in the UDMA-P. The PDMA thread is configured to point to the UDMA-P thread and the UDMA-P thread is configured to point to the PDMA thread. Once paired, the source channels in the PDMA will send all their data to the source channel in the UDMA-P and the destination channel in the UDMA-P will never see any data other than data from the source channel in the PDMA.

### 11.3.1.2.2.5.2.4 Static Transfer Request Setup

After reset, all channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will send configuration transactions across PSI-L and will set up the static TR for each destination channel. The format of the TR is identical for each DMA mode, consisting of an X, Y, and Z parameter, but the field interpretation varies.

#### 11.3.1.2.2.5.2.4.1 X-Y FIFO Mode Static TR

In X-Y FIFO mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the XY burst description for more information.                                                                                                                                                                                                                     |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                              |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, 4 = 64 bits, and 5-7 = RESERVED                                                                                          |
| Y     | 0x400     | 11:0  | Element count. This field specifies how many elements to transfer each time a trigger is received on the channel.                                                                                                                                                                                                          |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                     |
| Z     | 0x401     | 23:0  | FIFO count. This field specifies how many full FIFO operations comprise a complete packet. When the count has been reached, the PDMA will close the packet with an 'EOP' indication. If this parameter is set to NULL, then no packet delineation is supplied by the PDMA and all framing is controlled via the UDMA-P TR. |

#### 11.3.1.2.2.5.2.4.2 MCAN Mode Static TR

In MCAN mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                              |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the MCAN burst description for more information. |
| Acc32 | 0x400     | 30    | Not used                                                                                                 |
| X     | 0x400     | 26:24 | Not used                                                                                                 |

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Y     | 0x400     | 11:0  | Buffer Size. This field specifies how many bytes should be read from an MCAN RX buffer. This field includes the 8 byte MCAN header on the initial packet fragment. A buffer size less than 16 is treated as 16, and a buffer size greater than 72 is treated as 72.                                                                                                                                            |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                                                                                                         |
| Z     | 0x401     | 23:0  | Buffer Count. This field specifies how many MCAN RX buffers should be read before closing the CPPI packet with an 'EOP' indication. When this count is greater than 1, multiple MCAN RX buffers will be read into a single CPPI packet buffer. The 8 byte MCAN header will be skipped on subsequent MCAN buffer reads. Setting this field to NULL will suppress all packet delineation, and should be avoided. |

#### 11.3.1.2.2.5.2.4.3 AASRC Mode Static TR

AASRC mode is similar to X-Y FIFO mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                                                                                                                                                                                                               |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each read which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, and 4-7 = RESERVED                                                                                                                                                                                                                                                                                         |
| Y     | 0x400     | 11:0  | FIFO element count. In AASRC mode, a channel can service multiple FIFOs using a list supplied in its FIFO configuration. This field specifies how many times to service the FIFO list, hence how many elements to transfer from each FIFO, each time a trigger is received on the channel. Note for each loop specified by the value of Y, the entire list is processed. For example, if the FIFO list is 0, 1, 2, 3, and Y is set to 2 loops, the FIFOs are serviced in the order: 0, 1, 2, 3, 0, 1, 2, 3. |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                                                                                                                                                                                                      |
| Z     | 0x401     | 23:0  | FIFO count. This field specifies how many full DMA request operations comprise a complete packet. When the count has been reached, the PDMA will close the packet with an 'EOP' indication. If this parameter is set to NULL, then no packet delineation is supplied by the PDMA and all framing is controlled via the UDMA-P TR.                                                                                                                                                                           |

#### 11.3.1.2.2.5.2.4.4 AASRC RxFifoConfig (PSIL Address 0x405)

This register describes the FIFO list to be processed for this RX channel.

| Bits  | Field       | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | GroupMode   | 0x0   | When set, the channel is in 'Group Mode'. It will look for Group Mode DMA requests, and access the Group Mode FIFOs. When clear, the channel is 'Stream Mode'. It will look for Stream FIFO DMA requests, and access the Stream Mode FIFOs.                                                                                                                                                                                                                                                                 |
| 30    | DmaReqReset | 0x0   | When set, resets any latched DMA request using the DmaReqMask. This bit is self-clearing. It should be used to synchronize the AASRC event status with the PDMA in the event that the AASRC has been previously used and it is not known if the PDMA may have latched, and is holding, previous DMA requests.                                                                                                                                                                                               |
| 23:20 | LastSlot    | 0x0   | This is the index (0-15) of the last slot in the RX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                   |
| 19:16 | FirstSlot   | 0x0   | This is the index (0-15) of the first slot in the RX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                  |
| 15:0  | DmaReqMask  | 0x0   | This field holds a set of flags indicating which AASRC DMA requests must fire in order for this channel to activate.<br>In Steam Mode, these 16 flags correspond to the 16 DMA requests for each RX FIFO. The flags corresponding to all RX FIFOs involved with the channel should be set to 1.<br>In Group Mode, these flags indicate which Group Mode DMA requests must fire. In this case, only bits 3:0 are relevant and only one bit should be set to 1 as a DMA channel only services a single group. |

#### 11.3.1.2.2.5.2.4.5 AASRC RxOrderTable0 (PSIL Address 0x406)

This table is filled with FIFO index values. RX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all RX threads.

| Bits  | Field  | Reset | Description              |
|-------|--------|-------|--------------------------|
| 31:28 | Entry7 | 7     | RX FIFO Index for slot 7 |
| 27:24 | Entry6 | 6     | RX FIFO Index for slot 6 |
| 23:20 | Entry5 | 5     | RX FIFO Index for slot 5 |
| 19:16 | Entry4 | 4     | RX FIFO Index for slot 4 |
| 15:12 | Entry3 | 3     | RX FIFO Index for slot 3 |
| 11:8  | Entry2 | 2     | RX FIFO Index for slot 2 |
| 7:4   | Entry1 | 1     | RX FIFO Index for slot 1 |
| 3:0   | Entry0 | 0     | RX FIFO Index for slot 0 |

#### 11.3.1.2.2.5.2.4.6 AASRC RxOrderTable1 (PSI-L Address 0x407)

This table is filled with FIFO index values. RX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all RX threads.

| Bits  | Field   | Reset | Description               |
|-------|---------|-------|---------------------------|
| 31:28 | Entry15 | 15    | RX FIFO Index for slot 15 |
| 27:24 | Entry14 | 14    | RX FIFO Index for slot 14 |
| 23:20 | Entry13 | 13    | RX FIFO Index for slot 13 |
| 19:16 | Entry12 | 12    | RX FIFO Index for slot 12 |
| 15:12 | Entry11 | 11    | RX FIFO Index for slot 11 |
| 11:8  | Entry10 | 10    | RX FIFO Index for slot 10 |
| 7:4   | Entry9  | 9     | RX FIFO Index for slot 9  |
| 3:0   | Entry8  | 8     | RX FIFO Index for slot 8  |

#### 11.3.1.2.2.5.2.5 PSI-L Source Thread Enables

PSI-L source threads must be enabled in order to process peripheral DMA requests and send data. When disabled, DMA requests are ignored.

Once a thread is paired, the TR has been set up and the enable is asserted, the channel is armed and ready to be triggered to perform the specified set of read transactions.

#### 11.3.1.2.2.5.3 Data Transfer

Packet reception is accomplished within the PDMA by moving data from structures that are located in memory accessible via the VBUSP Memory Interface(s) onto the Receive PSI-L Interface. On the Rx side of the PDMA, these transfers are always reads. Data is read from an attached memory mapped space and packed into the Rx Per Channel Buffer for that channel. At a later time, the data is moved from the Rx Per Channel FIFO to a remote peer DMA entity via the Rx PSI-L interface

The sequences of logical transactions that are performed by the PDMA on the Memory I/F during receive is dependent on the channel type. The following sections describe what will happen for the different channel types.

##### 11.3.1.2.2.5.3.1 X-Y FIFO Mode Channel

The PDMA channel will remain idle until a pulse is detected on the associated input DMA request event pin. Once the pulse is detected, the DMA will sequentially issue a total of 'Y' parameter reads of 'X' parameter bytes from the data\_address specified in the tchan\_info parameter for the channel. Each read that the DMA performs will be a single 'X' element in size (no large bursts). Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The read transfers that are performed will be accomplished as quickly as possible given availability of data in the Rx channelized FIFO and given the arbitration that may occur as a result of other channels also using the same read unit.

##### 11.3.1.2.2.5.3.1.1 X-Y FIFO Burst Mode

The burst mode for XY is designed to allow the PDMA to burst across a FIFO region, while extracting out the 'sample size' from each data phase. So for example, it can read a "burst" of multiple 32-bit words from a McASP, and grab only 24-bits from each data phase.

It uses the same registers as standard XY mode, where X is the encoded sample size, and Y is the number of samples to read/write per DMA request. Setting bit 31 of the XY register enables burst.

The following are the rules for enabling burst mode. Incompatible peripherals do not need to enable burst, or can enable it on RX without enabling it on TX.

- The VBUSP address will increment throughout the burst
- Bursts will be sub-divided to fit into a 64 byte transfer window
- One sample is transferred for every bus data phase

- Cannot burst one byte samples from a 16-bit peripheral on a 32-bit bus
- Cannot burst 64-bit samples on a 32-bit bus (configure for 2 32-bit samples instead)
- PDMA will 'gap' the byte enables on writes as needed

#### 11.3.1.2.2.5.3.2 MCAN Mode Channel

The PDMA channel will remain idle until a pulse is detected on the associated input DMA request event pin. The DMA event pins are mapped from the CAN filter event bits. The event bits determine the channel and one of two CAN buffers to use for the RX operation. This allows the RX buffers on the CAN to be configured in a ping/pong fashion, preventing the loss of CAN packet data. When an event is received, the PDMA will start copying bytes out of the corresponding CAN buffer. The number of bytes copied is equal to the value of the 'Y' parameter in the channel configuration. Once all data has been copied from the buffer, the PDMA transfers ownership of the buffer back to the CAN by writing a CAN register. It then waits for another RX DMA event. The PDMA can copy multiple CAN RX buffers to the same CPPI packet. It will not close out the CPPI packet until it has copied out a number of RX buffers equal to the 'Z' parameter in the channel configuration. On subsequent RX buffer copies, the MCAN will skip the first 8 bytes of the RX buffer, which is the MCAN packet header.

The mapping of MCAN filter events to MCAN channels and buffer is important for properly configuring the DMA. The mapping is defined as follows.

| CAN FE2 | CAN FE1 | CAN FE0 | Description                            |
|---------|---------|---------|----------------------------------------|
| 0       | 0       | 0       | Not used                               |
| 0       | 0       | 1       | Not used                               |
| 0       | 1       | 0       | PDMA CAN channel offset 0, RX buffer 0 |
| 0       | 1       | 1       | PDMA CAN channel offset 0, RX buffer 1 |
| 1       | 0       | 0       | PDMA CAN channel offset 1, RX buffer 2 |
| 1       | 0       | 1       | PDMA CAN channel offset 1, RX buffer 3 |
| 1       | 1       | 0       | PDMA CAN channel offset 2, RX buffer 4 |
| 1       | 1       | 1       | PDMA CAN channel offset 2, RX buffer 5 |

By using two filter entries in the CAN, software can setup a ping/pong buffer for a particular RX packet ID. For example the following two filter entries will setup a ping/pong using RX buffers 0 and 1 for packet ID 5 on CAN RX channel 0:

| Filter Entry | Packet Match ID | Filter Event Bits |
|--------------|-----------------|-------------------|
| 0            | 5               | 0x2               |
| 1            | 5               | 0x3               |

#### 11.3.1.2.2.5.3.2.1 MCAN Burst Mode

Since MCAN buffers are stored in linear memory, the burst mode for MCAN is a simple linear burst across the transfer window. The max burst size is set to the 72 byte size of the MCAN buffer. This will allow a full MCAN packet to be read out as a single burst.

#### 11.3.1.2.2.5.3.3 AASRC Channel

The AASRC channel is controlled primarily via the channel's RxFifoConfig register. This register holds 3 basic pieces of information:

- Whether the channel uses AASRC Stream Mode or Group Mode
- The slot range in the order table used (from designated first slot to designated last slot)
- The AASRC DMA request event(s) that must fire before the channel becomes active

The channel will remain idle until a pulse is detected on ALL associated input DMA request event pins required by the RxFifoConfig setting. The pulses for the individual events are latched and held by the PDMA until they all arrive.

Once the channel activates, it will start reading FIFO index values from the RxOrderTable, starting at the configured 'First Slot' and ending with the 'Last Slot'. The actual FIFO indices used are obtained from the ordering table. For example, say FirstSlot=3 and LastSlot=5. If the first 6 slots of the ordering table were: 0, 2, 4, 6, 8, 10, the FIFOs read for the event would be 6, 8, and 10, because 'slot 3' of the table contains 6, and it would proceed through 'slot 5' of the table which contains 10.

The X and Y registers are still used as they are in a normal X-Y mode. When accessing each FIFO, the setting of X determines the sample byte width read from the FIFO. The value of 'Y' determines how many times the entire FIFO list is processed for each activation of the channel.

Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The read transfers that are performed will be accomplished as quickly as possible given availability of data in the TX channelized FIFO and given the arbitration that may occur as a result of other channels also using the same write unit.

#### 11.3.1.2.2.5.4 Receive PSI-L Interface Transactions

When an entire word has been packed into the Rx Per Channel Buffer for a given channel, a one word data phase transfer will be initiated for that channel/thread on the Rx PSI-L interface and the data will be popped from the Rx Per Channel FIFO. The value sources for the output pins on the PSI-L interface are described in the following table.

| Pin               | Output Value / Source From PDMA                                                                                                                                                                                                       |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| strm_o_req        | This signal is asserted when the PDMA determines that there is at least 1 word of data in its TP-CC output FIFO                                                                                                                       |
| strm_o_sthread_id | Set equal to the TP-CC DMA channel number which is on the interface for this cycle                                                                                                                                                    |
| strm_o_dthread_id | Set equal to the target thread ID value given in the PSI-L pairing configuration registers for this DMA channel                                                                                                                       |
| strm_o_data_type  | Will be set to the proper PSI-L data type. The PDMA can send config response, PSI info word 0, and PSI data word.                                                                                                                     |
| strm_o_wnum       | Set equal to the packing lane for the current word within a contiguous transfer. This value will start at 0 for each new TR and will increment for each subsequent data phase in the TR.                                              |
| strm_o_lastw      | This signal will be asserted coincident with eop.                                                                                                                                                                                     |
| strm_o_xcnt       | The xcnt will be equal to the data path width in bytes.                                                                                                                                                                               |
| strm_o_worden     | The worden will be modulated to indicate which 32-bit words are valid within each control type data phase.                                                                                                                            |
| strm_o_data       | The data will be packed/left justified to comply to the big endian data ordering as required in the PSI-L I/F specification.                                                                                                          |
| strm_o_sop        | This signal is asserted for 1 data phase at the beginning of each new TR or data transfer packet.                                                                                                                                     |
| strm_o_eop        | This signal is asserted for 1 data phase at the end of each TR or data transfer packet.                                                                                                                                               |
| strm_o_sol        | This signal is set to zero unless the EOL bit is set in PSI-L register 0x401, in which case, it is set for 1 data phase at the start of a new set of transactions designated by the count set in the Z field of PSI-L register 0x401. |
| strm_o_eol        | This signal is set to zero unless the EOL bit is set in PSI-L register 0x401, in which case, it is set for 1 data phase at the end of a set of transactions designated by the count set in the Z field of PSI-L register 0x401.       |
| strm_o_priv       | Set to zero.                                                                                                                                                                                                                          |
| strm_o_privid     | Set to zero.                                                                                                                                                                                                                          |
| strm_o_virtid     | Set to zero.                                                                                                                                                                                                                          |
| strm_o_secure     | Set to zero.                                                                                                                                                                                                                          |
| strm_o_interest   | Set to zero.                                                                                                                                                                                                                          |

| Pin           | Output Value / Source From PDMA                                      |
|---------------|----------------------------------------------------------------------|
| strm_o_steady | Always asserted as the PDMA is always able to accept credit returns. |

#### 11.3.1.2.2.5.5 Rx Pause

The Host initiates a channel pause by setting the pause bit in RT enable register. The paused channel can be resumed by clearing the register bit.

#### 11.3.1.2.2.5.6 Rx Teardown

The Host initiates a RX channel teardown by setting the tdown bit in the RT enable register for the target RX channel. The PDMA communicates the teardown state to the UDMA-P through the PSI-L data channel, to ensure that the teardown is not seen by the UDMA-P until all the previous PDMA data for the channel has been flushed.

The PDMA will not stop reading peripheral data until it reaches a FIFO boundary as configured through the 'X' and 'Y' parameters in the static TR. It will always attempt to complete the 'Y' count for the current event being processed. Upon reaching a stopping point, the PDMA will then clear the enable bit in the pairing register, however the teardown bit will remain set. No further packet processing will occur until the Host re-configures the channel. The teardown process will propagate to the UDMA-P and its final status can be checked there.

#### 11.3.1.2.2.5.7 Rx Channel Reset

In the unlikely event that channel synchronization is corrupted, a channel may fail to teardown gracefully. If this occurs, the channel may be reset by clearing the enable bit in the PSI-L enable register. This will cause a local reset of the entire channel, including TR and pairing registers. Note that it does not reset the UDMA-P peer. Resetting the UDMA-P peer is also required before re-initializing and re-pairing the channel.

#### 11.3.1.2.2.5.8 Rx Debug/State Register

The debug/state registers are supplied to give software applications additional information about the PDMA than they would need in regular operation, but which may be useful in debug situations. The registers appear on the PSI-L bus, near the static TR registers. For receive, they are defined as follows.

| Name    | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z*      | 0x402     | 31:16 | This field holds the lower 12 bits of the current Z count for legacy purposes. See register 0x40F below for the full width version of Z.                                                                                                                                                                                                                                             |
| Y       | 0x402     | 15:0  | This field holds the current Y count. In X-Y FIFO mode, this is the number of X sized samples yet to be read from the peripheral for the DMA event being serviced. In MCAN mode, this field holds the next read offset to use when read to the CAN RX buffer.                                                                                                                        |
| InEvent | 0x403     | 31    | When set, the PDMA is in the middle of processing a FIFO event.                                                                                                                                                                                                                                                                                                                      |
| Tdown   | 0x403     | 30    | When set, the PDMA is processing a teardown operation. This bit is set simultaneously with the teardown bit in the source (RX) RT enable register. This bit will clear when the teardown is complete, regardless as to if the teardown bit in the pairing register is cleared or not. The teardown will propagate to the UDMA-P and its full completion status can be checked there. |
| Pause   | 0x403     | 29    | When set, the PDMA is stopped in a paused state. This bit will clear if the channel is un-paused or disabled.                                                                                                                                                                                                                                                                        |
| Space   | 0x403     | 28    | When set, there is a non-zero amount of internal FIFO space available to hold new read data.                                                                                                                                                                                                                                                                                         |
| XSpace  | 0x403     | 27    | When set, there is enough internal FIFO space available to start servicing a peripheral DMA event.                                                                                                                                                                                                                                                                                   |

| Name     | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                     |
|----------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Buffer   | 0x403     | 26    | This is the current RX buffer (0/1) for the current MCAN receive operation.                                                                                                                                                                                                                                                                                                     |
| State    | 0x403     | 23:20 | This code reflects the current state of the PDMA channel, and is specific to the current implementation.                                                                                                                                                                                                                                                                        |
| EventCnt | 0x403     | 19:16 | This field holds the number of backlogged DMA events yet to be serviced.                                                                                                                                                                                                                                                                                                        |
| Z        | 0x40F     | 31:0  | This field holds the full width value of the current Z count. In X-Y FIFO mode, this field holds the 1 based FIFO count of the FIFO being currently read, or the number of FIFO completions when the current operation completes. In MCAN mode, this field holds the zero based buffer index of the buffer currently being read, or the number of previously completed buffers. |

### 11.3.1.3 Functional Description - UART

#### 11.3.1.3.1 Compliance to Standards

The PDMA complies fully to all standards listed in the previous section.

#### 11.3.1.3.2 Functional Operation

The Peripheral DMA is a simple, low cost implementation of the CPPI 5.0 Unified Transfer Controller. The PDMA module is required to be located close to one or more peripherals (both peripherals and PDMA direct connected to the SCR) which require an external DMA for data movement and is architected to reduce cost by using VBUSP interfaces and supporting only the static Transfer Request subset of UTC features which are useful for peripheral type transactions. Multiple source and destination channels are provided within the PDMA which allow multiple simultaneous transfer operations to be ongoing. The DMA controller maintains state information for each of the channels and employs time division multiplexing between channels in order to share the underlying DMA hardware. A scheduler is provided to control the ordering and rate at which this multiplexing occurs. A block diagram of the PDMA Controller is shown below.

#### 11.3.1.3.2.1 Submodule Descriptions

##### 11.3.1.3.2.1.1 Scheduler

The Scheduler block is responsible for monitoring the fullness level of the various FIFOs, monitoring input DMA triggering events, maintaining channel state information, and issuing credits to the Tx and Rx DMA units when it is time to perform each low level read or write operation.

##### 11.3.1.3.2.1.2 Tx Per Channel Buffers

The Tx Per Channel Buffers implement channelized FIFOs for each DMA channel. A single logical data FIFO is provided for each destination DMA channel that is used for buffering payload data that has been pushed into the PDMA from the Tx PSI-L interface. The Tx Per Channel Buffers are always written with full Tx PSI-L wide words (except for EOL/EOP data phases) but are read on byte granularity from the Tx DMA units.

##### 11.3.1.3.2.1.3 Tx DMA Unit

The Tx DMA Unit block implements all of the state machine functionality necessary to implement static TR type UTC destination channels. The Tx DMA unit waits until it is triggered by an incoming dma event and then writes data from the Tx Per Channel Data FIFO associated with the channel to an external memory mapped target via a VBUSP controller interface. The number and width of the writes that are performed is in accordance with the parameters which were programmed via PSI-L into the static TR for the channel.

##### 11.3.1.3.2.1.4 Rx Per Channel Buffers

Rx Per Channel Buffers implement a logical FIFO for each source DMA channel that is used for buffering payload data that has been fetched by the Rx DMA units. The buffers are byte oriented on write so that the data

from the Rx DMA units which may not be full words can be packed properly. The buffers are word oriented on read in accordance with the transport mechanism outlined in the PSI-L Interface specification. Each channel in the Rx DMA controller maps directly onto a thread in the Rx PSI-L interface. The Rx Per Channel Buffer block outputs queue fullness information to the scheduler block which it then uses to determine when it should initiate DMA opportunities to backfill the buffers. The Rx Per Channel Buffer will initiate transfers to the remote paired thread whenever any data is available in each channel buffer and credits are available in the corresponding thread. The block will simultaneously monitor the status of all of the threads and will perform a round robin arbitration between the different threads for the use of the Rx PSI-L interface. Each thread for which the target is indicating it can accept data and which currently has data available in the channel buffer will be included in the arbitration.

#### 11.3.1.3.2.1.5 Rx DMA Unit

The Rx DMA Unit block implements all of the state machine functionality necessary to implement static TR type UTC source channels. The Rx DMA unit waits until it is triggered by an incoming DMA event and then reads data from an external memory mapped source via a VBUSP controller read interface into the Rx Per Channel Data FIFO associated with the channel. The number and width of the writes that are performed is in accordance with the parameters which were programmed via PSI-L into the static TR for the channel.

#### 11.3.1.3.2.2 General Functionality (Applicable to All Functions/Modes)

##### 11.3.1.3.2.2.1 Operational States

At any given time, the PDMA can be in one of three different states, as shown in [Table 11-81](#).

**Table 11-81. Operational States**

| Operational State | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Init              | This is the initial state of the machine during and immediately after reset. During this state, all of the RAMs inside the PDMA will be initialized to known values including the ECC redundant parity bits. While in the init state, the DMA will de-assert all ready signals on all applicable target interfaces and will de-assert all request signals on all applicable controller interfaces. The PDMA will automatically transition out of the init state into the idle state when all of the RAM initialization has been completed. |
| Idle              | Once the PDMA leaves the Init state, it enters the Idle state whenever no outstanding transactions are pending on any of the PDMA interfaces (controller or target). The Idle state is generally a transient state and is used by the PDMA to determine when it is appropriate to allow the SoC power management complex to turn off the clock. For clock stop purposes, the module will only report idle if all DMA channels are disabled using the enable bit in PSIL register 2 for each channel.                                       |
| Active            | The PDMA enters the active state as soon as it issues a transaction or receives a transaction on any interface that uses a split protocol (expects a later response for a request). When all transactions have been accounted for (responses have all been either received or sent) the PDMA transitions to the Idle state.                                                                                                                                                                                                                |

##### 11.3.1.3.2.2.2 Clock Stop

The clock stop interface is a request/acknowledge interface used to coordinate the handshaking of properly stopping the main clock to the IP. Before attempting to perform a clock stop operation, software is required to teardown all active channels (via UDMAP 'real time' registers in the UDMAP, or PSIL register 0x408 in PSIL based peripherals), and after this is complete, also clear the global enable bit for all channels (via PSIL register 0x2 in both the UDMAP and PSIL based peripherals). Attempting a clock stop on the IP without first performing the channel teardowns or clearing of global enable bits will result in IP specific behavior that may be UNDEFINED.

The PDMA will not drive clock stop IDLE or clock stop ACK while the global enable (PSIL register 0x2) is set for any channel.

##### 11.3.1.3.2.2.3 Emulation Control

The emulation control input (susp\_emosusp) and the per channel emulation control 'free' bit allow DMA operation to be suspended on a per channel basis. When the emulation suspend state is entered, the DMA

will stop processing receive and transmit TRs for each channel at the next TR boundary. Any TR currently in reception or transmission will be halted at its next FIFO boundary as configured through the 'X' and 'Y' parameters in the static TR. Emulation control is implemented for compatibility with other peripherals. Each source and destination channel can be configured to either honor the suspend signal, or to 'free run' without regard to suspend. This is controlled via the 'free' bit in the channel Enable Register. Note the real time emulation suspend request signal is not supported.

#### **11.3.1.3.2.2.4 Dynamic Clock Gating**

The PDMA includes up to two mid level clock gates using `ksdw_pm_clkgate()`. One is on the main clock of the PDMA while the other is on the interal `ecc_aggr` (when RAM is used). These clock gates turn off the clock to their corresponding IP under idle conditions, and then turn the clock back on when work is to be done. Detecting work is done via internal state, or activity on the PSIL or DMA triggers. The DMA triggers are thus always monitored, even when the clocking to the rest of the IP is disabled.

The dynamic clock gating can be disabled through an external port called `pwr_disable_nogate`. No additional signaling is needed to support the dynamic clock gate, although the PDMA supports the 'early wake' pins on PSIL and VBUSP.

#### **11.3.1.3.2.3 Events and Flow Control**

The following sections describe the simplified mechanism that is provided on the Peripheral DMA for triggering.

##### **11.3.1.3.2.3.1 Channel Triggering**

Channels must be triggered in order for them to perform work. A local event input bus is provided on the peripheral DMA and each bit in the input bus corresponds to the trigger for the channel with the same channel index as the bit index in the bus (bit 0 triggers channel 0, bit 1 triggers channel 1, etc.). The event inputs for XY mode are triggered either via pulse, or by a clock synchronous rising edge. The counting mode is a design time configuration parameter. In MCAN mode, the inputs are expected to be single cycle pulses, synchronous with the PDMA clock.

- Event signals that are used in pulse mode must be sourced by the same clock as the PDMA.
- Event signals that are used in edge mode must be sourced by pseudo-synchronous sources (and be a slower clock multiple) to the PDMA clock, and they must remain high for at least 1 'slow' clock cycle.

The PDMA provides a 2 bit counter per event input to accommodate startup latency in the channel. (In AASRC mode, the signals are not counted, but latched whenever asserted.)

##### **11.3.1.3.2.3.2 Completion Events**

All transfers on PDMA are split TR in that they have a UDMA-P half and a (static) PDMA half. Completion events are designed to be triggered from the UDMA-P half of the split TR.

##### **11.3.1.3.2.3.3 Channel Types**

Each channel in the Peripheral DMA is configured at design time to be either standard X-Y FIFO mode or MCAN channel. The channel type is configured at design time, and can not be changed by software.

###### **11.3.1.3.2.3.3.1 X-Y FIFO Mode**

Most peripherals which are serviced by the Peripheral DMA follow the pattern of transferring X bytes from a fixed, non-changing address in a loop Y times for each triggering event that is received. The X parameter is typically 1-16 bytes and the Y parameter can be any integer up to 2048. If a peripheral can be serviced by this basic functionality then it is recommended to use this mode for the peripheral.

###### **11.3.1.3.2.3.3.2 MCAN Mode**

The MCANSS subsystem was found to require a few minor differences than standard X-Y mode. First, buffer ownership on transmit is different in that the DMA will start out owning the TX buffer space (instead of waiting for an initial DMA event from the MCAN). There is also a requirement to perform a write of a fixed value to a fixed address after each DMA event is serviced to pass ownership of a buffer back to the MCAN. Finally, MCAN

packet fragmentation requirement to place an 8 byte header on each 64 byte chunk that is transmitted and to remove the header from each 64 byte chunk (other than the first block) that is received.

#### 11.3.1.3.2.3.3.3 AASRC Mode

The AASRC mode of the PDMA is similar to the X-Y mode in that X specifies the sample width, any Y specifies the number of FIFO samples to transfer per DMA request, but in addition to this, a programmable FIFO list is supplied that allows a single PDMA channel to transfer data to multiple FIFOs. The FIFO list specifies which FIFOs to access, and in which order to access them. Both AASRC 'stream' and 'group' modes are supported in terms of DMA signalling and the FIFO memory map. When in AASRC mode, the entire PDMA operates exclusively in this mode. AASRC channels do not share the same PDMA as do XY and MCAN channels.

The following additional details apply to the PDMA in AASRC mode:

##### Main Features:

- Up to 16 independent RX channels and 16 TX channels
  - Each channel represents a different data stream to either the UDMA-P-P or a McASP PDMA
- Each channel can be configured to read or write any of the AASRC FIFOs in any order
- Packing support for 1, 2, 3, and 4 byte samples
  - Can directly talk to a McASP using any McASP data format
  - Packing sample size is fixed for a given channel
- Supports both Group and Stream AASRC signaling and FIFO memory maps
  - There is a single stream/group mode setting for each PDMA channel

##### Additional details:

- Each channel has a 'mask' of which DMA requests must fire to activate the channel
  - In stream mode, the mask specifies all the FIFO DMA requests that must fire
  - In group mode, the mask specifies the one group DMA request that must fire
- Each channel specifies an ordered list of how FIFOs should be accessed
  - All channels use a common list, specifying a range of entry indices within that list. This allows each channel to use a varying number of list elements.
  - The order list can be processed multiple times per DMA request. The number of samples to be transferred per request must match the configured threshold for the DMA request in the AASRC.
- All FIFOs are specified by index only
  - In the TX ordering table, the indices are assumed to be TX FIFOs
  - In the RX ordering table, the indices are assumed to be RX FIFOs
  - If a DMA channel is in 'Group Mode', the PDMA assumes the indices referenced by that channel represent Group Mode FIFOs; otherwise, it assumes Stream Mode FIFOs.
- The PDMA has configured base addressed and inter-FIFO spans such that it can always convert from a FIFO index to the proper Stream or Group mode FIFO address.

#### 11.3.1.3.2.4 Transmit Operation

##### 11.3.1.3.2.4.1 Destination (Tx) Channel Allocation

A total of 7 destination channels are provided within the DMA for concurrent transfers from Tx per channel buffers to the various attached peripherals. Each Tx channel requires a single PSI-L thread. The Tx channels are allocated as shown in [Table 11-82](#).

**Table 11-82. Tx Channel Allocation**

| Tx DMA Channel | Function        | Channel Type | Trigger Mode | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|-----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 8000           | USART 0 Tx Ch 0 | XY           | edge         | 000002800000      | 000000000000       | 000000000000         |
| 8001           | USART 1 Tx Ch 0 | XY           | edge         | 000002810000      | 000000000000       | 000000000000         |
| 8002           | USART 2 Tx Ch 0 | XY           | edge         | 000002820000      | 000000000000       | 000000000000         |
| 8003           | USART 3 Tx Ch 0 | XY           | edge         | 000002830000      | 000000000000       | 000000000000         |
| 8004           | USART 4 Tx Ch 0 | XY           | edge         | 000002840000      | 000000000000       | 000000000000         |

**Table 11-82. Tx Channel Allocation (continued)**

| Tx DMA Channel | Function        | Channel Type | Trigger Mode | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|-----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 8005           | USART 5 Tx Ch 0 | XY           | edge         | 000002850000      | 00000000000000     | 00000000000000       |
| 8006           | USART 6 Tx Ch 0 | XY           | edge         | 000002860000      | 00000000000000     | 00000000000000       |

**11.3.1.3.2.4.2 Destination (Tx) Channel Out of Band Signals**

The following table shows how PSIL signals are handled for destination channels.

**Table 11-83. Tx Channel Out of Band Signals**

| PSI-L Signal | XY/AASRC Mode                                        | MCAN Mode                                            |
|--------------|------------------------------------------------------|------------------------------------------------------|
| sop          | ignored                                              | ignored                                              |
| eop          | ignored                                              | closes current MCAN packet                           |
| sol          | ignored                                              | ignored                                              |
| eol          | ignored                                              | ignored                                              |
| drop         | ignored                                              | ignored                                              |
| pkt_error    | ignored                                              | ignored                                              |
| tdown        | reflect in status, teardown when data marker reached | reflect in status, teardown when data marker reached |

**11.3.1.3.2.4.3 Destination Channel Initialization**

After reset, all threads/channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will need to first pair the channel with a remote data source (normally a UDMA-P channel), set up the static TR for the channel, and enable the thread.

**11.3.1.3.2.4.3.1 PSI-L Destination Thread Pairing Registers**
**11.3.1.3.2.4.3.1.1 Enable Register (PSIL Address 0x002)**

| Bits | Field  | Reset | Description                                                                                                                                                                                                                          |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the RX channel is disabled. When disabled, the channel ignores all credit returns, and will not generate egress data. A one to zero transition on this bit fully resets the channel. |
| 30:0 | -      | 0x0   | Reserved.                                                                                                                                                                                                                            |

**11.3.1.3.2.4.3.1.2 Local Capabilities Register (PSIL Address 0x040)**

| Bits  | Field            | Reset | Description                                                                                                                                       |
|-------|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | -                | 0x0   | Reserved.                                                                                                                                         |
| 28:24 | LocalThreadWidth | 0x2   | Read only element width for the local thread used for pairing purposes. This field is encoded as follows: 0 = 4 bytes, 1 = 8 bytes, 2 = 16 bytes. |
| 23:8  | -                | 0x0   | Reserved.                                                                                                                                         |
| 7:0   | LocalCreditCnt   | 0x7   | Read only local thread free entry count used for pairing purposes.                                                                                |

**11.3.1.3.2.4.3.2 PSI-L Destination Thread Pairing**

After reset, all threads on PSI-L are uninitialized and unpaired. The Host will pair each destination PDMA channel with (typically) a corresponding source channel in the UDMA-P. The PDMA thread is configured to point to the UDMA-P thread and the UDMA-P thread is configured to point to the PDMA thread. Once paired, the source channels in the UDMA-P will send all their data to the destination channel in the PDMA and the

destination channel in the PDMA will never see any data other than data from the source channel in the UDMA-P.

#### 11.3.1.3.2.4.3.3.3 PSI-L Destination Thread Realtime Enable/Count Registers

##### 11.3.1.3.2.4.3.3.1 RT Enable Register (PSIL Address 0x408)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the TX channel is disabled. When disabled, it discards all held data. It clears DMA event counts and ignores all future DMA events from the peripheral. It maintains data exchange with the UDMA-P so that credit handshake is not disrupted. A 'hard teardown' can be performed by directly clearing this bit. Note that this bit cannot be changed from 0 to 1 if the global enable bit in the peer enable register is 0.     |
| 30   | tdown  | 0x0   | When set, the channel will commence a TX channel teardown procedure. To perform a TX teardown, the teardown bit should be set in the UDMA-P and it will automatically propagate to this register bit with the normal flow of peripheral data. Once the channel is fully stopped and ready to be reused (including returning all credits), the enable bit is cleared.                                                                                                            |
| 29   | pause  | 0x0   | When set, the channel is in a paused state. It will stop on the next FIFO boundary. It continues to accept and count DMA events from the peripherals, but will not act on them. The pause bit can be cleared and data will resume.                                                                                                                                                                                                                                              |
| 28   | flush  | 0x0   | When set, causes all TX channel data to be discarded instead of being written to the peripheral. It essentially allows the TX engine to 'free run' without DMA requests from the peripheral (it will also override 'pause'). This bit should be set only when a channel fails to complete its teardown procedure normally, because a peripheral is no longer functioning or because data flow was halted on a boundary that is not compatible with the static TR configuration. |
| 27:3 | -      | 0x0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2    | error  | 0x0   | When set, the channel has encountered a PSIL protocol violation. The error bit can only be set by hardware, and can only be cleared by software. Once this bit is set, the channel should be fully reset and re-initialized via the PSIL pairing registers.                                                                                                                                                                                                                     |
| 1    | idle   | 0x0   | This is a read-only bit that signifies that the disabled channel is also idle. This bit is read only and can only become set if the enable bit in the RT enable register is cleared.                                                                                                                                                                                                                                                                                            |
| 0    | free   | 0x0   | When cleared, the channel honors the emudbg suspend signal. When set, the channel will free run, regardless of the value of emudbg suspend.                                                                                                                                                                                                                                                                                                                                     |

##### 11.3.1.3.2.4.3.3.2 Destination Thread Byte Count Register (PSIL Address 0x404)

| Bits | Field | Reset | Description                                                                                                                                                                                                                                                                                                   |
|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | bytes | 0x0   | This register contains the number of bytes that have been written to the VBUSP mapped peripheral. The register is write to decrement, so running counts can be tracked by reading register and then writing back the value that was read. It will wrap on overflow. It will reset to zero on a channel reset. |

#### 11.3.1.3.2.4.3.4 Static Transfer Request Setup

After reset, all channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will send configuration transactions across PSIL and will set up the static TR for each destination channel. The format of the TR is identical for each DMA mode, consisting of an X, Y, and Z parameter, but the field interpretation varies.

##### 11.3.1.3.2.4.3.4.1 X-Y FIFO Mode Static TR

In X-Y FIFO mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                       |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the XY burst description for more information.                                                                                                                            |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                     |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, 4 = 64 bits, and 5-7 = RESERVED |
| Y     | 0x400     | 11:0  | Element count. This field specifies how many elements to transfer each time a trigger is received on the channel.                                                                                                                 |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                          |

##### 11.3.1.3.2.4.3.4.2 MCAN Mode Static TR

In MCAN mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the MCAN burst description for more information.                                                                                                                                                                                                                                                                                                                                                                                                          |
| Acc32 | 0x400     | 30    | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| X     | 0x400     | 26:24 | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Y     | 0x400     | 11:0  | Buffer Size. This field specifies how many bytes should be written to an MCAN TX buffer. This field includes the 8 byte MCAN header on the initial packet fragment. The PDMA will break up the source packet into fragments of this buffer size, copying the 8 byte MCAN header for the initial fragment, and then skipping it for each additional fragment and thus reusing the header from the first fragment. A buffer size less than 16 is treated as 16, and a buffer size greater than 72 is treated as 72. |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

##### 11.3.1.3.2.4.3.4.3 AASRC Mode Static TR

AASRC mode is similar to X-Y FIFO mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description |
|-------|-----------|-------|-------------|
| Burst | 0x400     | 31    | Not used    |

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                                                                                                                                                                                                             |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, and 4-7 = RESERVED                                                                                                                                                                                                                                                                                      |
| Y     | 0x400     | 11:0  | FIFO element count. In AASRC mode, a channel can service multiple FIFOs using a list supplied in its FIFO configuration. This field specifies how many times to service the FIFO list, hence how many elements to transfer to each FIFO, each time a trigger is received on the channel. Note for each loop specified by the value of Y, the entire list is processed. For example, if the FIFO list is 0, 1, 2, 3, and Y is set to 2 loops, the FIFOs are serviced in the order: 0, 1, 2, 3, 0, 1, 2, 3. |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### 11.3.1.3.2.4.3.4.4 AASRC TxFifoConfig (PSIL Address 0x405)

This register describes the FIFO list to be processed for this TX channel.

| Bits  | Field       | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | GroupMode   | 0x0   | When set, the channel is in 'Group Mode'. It will look for Group Mode DMA requests, and access the Group Mode FIFOs. When clear, the channel is 'Stream Mode'. It will look for Stream FIFO DMA requests, and access the Stream Mode FIFOs.                                                                                                                                                                                                                                                                         |
| 30    | DmaReqReset | 0x0   | When set, resets any latched DMA request using the DmaReqMask. This bit is self-clearing. It should be used to synchronize the AASRC event status with the PDMA in the event that the AASRC has been previously used and it is not known if the PDMA may have latched, and is holding, previous DMA requests.                                                                                                                                                                                                       |
| 23:20 | LastSlot    | 0x0   | This is the index (0-15) of the last slot in the TX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                           |
| 19:16 | FirstSlot   | 0x0   | This is the index (0-15) of the first slot in the TX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                          |
| 15:0  | DmaReqMask  | 0x0   | This field holds a set of flags indicating which AASRC DMA requests must fire in order for this channel to activate.<br><br>In Steam Mode, these 16 flags correspond to the 16 DMA requests for each TX FIFO. The flags corresponding to all TX FIFOs involved with the channel should be set to 1.<br><br>In Group Mode, these flags indicate which Group Mode DMA requests must fire. In this case, only bits 3:0 are relevant and only one bit should be set to 1 as a DMA channel only services a single group. |

#### 11.3.1.3.2.4.3.4.5 AASRC TxOrderTable0 (PSIL Address 0x406)

This table is filled with FIFO index values. TX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all TX threads.

| Bits  | Field  | Reset | Description              |
|-------|--------|-------|--------------------------|
| 31:28 | Entry7 | 7     | TX FIFO Index for slot 7 |
| 27:24 | Entry6 | 6     | TX FIFO Index for slot 6 |
| 23:20 | Entry5 | 5     | TX FIFO Index for slot 5 |
| 19:16 | Entry4 | 4     | TX FIFO Index for slot 4 |
| 15:12 | Entry3 | 3     | TX FIFO Index for slot 3 |
| 11:8  | Entry2 | 2     | TX FIFO Index for slot 2 |
| 7:4   | Entry1 | 1     | TX FIFO Index for slot 1 |
| 3:0   | Entry0 | 0     | TX FIFO Index for slot 0 |

#### 11.3.1.3.2.4.3.4.6 AASRC TxOrderTable1 (PSIL Address 0x407)

This table is filled with FIFO index values. TX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all TX threads.

| Bits  | Field   | Reset | Description               |
|-------|---------|-------|---------------------------|
| 31:28 | Entry15 | 15    | TX FIFO Index for slot 15 |
| 27:24 | Entry14 | 14    | TX FIFO Index for slot 14 |
| 23:20 | Entry13 | 13    | TX FIFO Index for slot 13 |
| 19:16 | Entry12 | 12    | TX FIFO Index for slot 12 |
| 15:12 | Entry11 | 11    | TX FIFO Index for slot 11 |
| 11:8  | Entry10 | 10    | TX FIFO Index for slot 10 |
| 7:4   | Entry9  | 9     | TX FIFO Index for slot 9  |
| 3:0   | Entry8  | 8     | TX FIFO Index for slot 8  |

#### 11.3.1.3.2.4.3.5 PSI-L Destination Thread Enables

PSI-L destination threads must first be enabled in order to accept data. Threads are enabled or disabled by setting or clearing the enable bit in the PSI-L pairing registers for the thread. When a thread is disabled, it must drop any data phases which are sent but properly return the credits for the data phases which are dropped.

Once a thread is paired, the TR has been set up and the enable is asserted, the channel is armed and ready to be triggered to perform the specified set of write transactions.

#### 11.3.1.3.2.4.4 Data Transfer

Packet reception is accomplished within the PDMA by moving data from structures that are located in memory accessible via the VBUSP Memory Interface(s) onto the Receive PSI-L Interface. On the Rx side of the PDMA, these transfers are always reads. Data is read from an attached memory mapped space and packed into the Rx Per Channel Buffer for that channel. At a later time, the data is moved from the Rx Per Channel FIFO to a remote peer DMA entity via the Rx PSI-L interface

The sequences of logical transactions that are performed by the PDMA on the Memory I/F during receive is dependent on the channel type. The following sections describe what will happen for the different channel types.

##### 11.3.1.3.2.4.4.1 X-Y FIFO Mode Channel

The PDMA channel will remain idle until a pulse is detected on the associated input DMA request event pin. Once the pulse is detected, the DMA will sequentially issue a total of 'Y' parameter reads of 'X' parameter bytes from the data\_address specified in the tchan\_info parameter for the channel. Each read that the DMA performs

will be a single 'X' element in size (no large bursts). Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The read transfers that are performed will be accomplished as quickly as possible given availability of data in the Rx channelized FIFO and given the arbitration that may occur as a result of other channels also using the same read unit.

#### 11.3.1.3.2.4.4.1.1 X-Y FIFO Burst Mode

The burst mode for XY is designed to allow the PDMA to burst across a FIFO region, while extracting out the 'sample size' from each data phase. So for example, it can read a "burst" of multiple 32-bit words from a McASP, and grab only 24-bits from each data phase.

It uses the same registers as standard XY mode, where X is the encoded sample size, and Y is the number of samples to read/write per DMA request. Setting bit 31 of the XY register enables burst.

The following are the rules for enabling burst mode. Incompatible peripherals do not need to enable burst, or can enable it on RX without enabling it on TX.

- The VBUSP address will increment throughout the burst
- Bursts will be sub-divided to fit into a 64 byte transfer window
- One sample is transferred for every bus data phase
  - Cannot burst one byte samples from a 16-bit peripheral on a 32-bit bus
  - Cannot burst 64-bit samples on a 32-bit bus (configure for 2 32-bit samples instead)
- PDMA will 'gap' the byte enables on writes as needed

#### 11.3.1.3.2.4.4.2 MCAN Mode Channel

The PDMA channel will remain idle until a pulse is detected on the associated input DMA request event pin. The DMA event pins are mapped from the CAN filter event bits. The event bits determine the channel and one of two CAN buffers to use for the RX operation. This allows the RX buffers on the CAN to be configured in a ping/pong fashion, preventing the loss of CAN packet data. When an event is received, the PDMA will start copying bytes out of the corresponding CAN buffer. The number of bytes copied is equal to the value of the 'Y' parameter in the channel configuration. Once all data has been copied from the buffer, the PDMA transfers ownership of the buffer back to the CAN by writing a CAN register. It then waits for another RX DMA event. The PDMA can copy multiple CAN RX buffers to the same CPPI packet. It will not close out the CPPI packet until it has copied out a number of RX buffers equal to the 'Z' parameter in the channel configuration. On subsequent RX buffer copies, the MCAN will skip the first 8 bytes of the RX buffer, which is the MCAN packet header.

The mapping of MCAN filter events to MCAN channels and buffer is important for properly configuring the DMA. The mapping is defined as follows.

| CAN FE2 | CAN FE1 | CAN FE0 | Description                            |
|---------|---------|---------|----------------------------------------|
| 0       | 0       | 0       | Not used                               |
| 0       | 0       | 1       | Not used                               |
| 0       | 1       | 0       | PDMA CAN channel offset 0, RX buffer 0 |
| 0       | 1       | 1       | PDMA CAN channel offset 0, RX buffer 1 |
| 1       | 0       | 0       | PDMA CAN channel offset 1, RX buffer 2 |
| 1       | 0       | 1       | PDMA CAN channel offset 1, RX buffer 3 |
| 1       | 1       | 0       | PDMA CAN channel offset 2, RX buffer 4 |
| 1       | 1       | 1       | PDMA CAN channel offset 2, RX buffer 5 |

By using two filter entries in the CAN, software can setup a ping/pong buffer for a particular RX packet ID. For example the following two filter entries will setup a ping/pong using RX buffers 0 and 1 for packet ID 5 on CAN RX channel 0:

| Filter Entry | Packet Match ID | Filter Event Bits |
|--------------|-----------------|-------------------|
| 0            | 5               | 0x2               |

| Filter Entry | Packet Match ID | Filter Event Bits |
|--------------|-----------------|-------------------|
| 1            | 5               | 0x3               |

#### 11.3.1.3.2.4.4.2.1 MCAN Burst Mode

Since MCAN buffers are stored in linear memory, the burst mode for MCAN is a simple linear burst across the transfer window. The max burst size is set to the 72 byte size of the MCAN buffer. This will allow a full MCAN packet to be read out as a single burst.

#### 11.3.1.3.2.4.4.3 AASRC Channel

The AASRC channel is controlled primarily via the channel's RxFifoConfig register. This register holds 3 basic pieces of information:

- Whether the channel uses AASRC Stream Mode or Group Mode
- The slot range in the order table used (from designated first slot to designated last slot)
- The AASRC DMA request event(s) that must fire before the channel becomes active

The channel will remain idle until a pulse is detected on ALL associated input DMA request event pins required by the RxFifoConfig setting. The pulses for the individual events are latched and held by the PDMA until they all arrive.

Once the channel activates, it will start reading FIFO index values from the RxOrderTable, starting at the configured 'First Slot' and ending with the 'Last Slot'. The actual FIFO indices used are obtained from the ordering table. For example, say FirstSlot=3 and LastSlot=5. If the first 6 slots of the ordering table were: 0, 2, 4, 6, 8, 10, the FIFOs read for the event would be 6, 8, and 10, because 'slot 3' of the table contains 6, and it would proceed through 'slot 5' of the table which contains 10.

The X and Y registers are still used as they are in a normal X-Y mode. When accessing each FIFO, the setting of X determines the sample byte width read from the FIFO. The value of 'Y' determines how many times the entire FIFO list is processed for each activation of the channel.

Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The read transfers that are performed will be accomplished as quickly as possible given availability of data in the TX channelized FIFO and given the arbitration that may occur as a result of other channels also using the same write unit.

#### 11.3.1.3.2.4.5 Transmit PSI-L Interface Transactions

The PDMA will accept data across the Tx PSI-L Interface in accordance with the physical handshaking protocol as defined in the PSI-L Interface specification. The value sources for the output pins on the PSI-L interface are described in the following table.

| Pin              | Output Value / Source From PDMA                                                                    |
|------------------|----------------------------------------------------------------------------------------------------|
| strm_i_link      | This signal is asserted high to indicate the PSI-L link is valid.                                  |
| strm_i_ready     | This signal is asserted high anytime there is space in the PSI-L ingress fifo.                     |
| strm_i_sreq      | This signal is asserted high anytime there is credit return data waiting in the PSI-L status fifo. |
| strm_i_sthreadid | This is set to the local destination thread that is returning credit.                              |
| strm_i_sccnt     | This is set to the number of credits being returned, or 0 on a TX teardown acknowledgement.        |

#### 11.3.1.3.2.4.6 Tx Pause

The Host initiates a channel pause by setting the pause bit in the RT enable register. The paused channel can be resumed by clearing the register bit.

#### 11.3.1.3.2.4.7 Tx Teardown

The Host initiates a channel teardown by setting the tdown bit in the UDMA-P channel that is paired with the PDMA. The UDMA-P communicates the teardown state through the PSI-L data channel, to ensure that the

teardown is not seen by the PDMA until all the previous UDMA-P data for the channel has been flushed. At this time, the teardown state will be reflected in the PSI-L RT Enable register of the PDMA. Note that a non-synchronized teardown can also be initiated by directly clearing the enable bit in the PSI-L RT Enable register of the PDMA.

Once all data has been flushed from the PDMA to the peripheral, the enable state of the PDMA channel will be cleared in the PSI-L RT enable register, but the teardown bit will remain high. A teardown completion indication is sent back across the status pins of the PSI-L in the form of a credit response with sccnt=0. Upon completion, no further packet processing will occur until the Host re-configures the channel. If the channel fails to teardown because the peripheral has stopped responding, or if the UDMA-P transmission stops on a data boundary that is not compatible with the static TR configuration, the flush bit in the RT enable register can be set to guarantee that all data can be properly flushed from the internal pipe.

#### 11.3.1.3.2.4.8 Tx Channel Reset

In the unlikely event that channel synchronization is corrupted, a channel may fail to teardown gracefully, even with flush enabled. If this occurs, the channel may be reset by clearing the enable bit in the PSI-L Enable register. This will cause a local reset of the entire channel, including TR and pairing registers. Note that it does not reset the UDMA-P peer. Resetting the UDMA-P peer is also required before re-initializing and re-pairing the channel.

#### 11.3.1.3.2.4.9 Tx Debug/State Register

The debug/state registers are supplied to give software applications additional information about the PDMA than they would need in regular operation, but which may be useful in debug situations. The registers appear on the PSI-L bus, near the static TR registers. For transmit, they are defined as in the following table.

| Name     | PSI-L Addr | Field | Description                                                                                                                                                                                                                                                   |
|----------|------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Y        | 0x402      | 15:0  | This field holds the current Y count. In X-Y FIFO mode, this is the number of X sized samples yet to write to the peripheral for the DMA event being serviced. In MCAN mode, this field holds the next write offset to use when writing to the CAN TX buffer. |
| InEvent  | 0x403      | 31    | When set, the PDMA is in the middle of processing a FIFO event.                                                                                                                                                                                               |
| Flush    | 0x403      | 30    | When set, the PDMA is processing in a flushing state, where it runs without waiting for DMA requests and without writing data to the peripheral. It is only operating its internal state machine to allow internal data pipes to drain properly.              |
| Pause    | 0x403      | 29    | When set, the PDMA waiting in a paused state. This bit will clear when data starts flowing again from the UDMA-P.                                                                                                                                             |
| Data     | 0x403      | 28    | When set, there is a non-zero amount of data still waiting to be written to the peripheral.                                                                                                                                                                   |
| XData    | 0x403      | 27    | When set, there is enough data still waiting to be written to the peripheral to start servicing a peripheral DMA event.                                                                                                                                       |
| State    | 0x403      | 23:20 | This code reflects the current state of the PDMA channel, and is specific to the current implementation.                                                                                                                                                      |
| EventCnt | 0x403      | 19:16 | This field holds the number of backlogged DMA events yet to be serviced.                                                                                                                                                                                      |

#### 11.3.1.3.2.5 Receive Operation

#### 11.3.1.3.2.5.1 Source (Rx) Channel Allocation

A total of 7 source channels are provided within the DMA for concurrent transfers from the various attached peripherals into the Rx per channel buffers and on to the PSI-L Rx Interface. Each Rx channel requires a single PSI-L thread. The Rx channels are allocated as shown in [Table 11-84](#).

**Table 11-84. Rx Channel Allocation**

| Rx DMA Channel | Function        | Channel Type | Trigger Type | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|-----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 0              | USART 0 Rx Ch 0 | XY           | edge         | 000002800000      | 00000000000000     | 00000000000000       |
| 1              | USART 1 Rx Ch 0 | XY           | edge         | 000002810000      | 00000000000000     | 00000000000000       |
| 2              | USART 2 Rx Ch 0 | XY           | edge         | 000002820000      | 00000000000000     | 00000000000000       |
| 3              | USART 3 Rx Ch 0 | XY           | edge         | 000002830000      | 00000000000000     | 00000000000000       |
| 4              | USART 4 Rx Ch 0 | XY           | edge         | 000002840000      | 00000000000000     | 00000000000000       |
| 5              | USART 5 Rx Ch 0 | XY           | edge         | 000002850000      | 00000000000000     | 00000000000000       |
| 6              | USART 6 Rx Ch 0 | XY           | edge         | 000002860000      | 00000000000000     | 00000000000000       |

#### 11.3.1.3.2.5.2 Source Channel Initialization

After reset, all threads/channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will need to first pair the channel with a remote data source (normally a UDMA-P channel), set up the static TR for the channel, and enable the thread.

#### 11.3.1.3.2.5.2.1 PSI-L Source Thread Pairing Registers

##### 11.3.1.3.2.5.2.1.1 Peer Thread ID Register (PSIL Address 0x000)

| Bits  | Field           | Reset | Description                                                                                                                                       |
|-------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | ThreadPriority  | 0x0   | This field is hard coded to 0x0 and is not writable                                                                                               |
| 28:24 | PeerThreadWidth | 0x0   | Datapath width of paired peer destination thread. This field is encoded as follows: 0 = 32-bit, 1 = 64-bit, 2 = 128 bit, 3 = 256 bit, 4 = 512 bit |
| 23:16 | -               | 0x0   | Reserved.                                                                                                                                         |
| 15:0  | Peer ThreadID   | 0x0   | Thread ID to which all non-Transfer Response, non-Config messages from this thread will be sent.                                                  |

##### 11.3.1.3.2.5.2.1.2 Peer Credit Register (PSIL Address 0x001)

| Bits | Field     | Reset | Description                                                                       |
|------|-----------|-------|-----------------------------------------------------------------------------------|
| 31:8 | -         | 0x0   | Reserved.                                                                         |
| 7:0  | CreditCnt | 0x0   | Free entries in destination thread. Legal range is 0 - 128 in number of elements. |

##### 11.3.1.3.2.5.2.1.3 Enable Register (PSIL Address 0x002)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                          |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the RX channel is disabled. When disabled, the channel ignores all credit returns, and will not generate egress data. A one to zero transition on this bit fully resets the channel. |
| 30:0 | -      | 0x0   | Reserved.                                                                                                                                                                                                                            |

### 11.3.1.3.2.5.2.2 PSI-L Source Thread Realtime Enable/Count Registers

#### 11.3.1.3.2.5.2.2.1 RT Enable Register (PSIL Address 0x408)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | <p>When set, the channel is enabled. When cleared, the RX channel is disabled. When disabled, the channel ignores all DMA events from the peripheral. It maintains proper data transfers with the UDMA-P such that the credit handshake is not disrupted. However, unlike teardown, it does not close out the current open packet. Thus the teardown bit should always be used to disable an RX channel instead of manually clearing this bit. Failing to use teardown may result in stale data remaining in the internal RX FIFO, which would also prevent the channel from going idle without a channel reset.</p> <p>Note that this bit cannot be changed from 0 to 1 if the global enable bit in the peer enable register is 0.</p> |
| 30   | tdown  | 0x0   | <p>When set, the channel will commence a RX channel teardown procedure. It will stop on the next FIFO boundary. It then clears the DMA event count and ignores all future DMA events from the peripheral.</p> <p>After stopping peripheral reads, the PDMA sends a teardown message to the UDMA-P that also closes the current packet with an EOP. If no packet is open at the time of the teardown, the message also includes SOP. The EOP teardown message may or may not contain final packet data.</p> <p>Once the channel teardown is complete and ready to be reused, the enable bit is cleared.</p>                                                                                                                              |
| 29   | pause  | 0x0   | <p>When set, the channel is in a paused state. It will stop on the next FIFO boundary. It continues to accept and count DMA events from the peripherals, but will not act on them. The pause bit can be cleared and data will resume. Pause will not stop teardown from completing.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 28:2 | -      | 0x0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1    | idle   | 0x0   | This is a read-only bit that signifies that the Paused or Disabled channel is also idle. This bit is read only and can only become set if pause is set or enable is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0    | free   | 0x0   | Free Run: 0 = channel honors the emudbg suspend signal, 1 = channel will free run, regardless of the value of emudbg suspend.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 11.3.1.3.2.5.2.2.2 Source Thread Byte Count Register (PSIL Address 0x404)

| Bits | Field | Reset | Description                                                                                                                                                                                                                                                                                                  |
|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | bytes | 0x0   | This register contains the number of bytes that have been read from the VBUSP mapped peripheral. The register is write to decrement, so running counts can be tracked by reading register and then writing back the value that was read. It will wrap on overflow. It will reset to zero on a channel reset. |

#### 11.3.1.3.2.5.2.3 PSI-L Source Thread Pairing

After reset, all threads on PSI-L are uninitialized and unpaired. The Host will pair each source PDMA channel with (typically) a corresponding destination channel in the UDMA-P. The PDMA thread is configured to point to the UDMA-P thread and the UDMA-P thread is configured to point to the PDMA thread. Once paired, the source channels in the PDMA will send all their data to the source channel in the UDMA-P and the destination channel in the UDMA-P will never see any data other than data from the source channel in the PDMA.

#### 11.3.1.3.2.5.2.4 Static Transfer Request Setup

After reset, all channels in the PDMA will be idle and waiting for work to be assigned to them. In order to initiate PDMA operation, the Host will send configuration transactions across PSI-L and will set up the static TR for each destination channel. The format of the TR is identical for each DMA mode, consisting of an X, Y, and Z parameter, but the field interpretation varies.

##### 11.3.1.3.2.5.2.4.1 X-Y FIFO Mode Static TR

In X-Y FIFO mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the XY burst description for more information.                                                                                                                                                                                                                     |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                              |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, 4 = 64 bits, and 5-7 = RESERVED                                                                                          |
| Y     | 0x400     | 11:0  | Element count. This field specifies how many elements to transfer each time a trigger is received on the channel.                                                                                                                                                                                                          |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                     |
| Z     | 0x401     | 23:0  | FIFO count. This field specifies how many full FIFO operations comprise a complete packet. When the count has been reached, the PDMA will close the packet with an 'EOP' indication. If this parameter is set to NULL, then no packet delineation is supplied by the PDMA and all framing is controlled via the UDMA-P TR. |

##### 11.3.1.3.2.5.2.4.2 MCAN Mode Static TR

In MCAN mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the MCAN burst description for more information.                                                                                                                                                                                                                                                                                                       |
| Acc32 | 0x400     | 30    | Not used                                                                                                                                                                                                                                                                                                                                                                                                       |
| X     | 0x400     | 26:24 | Not used                                                                                                                                                                                                                                                                                                                                                                                                       |
| Y     | 0x400     | 11:0  | Buffer Size. This field specifies how many bytes should be read from an MCAN RX buffer. This field includes the 8 byte MCAN header on the initial packet fragment. A buffer size less than 16 is treated as 16, and a buffer size greater than 72 is treated as 72.                                                                                                                                            |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                                                                                                         |
| Z     | 0x401     | 23:0  | Buffer Count. This field specifies how many MCAN RX buffers should be read before closing the CPPI packet with an 'EOP' indication. When this count is greater than 1, multiple MCAN RX buffers will be read into a single CPPI packet buffer. The 8 byte MCAN header will be skipped on subsequent MCAN buffer reads. Setting this field to NULL will suppress all packet delineation, and should be avoided. |

#### 11.3.1.3.2.5.2.4.3 AASRC Mode Static TR

AASRC mode is similar to X-Y FIFO mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                                                                                                                                                                                                               |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each read which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, and 4-7 = RESERVED                                                                                                                                                                                                                                                                                         |
| Y     | 0x400     | 11:0  | FIFO element count. In AASRC mode, a channel can service multiple FIFOs using a list supplied in its FIFO configuration. This field specifies how many times to service the FIFO list, hence how many elements to transfer from each FIFO, each time a trigger is received on the channel. Note for each loop specified by the value of Y, the entire list is processed. For example, if the FIFO list is 0, 1, 2, 3, and Y is set to 2 loops, the FIFOs are serviced in the order: 0, 1, 2, 3, 0, 1, 2, 3. |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                                                                                                                                                                                                      |

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                       |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z     | 0x401     | 23:0  | FIFO count. This field specifies how many full DMA request operations comprise a complete packet. When the count has been reached, the PDMA will close the packet with an 'EOP' indication. If this parameter is set to NULL, then no packet delineation is supplied by the PDMA and all framing is controlled via the UDMA-P TR. |

#### 11.3.1.3.2.5.2.4.4 AASRC RxFifoConfig (PSIL Address 0x405)

This register describes the FIFO list to be processed for this RX channel.

| Bits  | Field       | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | GroupMode   | 0x0   | When set, the channel is in 'Group Mode'. It will look for Group Mode DMA requests, and access the Group Mode FIFOs. When clear, the channel is 'Stream Mode'. It will look for Stream FIFO DMA requests, and access the Stream Mode FIFOs.                                                                                                                                                                                                                                                                  |
| 30    | DmaReqReset | 0x0   | When set, resets any latched DMA request using the DmaReqMask. This bit is self-clearing. It should be used to synchronize the AASRC event status with the PDMA in the event that the AASRC has been previously used and it is not known if the PDMA may have latched, and is holding, previous DMA requests.                                                                                                                                                                                                |
| 23:20 | LastSlot    | 0x0   | This is the index (0-15) of the last slot in the RX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                    |
| 19:16 | FirstSlot   | 0x0   | This is the index (0-15) of the first slot in the RX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                                   |
| 15:0  | DmaReqMask  | 0x0   | This field holds a set of flags indicating which AASRC DMA requests must fire in order for this channel to activate.<br>In Stream Mode, these 16 flags correspond to the 16 DMA requests for each RX FIFO. The flags corresponding to all RX FIFOs involved with the channel should be set to 1.<br>In Group Mode, these flags indicate which Group Mode DMA requests must fire. In this case, only bits 3:0 are relevant and only one bit should be set to 1 as a DMA channel only services a single group. |

#### 11.3.1.3.2.5.2.4.5 AASRC RxOrderTable0 (PSIL Address 0x406)

This table is filled with FIFO index values. RX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all RX threads.

| Bits  | Field  | Reset | Description              |
|-------|--------|-------|--------------------------|
| 31:28 | Entry7 | 7     | RX FIFO Index for slot 7 |
| 27:24 | Entry6 | 6     | RX FIFO Index for slot 6 |
| 23:20 | Entry5 | 5     | RX FIFO Index for slot 5 |

| Bits  | Field  | Reset | Description              |
|-------|--------|-------|--------------------------|
| 19:16 | Entry4 | 4     | RX FIFO Index for slot 4 |
| 15:12 | Entry3 | 3     | RX FIFO Index for slot 3 |
| 11:8  | Entry2 | 2     | RX FIFO Index for slot 2 |
| 7:4   | Entry1 | 1     | RX FIFO Index for slot 1 |
| 3:0   | Entry0 | 0     | RX FIFO Index for slot 0 |

#### 11.3.1.3.2.5.2.4.6 AASRC RxOrderTable1 (PSIL Address 0x407)

This table is filled with FIFO index values. RX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all RX threads.

| Bits  | Field   | Reset | Description               |
|-------|---------|-------|---------------------------|
| 31:28 | Entry15 | 15    | RX FIFO Index for slot 15 |
| 27:24 | Entry14 | 14    | RX FIFO Index for slot 14 |
| 23:20 | Entry13 | 13    | RX FIFO Index for slot 13 |
| 19:16 | Entry12 | 12    | RX FIFO Index for slot 12 |
| 15:12 | Entry11 | 11    | RX FIFO Index for slot 11 |
| 11:8  | Entry10 | 10    | RX FIFO Index for slot 10 |
| 7:4   | Entry9  | 9     | RX FIFO Index for slot 9  |
| 3:0   | Entry8  | 8     | RX FIFO Index for slot 8  |

#### 11.3.1.3.2.5.2.5 PSI-L Source Thread Enables

PSI-L source threads must be enabled in order to process peripheral DMA requests and send data. When disabled, DMA requests are ignored.

Once a thread is paired, the TR has been set up and the enable is asserted, the channel is armed and ready to be triggered to perform the specified set of read transactions.

#### 11.3.1.3.2.5.3 Data Transfer

Packet reception is accomplished within the PDMA by moving data from structures that are located in memory accessible via the VBUSP Memory Interface(s) onto the Receive PSI-L Interface. On the Rx side of the PDMA, these transfers are always reads. Data is read from an attached memory mapped space and packed into the Rx Per Channel Buffer for that channel. At a later time, the data is moved from the Rx Per Channel FIFO to a remote peer DMA entity via the Rx PSI-L interface

The sequences of logical transactions that are performed by the PDMA on the Memory I/F during receive is dependent on the channel type. The following sections describe what will happen for the different channel types.

##### 11.3.1.3.2.5.3.1 X-Y FIFO Mode Channel

The PDMA channel will remain idle until a pulse is detected on the associated input DMA request event pin. Once the pulse is detected, the DMA will sequentially issue a total of 'Y' parameter reads of 'X' parameter bytes from the data\_address specified in the tchan\_info parameter for the channel. Each read that the DMA performs will be a single 'X' element in size (no large bursts). Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The read transfers that are performed will be accomplished as quickly as possible given availability of data in the Rx channelized FIFO and given the arbitration that may occur as a result of other channels also using the same read unit.

###### 11.3.1.3.2.5.3.1.1 X-Y FIFO Burst Mode

The burst mode for XY is designed to allow the PDMA to burst across a FIFO region, while extracting out the 'sample size' from each data phase. So for example, it can read a "burst" of multiple 32-bit words from a McASP, and grab only 24-bits from each data phase.

It uses the same registers as standard XY mode, where X is the encoded sample size, and Y is the number of samples to read/write per DMA request. Setting bit 31 of the XY register enables burst.

The following are the rules for enabling burst mode. Incompatible peripherals do not need to enable burst, or can enable it on RX without enabling it on TX.

- The VBUSP address will increment throughout the burst
- Bursts will be sub-divided to fit into a 64 byte transfer window
- One sample is transferred for every bus data phase
  - Cannot burst one byte samples from a 16-bit peripheral on a 32-bit bus
  - Cannot burst 64-bit samples on a 32-bit bus (configure for 2 32-bit samples instead)
- PDMA will 'gap' the byte enables on writes as needed

#### 11.3.1.3.2.5.3.2 MCAN Mode Channel

The PDMA channel will remain idle until a pulse is detected on the associated input DMA request event pin. The DMA event pins are mapped from the CAN filter event bits. The event bits determine the channel and one of two CAN buffers to use for the RX operation. This allows the RX buffers on the CAN to be configured in a ping/pong fashion, preventing the loss of CAN packet data. When an event is received, the PDMA will start copying bytes out of the corresponding CAN buffer. The number of bytes copied is equal to the value of the 'Y' parameter in the channel configuration. Once all data has been copied from the buffer, the PDMA transfers ownership of the buffer back to the CAN by writing a CAN register. It then waits for another RX DMA event. The PDMA can copy multiple CAN RX buffers to the same CPPI packet. It will not close out the CPPI packet until it has copied out a number of RX buffers equal to the 'Z' parameter in the channel configuration. On subsequent RX buffer copies, the MCAN will skip the first 8 bytes of the RX buffer, which is the MCAN packet header.

The mapping of MCAN filter events to MCAN channels and buffer is important for properly configuring the DMA. The mapping is defined as follows.

| CAN FE2 | CAN FE1 | CAN FE0 | Description                            |
|---------|---------|---------|----------------------------------------|
| 0       | 0       | 0       | Not used                               |
| 0       | 0       | 1       | Not used                               |
| 0       | 1       | 0       | PDMA CAN channel offset 0, RX buffer 0 |
| 0       | 1       | 1       | PDMA CAN channel offset 0, RX buffer 1 |
| 1       | 0       | 0       | PDMA CAN channel offset 1, RX buffer 2 |
| 1       | 0       | 1       | PDMA CAN channel offset 1, RX buffer 3 |
| 1       | 1       | 0       | PDMA CAN channel offset 2, RX buffer 4 |
| 1       | 1       | 1       | PDMA CAN channel offset 2, RX buffer 5 |

By using two filter entries in the CAN, software can setup a ping/pong buffer for a particular RX packet ID. For example the following two filter entries will setup a ping/pong using RX buffers 0 and 1 for packet ID 5 on CAN RX channel 0:

| Filter Entry | Packet Match ID | Filter Event Bits |
|--------------|-----------------|-------------------|
| 0            | 5               | 0x2               |
| 1            | 5               | 0x3               |

#### 11.3.1.3.2.5.3.2.1 MCAN Burst Mode

Since MCAN buffers are stored in linear memory, the burst mode for MCAN is a simple linear burst across the transfer window. The max burst size is set to the 72 byte size of the MCAN buffer. This will allow a full MCAN packet to be read out as a single burst.

#### 11.3.1.3.2.5.3.3 AASRC Channel

The AASRC channel is controlled primarily via the channel's RxFifoConfig register. This register holds 3 basic pieces of information:

- Whether the channel uses AASRC Stream Mode or Group Mode
- The slot range in the order table used (from designated first slot to designated last slot)
- The AASRC DMA request event(s) that must fire before the channel becomes active

The channel will remain idle until a pulse is detected on ALL associated input DMA request event pins required by the RxFifoConfig setting. The pulses for the individual events are latched and held by the PDMA until they all arrive.

Once the channel activates, it will start reading FIFO index values from the RxOrderTable, starting at the configured 'First Slot' and ending with the 'Last Slot'. The actual FIFO indices used are obtained from the ordering table. For example, say FirstSlot=3 and LastSlot=5. If the first 6 slots of the ordering table were: 0, 2, 4, 6, 8, 10, the FIFOs read for the event would be 6, 8, and 10, because 'slot 3' of the table contains 6, and it would proceed through 'slot 5' of the table which contains 10.

The X and Y registers are still used as they are in a normal X-Y mode. When accessing each FIFO, the setting of X determines the sample byte width read from the FIFO. The value of 'Y' determines how many times the entire FIFO list is processed for each activation of the channel.

Once the total specified number of transactions has been completed the channel will return to an idle state and wait until it is triggered again. The read transfers that are performed will be accomplished as quickly as possible given availability of data in the TX channelized FIFO and given the arbitration that may occur as a result of other channels also using the same write unit.

#### 11.3.1.3.2.5.4 Receive PSI-L Interface Transactions

When an entire word has been packed into the Rx Per Channel Buffer for a given channel, a one word data phase transfer will be initiated for that channel/thread on the Rx PSI-L interface and the data will be popped from the Rx Per Channel FIFO. The value sources for the output pins on the PSI-L interface are described in the following table.

| Pin               | Output Value / Source From PDMA                                                                                                                                                                                                       |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| strm_o_req        | This signal is asserted when the PDMA determines that there is at least 1 word of data in its TP-CC output FIFO                                                                                                                       |
| strm_o_sthread_id | Set equal to the TP-CC DMA channel number which is on the interface for this cycle                                                                                                                                                    |
| strm_o_dthread_id | Set equal to the target thread ID value given in the PSI-L pairing configuration registers for this DMA channel                                                                                                                       |
| strm_o_data_type  | Will be set to the proper PSI-L data type. The PDMA can send config response, PSI info word 0, and PSI data word.                                                                                                                     |
| strm_o_wnum       | Set equal to the packing lane for the current word within a contiguous transfer. This value will start at 0 for each new TR and will increment for each subsequent data phase in the TR.                                              |
| strm_o_lastw      | This signal will be asserted coincident with eop.                                                                                                                                                                                     |
| strm_o_xcnt       | The xcnt will be equal to the data path width in bytes.                                                                                                                                                                               |
| strm_o_worden     | The worden will be modulated to indicate which 32-bit words are valid within each control type data phase.                                                                                                                            |
| strm_o_data       | The data will be packed/left justified to comply to the big endian data ordering as required in the PSI-L I/F specification.                                                                                                          |
| strm_o_sop        | This signal is asserted for 1 data phase at the beginning of each new TR or data transfer packet.                                                                                                                                     |
| strm_o_eop        | This signal is asserted for 1 data phase at the end of each TR or data transfer packet.                                                                                                                                               |
| strm_o_sol        | This signal is set to zero unless the EOL bit is set in PSI-L register 0x401, in which case, it is set for 1 data phase at the start of a new set of transactions designated by the count set in the Z field of PSI-L register 0x401. |
| strm_o_eol        | This signal is set to zero unless the EOL bit is set in PSI-L register 0x401, in which case, it is set for 1 data phase at the end of a set of transactions designated by the count set in the Z field of PSI-L register 0x401.       |

| Pin             | Output Value / Source From PDMA                                      |
|-----------------|----------------------------------------------------------------------|
| strm_o_priv     | Set to zero.                                                         |
| strm_o_privid   | Set to zero.                                                         |
| strm_o_virtid   | Set to zero.                                                         |
| strm_o_secure   | Set to zero.                                                         |
| strm_o_interest | Set to zero.                                                         |
| strm_o_steady   | Always asserted as the PDMA is always able to accept credit returns. |

#### 11.3.1.3.2.5.5 Rx Pause

The Host initiates a channel pause by setting the pause bit in RT enable register. The paused channel can be resumed by clearing the register bit.

#### 11.3.1.3.2.5.6 Rx Teardown

The Host initiates a RX channel teardown by setting the tdown bit in the RT enable register for the target RX channel. The PDMA communicates the teardown state to the UDMA-P through the PSI-L data channel, to ensure that the teardown is not seen by the UDMA-P until all the previous PDMA data for the channel has been flushed.

The PDMA will not stop reading peripheral data until it reaches a FIFO boundary as configured through the 'X' and 'Y' parameters in the static TR. It will always attempt to complete the 'Y' count for the current event being processed. Upon reaching a stopping point, the PDMA will then clear the enable bit in the pairing register, however the teardown bit will remain set. No further packet processing will occur until the Host re-configures the channel. The teardown process will propagate to the UDMA-P and its final status can be checked there.

#### 11.3.1.3.2.5.7 Rx Channel Reset

In the unlikely event that channel synchronization is corrupted, a channel may fail to teardown gracefully. If this occurs, the channel may be reset by clearing the enable bit in the PSI-L enable register. This will cause a local reset of the entire channel, including TR and pairing registers. Note that it does not reset the UDMA-P peer. Resetting the UDMA-P peer is also required before re-initializing and re-pairing the channel.

#### 11.3.1.3.2.5.8 Rx Debug/State Register

The debug/state registers are supplied to give software applications additional information about the PDMA than they would need in regular operation, but which may be useful in debug situations. The registers appear on the PSI-L bus, near the static TR registers. For receive, they are defined as follows.

| Name    | PSI-L Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                          |
|---------|------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z*      | 0x402      | 31:16 | This field holds the lower 12 bits of the current Z count for legacy purposes. See register 0x40F below for the full width version of Z.                                                                                                                                                                                                                                             |
| Y       | 0x402      | 15:0  | This field holds the current Y count. In X-Y FIFO mode, this is the number of X sized samples yet to be read from the peripheral for the DMA event being serviced. In MCAN mode, this field holds the next read offset to use when read to the CAN RX buffer.                                                                                                                        |
| InEvent | 0x403      | 31    | When set, the PDMA is in the middle of processing a FIFO event.                                                                                                                                                                                                                                                                                                                      |
| Tdown   | 0x403      | 30    | When set, the PDMA is processing a teardown operation. This bit is set simultaneously with the teardown bit in the source (RX) RT enable register. This bit will clear when the teardown is complete, regardless as to if the teardown bit in the pairing register is cleared or not. The teardown will propagate to the UDMA-P and its full completion status can be checked there. |

| Name     | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                     |
|----------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pause    | 0x403     | 29    | When set, the PDMA is stopped in a paused state. This bit will clear if the channel is unpaused or disabled.                                                                                                                                                                                                                                                                    |
| Space    | 0x403     | 28    | When set, there is a non-zero amount of internal FIFO space available to hold new read data.                                                                                                                                                                                                                                                                                    |
| XSpace   | 0x403     | 27    | When set, there is enough internal FIFO space available to start servicing a peripheral DMA event.                                                                                                                                                                                                                                                                              |
| Buffer   | 0x403     | 26    | This is the current RX buffer (0/1) for the current MCAN receive operation.                                                                                                                                                                                                                                                                                                     |
| State    | 0x403     | 23:20 | This code reflects the current state of the PDMA channel, and is specific to the current implementation.                                                                                                                                                                                                                                                                        |
| EventCnt | 0x403     | 19:16 | This field holds the number of backlogged DMA events yet to be serviced.                                                                                                                                                                                                                                                                                                        |
| Z        | 0x40F     | 31:0  | This field holds the full width value of the current Z count. In X-Y FIFO mode, this field holds the 1 based FIFO count of the FIFO being currently read, or the number of FIFO completions when the current operation completes. In MCAN mode, this field holds the zero based buffer index of the buffer currently being read, or the number of previously completed buffers. |

#### 11.3.1.4 Functional Description - McASP

##### 11.3.1.4.1 Compliance to Standards

The PDMA complies fully to all standards listed in the previous section.

##### 11.3.1.4.2 Functional Operation

The Peripheral DMA is a simple, low cost implementation of the CPPI 5.0 Unified Transfer Controller. The PDMA module is required to be located close to one or more peripherals (both peripherals and PDMA direct connected to the SCR) which require an external DMA for data movement and is architected to reduce cost by using VBUSP interfaces and supporting only the static Transfer Request subset of UTC features which are useful for peripheral type transactions. Multiple source and destination channels are provided within the PDMA, which allow multiple simultaneous transfer operations to be ongoing. The DMA controller maintains state information for each of the channels and employs time division multiplexing between channels to share the underlying DMA hardware. A scheduler is provided to control the ordering and rate at which this multiplexing occurs. A block diagram of the PDMA Controller is shown below:

##### 11.3.1.4.2.1 Submodule Descriptions

###### 11.3.1.4.2.1.1 Scheduler

The Scheduler block is responsible for monitoring the fullness level of the various FIFOs, monitoring input DMA triggering events, maintaining channel state information, and issuing credits to the Tx and Rx DMA units when it is time to perform each low level read or write operation.

###### 11.3.1.4.2.1.2 Tx Per Channel Buffers

The Tx Per Channel Buffers implement channelized FIFOs for each DMA channel. A single logical data FIFO is provided for each destination DMA channel that is used for buffering payload data that has been pushed into the PDMA from the Tx PSI-L interface. The Tx Per Channel Buffers are always written with full Tx PSI-L wide words (except for EOL/EOP data phases) but are read on byte granularity from the Tx DMA units.

#### 11.3.1.4.2.1.3 Tx DMA Unit

The Tx DMA Unit block implements all of the state machine functionality necessary to implement static TR type UTC destination channels. The Tx DMA unit waits until it is triggered by an incoming dma event and then writes data from the Tx Per Channel Data FIFO associated with the channel to an external memory mapped target via a VBUSP controller interface. The number and width of the writes that are performed is in accordance with the parameters which were programmed via PSIL into the static TR for the channel.

#### 11.3.1.4.2.1.4 Rx Per Channel Buffers

Rx Per Channel Buffers implement a logical FIFO for each source DMA channel that is used for buffering payload data that has been fetched by the Rx DMA units. The buffers are byte oriented on write so that the data from the Rx DMA units which may not be full words can be packed properly. The buffers are word oriented on read in accordance with the transport mechanism outlined in the PSIL Interface specification. Each channel in the Rx DMA controller maps directly onto a thread in the Rx PSIL interface. The Rx Per Channel Buffer block outputs queue fullness information to the scheduler block, which it then uses to determine when it should initiate DMA opportunities to backfill the buffers. The Rx Per Channel Buffer initiates transfers to the remote paired thread whenever any data is available in each channel buffer and credits are available in the corresponding thread. The block simultaneously monitors the status of all of the threads and performs a round robin arbitration between the different threads for the use of the Rx PSIL interface. Each thread for which the target is indicating it can accept data and which currently has data available in the channel buffer is included in the arbitration.

#### 11.3.1.4.2.1.5 Rx DMA Unit

The Rx DMA Unit block implements all of the state machine functionality necessary to implement static TR type UTC source channels. The Rx DMA unit waits until it is triggered by an incoming DMA event and then reads data from an external memory mapped source via a VBUSP controller read interface into the Rx Per Channel Data FIFO associated with the channel. The number and width of the writes that are performed is in accordance with the parameters which were programmed via PSIL into the static TR for the channel.

#### 11.3.1.4.2.2 General Functionality (Applicable to All Functions/Modes)

##### 11.3.1.4.2.2.1 Operational States

At any given time, the PDMA can be in one of three different states, as shown in [Table 11-85](#).

**Table 11-85. PDMA Operational States**

| Operational State | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Init              | This is the initial state of the machine during and immediately after reset. During this state, all of the RAMs inside the PDMA will be initialized to known values including the ECC redundant parity bits. While in the init state, the DMA will de-assert all ready signals on all applicable target interfaces and will de-assert all request signals on all applicable controller interfaces. The PDMA will automatically transition out of the init state into the idle state when all of the RAM initialization has been completed. |
| Idle              | Once the PDMA leaves the Init state, it enters the Idle state whenever no outstanding transactions are pending on any of the PDMA interfaces (controller or target). The Idle state is generally a transient state and is used by the PDMA to determine when it is appropriate to allow the SoC power management complex to turn off the clock. For clock stop purposes, the module will only report idle if all DMA channels are disabled using the enable bit in PSIL register 2 for each channel.                                       |
| Active            | The PDMA enters the active state as soon as it issues a transaction or receives a transaction on any interface that uses a split protocol (expects a later response for a request). When all transactions have been accounted for (responses have all been either received or sent) the PDMA transitions to the Idle state.                                                                                                                                                                                                                |

##### 11.3.1.4.2.2.2 Clock Stop

The clock stop interface is used to instruct the PDMA to stop issuing commands on its external interfaces. Note that the PDMA will report a clock stop idle if all its DMA channels have been previously disabled by software using the enable bit in PSIL register 2 for each channel.

#### 11.3.1.4.2.2.3 Emulation Control

The emulation control input (susp\_emsusp) and the per channel emulation control 'free' bit allow DMA operation to be suspended on a per channel basis. When the emulation suspend state is entered, the DMA will stop processing receive and transmit TRs for each channel at the next TR boundary. Any TR currently in reception or transmission will be halted at its next FIFO boundary as configured through the 'X' and 'Y' parameters in the static TR. Emulation control is implemented for compatibility with other peripherals. Each source and destination channel can be configured to either honor the suspend signal, or to 'free run' without regard to suspend. This is controlled via the 'free' bit in the channel Enable Register. Note the real time emulation suspend request signal is not supported.

#### 11.3.1.4.2.3 Events and Flow Control

The following sections describe the simplified mechanism provided on the Peripheral DMA for triggering.

##### 11.3.1.4.2.3.1 Channel Triggering

Channels must be triggered for them to perform work. A local event input bus is provided on the peripheral DMA and each bit in the input bus corresponds to the trigger for the channel with the same channel index as the bit index in the bus (bit 0 triggers channel 0, bit 1 triggers channel 1, and so forth). The event inputs for XY mode are triggered either via pulse, or by a clock synchronous rising edge. The counting mode is a design time configuration parameter. In MCAN mode, the inputs are expected to be single cycle pulses, synchronous with the PDMA clock.

- Event signals that are used in pulse mode must be sourced by the same clock as the PDMA.
- Event signals that are used in edge mode must be sourced by pseudo-synchronous sources (and be a slower clock multiple) to the PDMA clock, and they must remain high for at least 1 'slow' clock cycle.

The PDMA provides a 2-bit counter per event input to accommodate startup latency in the channel. (In AASRC mode, the signals are not counted, but latched whenever asserted.)

##### 11.3.1.4.2.3.2 Completion Events

All transfers on PDMA are split TR in that they have a UDMA-P half and a (static) PDMA half. Completion events are designed to be triggered from the UDMA-P half of the split TR.

##### 11.3.1.4.2.3.3 Channel Types

Each channel in the Peripheral DMA is configured at design time to be either standard X-Y FIFO mode or MCAN channel. The channel type is configured at design time, and can not be changed by software.

###### 11.3.1.4.2.3.3.1 X-Y FIFO Mode

Most peripherals which are serviced by the Peripheral DMA follow the pattern of transferring X bytes from a fixed, non-changing address in a loop Y times for each triggering event that is received. The X parameter is typically 1-16 bytes and the Y parameter can be any integer up to 2048. If a peripheral can be serviced by this basic functionality then it is recommended to use this mode for the peripheral.

###### 11.3.1.4.2.3.3.2 MCAN Mode

The MCANSS subsystem was found to require a few minor differences than standard X-Y mode. First, buffer ownership on transmit is different in that the DMA starts out owning the TX buffer space (instead of waiting for an initial DMA event from the MCAN). There is also a requirement to perform a write of a fixed value to a fixed address after each DMA event is serviced to pass ownership of a buffer back to the MCAN. Finally, MCAN packet fragmentation requirement to place an 8-byte header on each 64-byte chunk that is transmitted and to remove the header from each 64-byte chunk (other than the first block) that is received.

###### 11.3.1.4.2.3.3.3 AASRC Mode

The AASRC mode of the PDMA is similar to the X-Y mode in that X specifies the sample width, any Y specifies the number of FIFO samples to transfer per DMA request, but in addition to this, a programmable FIFO list is supplied that allows a single PDMA channel to transfer data to multiple FIFOs. The FIFO list specifies which FIFOs to access, and in which order to access them. Both AASRC 'stream' and 'group' modes are supported

in terms of DMA signalling and the FIFO memory map. When in AASRC mode, the entire PDMA operates exclusively in this mode. AASRC channels do not share the same PDMA as do XY and MCAN channels.

The following additional details apply to the PDMA in AASRC mode.

#### Main Features:

- Up to 16 independent RX channels and 16 TX channels
  - Each channel represents a different data stream to either the UDMA-P-P or a McASP PDMA
- Each channel can be configured to read or write any of the AASRC FIFOs in any order
- Packing support for 1, 2, 3, and 4 byte samples
  - Can directly talk to a McASP using any McASP data format
  - Packing sample size is fixed for a given channel
- Supports both Group and Stream AASRC signaling and FIFO memory maps
  - There is a single stream/group mode setting for each PDMA channel

#### Additional details:

- Each channel has a 'mask' of which DMA requests must fire to activate the channel
  - In stream mode, the mask specifies all the FIFO DMA requests that must fire
  - In group mode, the mask specifies the one group DMA request that must fire
- Each channel specifies an ordered list of how FIFOs should be accessed
  - All channels use a common list, specifying a range of entry indices within that list. This lets each channel use a varying number of list elements.
  - The order list can be processed multiple times per DMA request. The number of samples to be transferred per request must match the configured threshold for the DMA request in the AASRC.
- All FIFOs are specified by index only
  - In the TX ordering table, the indices are assumed to be TX FIFOs
  - In the RX ordering table, the indices are assumed to be RX FIFOs
  - If a DMA channel is in 'Group Mode', the PDMA assumes the indices referenced by that channel represent Group Mode FIFOs; otherwise, it assumes Stream Mode FIFOs.
- The PDMA has configured base addressed and inter-FIFO spans such that it can always convert from a FIFO index to the proper Stream or Group mode FIFO address

#### 11.3.1.4.2.4 Transmit Operation

##### 11.3.1.4.2.4.1 Destination (Tx) Channel Allocation

A total of 3 destination channels are provided within the DMA for concurrent transfers from Tx per channel buffers to the various attached peripherals. Each Tx channel requires a single PSIL thread. The Tx channels are allocated as follows:

| Tx DMA Channel | Function        | Channel Type | Trigger Mode | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|-----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 8000           | McASP 0 Tx Ch 0 | XY           | edge         | 000002B08000      | 000000000000       | 000000000000         |
| 8001           | McASP 1 Tx Ch 0 | XY           | edge         | 000002B18000      | 000000000000       | 000000000000         |
| 8002           | McASP 2 Tx Ch 0 | XY           | edge         | 000002B28000      | 000000000000       | 000000000000         |

##### 11.3.1.4.2.4.2 Destination (Tx) Channel Out of Band Signals

The following table shows how PSIL signals are handled for destination channels.

| PSIL Signal | XY/AASRC Mode | MCAN Mode                  |
|-------------|---------------|----------------------------|
| sop         | ignored       | ignored                    |
| eop         | ignored       | closes current MCAN packet |
| sol         | ignored       | ignored                    |
| eol         | ignored       | ignored                    |
| drop        | ignored       | ignored                    |

| PSI-L Signal | XY/AASRC Mode                                        | MCAN Mode                                            |
|--------------|------------------------------------------------------|------------------------------------------------------|
| pkt_error    | ignored                                              | ignored                                              |
| tdown        | reflect in status, teardown when data marker reached | reflect in status, teardown when data marker reached |

#### 11.3.1.4.2.4.3 Destination Channel Initialization

After reset, all threads/channels in the PDMA are idle and waiting for work to be assigned to them. To initiate PDMA operation, the Host must first pair the channel with a remote data source (normally a UDMA-P channel), set up the static TR for the channel, and enable the thread.

##### 11.3.1.4.2.4.3.1 PSI-L Destination Thread Pairing Registers

###### 11.3.1.4.2.4.3.1.1 Enable Register (PSIL Address 0x002)

| Bits | Field  | Reset | Description                                                                                                                                                                                      |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the TX channel is disabled. When disabled, the channel discards all ingress data. A one to zero transition on this bit fully resets the channel. |
| 30:0 | -      | 0x0   | Reserved.                                                                                                                                                                                        |

###### 11.3.1.4.2.4.3.1.2 Peer Credit Register (PSIL Address 0x040)

| Bits  | Field            | Reset | Description                                                                                                                                       |
|-------|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | -                | 0x0   | Reserved.                                                                                                                                         |
| 28:24 | LocalThreadWidth | 0x2   | Read only element width for the local thread used for pairing purposes. This field is encoded as follows: 0 = 4 bytes, 1 = 8 bytes, 2 = 16 bytes. |
| 23:8  | -                | 0x0   | Reserved.                                                                                                                                         |
| 7:0   | LocalCreditCnt   | 0x8   | Read only local thread free entry count used for pairing purposes.                                                                                |

###### 11.3.1.4.2.4.3.2 PSI-L Destination Thread Pairing

After reset, all threads on PSI-L are uninitialized and unpaired. The Host pairs each destination PDMA channel with (typically) a corresponding source channel in the UDMA-P. The PDMA thread is configured to point to the UDMA-P thread, and the UDMA-P thread is configured to point to the PDMA thread. Once paired, the source channels in the UDMA-P send all their data to the destination channel in the PDMA, and the destination channel in the PDMA never sees any data other than data from the source channel in the UDMA-P.

##### 11.3.1.4.2.4.3.3 PSI-L Destination Thread Realtime Enable/Count Registers

###### 11.3.1.4.2.4.3.3.1 RT Enable Register (PSIL Address 0x408)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the TX channel is disabled. When disabled, it discards all held data. It clears DMA event counts and ignores all future DMA events from the peripheral. It maintains data exchange with the UDMA-P so that credit handshake is not disrupted. A 'hard teardown' can be performed by directly clearing this bit.<br>Note that this bit cannot be changed from 0 to 1 if the global enable bit in the peer enable register is 0. |

| Bits | Field | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30   | tdown | 0x0   | When set, the channel will commence a TX channel teardown procedure.<br>To perform a TX teardown, the teardown bit should be set in the UDMA-P and it will automatically propagate to this register bit with the normal flow of peripheral data.<br>Once the channel is fully stopped and ready to be reused (including returning all credits), the enable bit is cleared.                                                                                                      |
| 29   | pause | 0x0   | When set, the channel is in a paused state. It will stop on the next FIFO boundary. It continues to accept and count DMA events from the peripherals, but will not act on them. The pause bit can be cleared and data will resume.                                                                                                                                                                                                                                              |
| 28   | flush | 0x0   | When set, causes all TX channel data to be discarded instead of being written to the peripheral. It essentially allows the TX engine to 'free run' without DMA requests from the peripheral (it will also override 'pause'). This bit should be set only when a channel fails to complete its teardown procedure normally, because a peripheral is no longer functioning or because data flow was halted on a boundary that is not compatible with the static TR configuration. |
| 27:3 | -     | 0x0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2    | error | 0x0   | When set, the channel has encountered a PSIL protocol violation. The error bit can only be set by hardware, and can only be cleared by software. Once this bit is set, the channel should be fully reset and re-initialized via the PSIL pairing registers.                                                                                                                                                                                                                     |
| 1    | idle  | 0x0   | This is a read-only bit that signifies that the disabled channel is also idle. This bit is read only and can only become set if the enable bit in the RT enable register is cleared.                                                                                                                                                                                                                                                                                            |
| 0    | free  | 0x0   | When cleared, the channel honors the emudbg suspend signal. When set, the channel will free run, regardless of the value of emudbg suspend.                                                                                                                                                                                                                                                                                                                                     |

#### 11.3.1.4.2.4.3.3.2 Destination Thread Byte Count Register (PSIL Address 0x404)

| Bits | Field | Reset | Description                                                                                                                                                                                                                                                                                                   |
|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | bytes | 0x0   | This register contains the number of bytes that have been written to the VBUSP mapped peripheral. The register is write to decrement, so running counts can be tracked by reading register and then writing back the value that was read. It will wrap on overflow. It will reset to zero on a channel reset. |

#### 11.3.1.4.2.4.3.4.4 Static Transfer Request Setup

After reset, all channels in the PDMA are idle and waiting for work to be assigned to them. To initiate PDMA operation, the Host sends configuration transactions across PSI-L and sets up the static TR for each destination channel. The format of the TR is identical for each DMA mode, consisting of an X, Y, and Z parameter, but the field interpretation varies somewhat.

##### 11.3.1.4.2.4.3.4.1 X-Y FIFO Mode Static TR

In X-Y FIFO mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description                                                                                            |
|-------|-----------|-------|--------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the XY burst description for more information. |

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                       |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                     |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, 4 = 64 bits, and 5-7 = RESERVED |
| Y     | 0x400     | 11:0  | Element count. This field specifies how many elements to transfer each time a trigger is received on the channel.                                                                                                                 |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                          |

#### 11.3.1.4.2.4.3.4.2 MCAN Mode Static TR

In MCAN mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                                                                                                                                                                                                                     |
| X     | 0x400     | 26:24 | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Y     | 0x400     | 11:0  | Buffer Size. This field specifies how many bytes should be written to an MCAN TX buffer. This field includes the 8 byte MCAN header on the initial packet fragment. The PDMA will break up the source packet into fragments of this buffer size, copying the 8 byte MCAN header for the initial fragment, and then skipping it for each additional fragment and thus reusing the header from the first fragment. A buffer size less than 16 is treated as 16, and a buffer size greater than 72 is treated as 72. |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 11.3.1.4.2.4.3.4.3 AASRC Mode Static TR

AASRC mode is similar to X-Y FIFO mode, the static TR consists of the following information:

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                                                                                                                                                                                                             |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, and 4-7 = RESERVED                                                                                                                                                                                                                                                                                      |
| Y     | 0x400     | 11:0  | FIFO element count. In AASRC mode, a channel can service multiple FIFOs using a list supplied in its FIFO configuration. This field specifies how many times to service the FIFO list, hence how many elements to transfer to each FIFO, each time a trigger is received on the channel. Note for each loop specified by the value of Y, the entire list is processed. For example, if the FIFO list is 0, 1, 2, 3, and Y is set to 2 loops, the FIFOs are serviced in the order: 0, 1, 2, 3, 0, 1, 2, 3. |
| Z     | 0x401     | 23:0  | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### 11.3.1.4.2.4.3.4.4 AASRC TxFifoConfig (PSIL Address 0x405)

This register describes the FIFO list to be processed for this TX channel.

| Bits  | Field       | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | GroupMode   | 0x0   | When set, the channel is in 'Group Mode'. It will look for Group Mode DMA requests, and access the Group Mode FIFOs. When clear, the channel is 'Stream Mode'. It will look for Stream FIFO DMA requests, and access the Stream Mode FIFOs.                                                                                                                                                                                                                                                           |
| 30    | DmaReqReset | 0x0   | When set, resets any latched DMA request using the DmaReqMask. This bit is self-clearing. It should be used to synchronize the AASRC event status with the PDMA in the event that the AASRC has been previously used and it is not known if the PDMA may have latched, and is holding, previous DMA requests.                                                                                                                                                                                         |
| 23:20 | LastSlot    | 0x0   | This is the index (0-15) of the last slot in the TX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                             |
| 19:16 | FirstSlot   | 0x0   | This is the index (0-15) of the first slot in the TX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                            |
| 15:0  | DmaReqMask  | 0x0   | This field holds a set of flags indicating which AASRC DMA requests must fire in order for this channel to activate. In Steam Mode, these 16 flags correspond to the 16 DMA requests for each TX FIFO. The flags corresponding to all TX FIFOs involved with the channel should be set to 1. In Group Mode, these flags indicate which Group Mode DMA requests must fire. In this case, only bits 3:0 are relevant and only one bit should be set to 1 as a DMA channel only services a single group. |

#### 11.3.1.4.2.4.3.4.5 AASRC TxOrderTable0 (PSIL Address 0x406)

This table is filled with FIFO index values. TX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all TX threads.

| Bits  | Field  | Reset | Description              |
|-------|--------|-------|--------------------------|
| 31:28 | Entry7 | 7     | TX FIFO Index for slot 7 |
| 27:24 | Entry6 | 6     | TX FIFO Index for slot 6 |
| 23:20 | Entry5 | 5     | TX FIFO Index for slot 5 |
| 19:16 | Entry4 | 4     | TX FIFO Index for slot 4 |
| 15:12 | Entry3 | 3     | TX FIFO Index for slot 3 |
| 11:8  | Entry2 | 2     | TX FIFO Index for slot 2 |
| 7:4   | Entry1 | 1     | TX FIFO Index for slot 1 |
| 3:0   | Entry0 | 0     | TX FIFO Index for slot 0 |

#### 11.3.1.4.2.4.3.4.6 AASRC TxOrderTable1 (PSIL Address 0x407)

This table is filled with FIFO index values. TX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all TX threads.

| Bits  | Field   | Reset | Description               |
|-------|---------|-------|---------------------------|
| 31:28 | Entry15 | 15    | TX FIFO Index for slot 15 |

| Bits  | Field   | Reset | Description               |
|-------|---------|-------|---------------------------|
| 27:24 | Entry14 | 14    | TX FIFO Index for slot 14 |
| 23:20 | Entry13 | 13    | TX FIFO Index for slot 13 |
| 19:16 | Entry12 | 12    | TX FIFO Index for slot 12 |
| 15:12 | Entry11 | 11    | TX FIFO Index for slot 11 |
| 11:8  | Entry10 | 10    | TX FIFO Index for slot 10 |
| 7:4   | Entry9  | 9     | TX FIFO Index for slot 9  |
| 3:0   | Entry8  | 8     | TX FIFO Index for slot 8  |

#### 11.3.1.4.2.4.3.5 PSI-L Destination Thread Enables

PSI-L destination threads must first be enabled to accept data. Threads are enabled or disabled by setting or clearing the enable bit in the PSI-L pairing registers for the thread. When a thread is disabled, it must drop any data phases which are sent but properly return the credits for the data phases which are dropped.

Once a thread is paired, the TR has been set up and the enable is asserted, the channel is armed and ready to be triggered to perform the specified set of write transactions.

#### 11.3.1.4.2.4.4 Data Transfer

Packet transmission is accomplished within the PDMA by unpacking and moving data from the Tx Per Channel FIFOs which were filled via the Transmit PSI-L Interface to specified memory mapped address ranges via the VBUSP controller interfaces. On the Tx side of the PDMA, these transfers are always writes. Each write transfer which is performed by the Tx DMA Unit is to a destination address that is hardcoded in the channel at design time and of a size as specified in the static Transfer Request.

The sequences of logical transactions that are performed by the PDMA on the Memory I/F during transmit is dependent on the channel type. The following sections describe what will happen for the different channel types.

##### 11.3.1.4.2.4.4.1 X-Y FIFO Mode Channel

The PDMA channel remains idle until a pulse is detected on the associated input DMA request event pin. Once the pulse is detected, the DMA sequentially issues a total of 'Y' parameter writes of 'X' parameter bytes to the data\_address specified in the tchan\_info parameter for the channel. Each write that the DMA performs is a single 'X' element in size (no large bursts). Once the total specified number of transactions has been completed, the channel returns to an idle state and waits until it is triggered again. The write transfers that are performed are accomplished as quickly as possible given availability of data in the Tx channelized FIFO, and given the arbitration that may occur as a result of other channels also using the same write unit.

##### 11.3.1.4.2.4.4.1.1 X-Y FIFO Burst Mode

The burst mode for XY is designed to allow the PDMA to burst across a FIFO region, while extracting out the 'sample size' from each data phase. So for example, it can read a "burst" of multiple 32-bit words from a McASP, and grab only 24-bits from each data phase.

It uses the same registers as standard XY mode, where X is the encoded sample size, and Y is the number of samples to read/write per DMA request. Setting bit 31 of the XY register enables burst.

The following are the rules for enabling burst mode. Incompatible peripherals do not need to enable burst, or can enable it on RX without enabling it on TX.

- The VBUSP address increments throughout the burst
- Bursts are sub-divided to fit into a 64 byte transfer window
- One sample is transferred for every bus data phase
  - Cannot burst one byte samples from a 16-bit peripheral on a 32-bit bus
  - Cannot burst 64-bit samples on a 32-bit bus (configure for 2 32-bit samples instead)
- PDMA 'gaps' the byte enables on writes as needed

#### 11.3.1.4.2.4.4.2 MCAN Mode Channel

The PDMA channel remains idle until data is received from the UDMA-P over the PSIL interface. At this time, the PDMA immediately starts copying packet bytes into the MCAN TX buffer corresponding to the PDMA/MCAN channel. The number of bytes copied is smaller of the remaining bytes in the packet, or the value of the 'Y' parameter. Once a TX buffer has been filled, the PDMA transfers ownership of the buffer to MCAN by performing an MCAN register write. The PDMA then waits to regain ownership of the TX buffer by waiting for the corresponding MCAN TX event. At this time, the PDMA continues with refilling the TX buffer for the next packet fragment. On subsequent fills (until the end of packet is reached), the PDMA skips over the 8 byte MCAN header, leaving the original contents from the initial fragment copy in place.

#### 11.3.1.4.2.4.4.3 AASRC Channel

The AASRC channel is controlled primarily via the channel's TxFifoConfig register. This register holds 3 basic pieces of information:

- Whether the channel uses AASRC Stream Mode or Group Mode
- The slot range in the order table used (from designated first slot to designated last slot)
- The AASRC DMA request event(s) that must fire before the channel becomes active

The channel remains idle until a pulse is detected on ALL associated input DMA request event pins required by the TxFifoConfig setting. The pulses for the individual events are latched and held by the PDMA until they all arrive.

Once the channel activates, it starts reading FIFO index values from the TxOrderTable, starting at the configured 'First Slot' and ending with the 'Last Slot'. The actual FIFO indices used are obtained from the ordering table. For example, say FirstSlot=3 and LastSlot=5. If the first 6 slots of the ordering table were: 0, 2, 4, 6, 8, 10, the FIFOs written for the event would be 6, 8, and 10, because 'slot 3' of the table contains 6, and it would proceed through 'slot 5' of the table which contains 10.

The X and Y registers are still used as they are in a normal X-Y mode. When accessing each FIFO, the setting of X determines the sample byte width written to the FIFO. The value of 'Y' determines how many times the entire FIFO list is processed for each activation of the channel.

Once the total specified number of transactions has been completed, the channel returns to an idle state and waits until it is triggered again. The write transfers that are performed are accomplished as quickly as possible, given availability of data in the TX channelized FIFO and given the arbitration that may occur as a result of other channels also using the same write unit.

#### 11.3.1.4.2.4.5 Transmit PSI-L Interface Transactions

The PDMA accepts data across the Tx PSI-L Interface in accordance with the physical handshaking protocol, as defined in the PSI-L Interface specification. The value sources for the output pins on the PSI-L interface are described in the following table.

| Pin              | Output Value / Source From PDMA                                                                    |
|------------------|----------------------------------------------------------------------------------------------------|
| strm_i_link      | This signal is asserted high to indicate the PSI-L link is valid.                                  |
| strm_i_ready     | This signal is asserted high anytime there is space in the PSI-L ingress fifo.                     |
| strm_i_sreq      | This signal is asserted high anytime there is credit return data waiting in the PSI-L status fifo. |
| strm_i_sthreadid | This is set to the local destination thread that is returning credit.                              |
| strm_i_sccnt     | This is set to the number of credits being returned, or 0 on a TX teardown acknowledgement.        |

#### 11.3.1.4.2.4.6 Tx Pause

The Host initiates a channel pause by setting the pause bit in the RT enable register. The paused channel can be resumed by clearing the register bit.

#### 11.3.1.4.2.4.7 Tx Teardown

The Host initiates a channel teardown by setting the tdown bit in the UDMA-P channel paired with the PDMA. The UDMA-P communicates the teardown state through the PSI-L data channel, to ensure that the teardown is not seen by the PDMA until all the previous UDMA-P data for the channel has been flushed. At this time, the teardown state is reflected in the PSI-L RT Enable register of the PDMA. Note that a non-synchronized teardown can also be initiated by directly clearing the enable bit in the PSI-L RT Enable register of the PDMA.

Once all data has been flushed from the PDMA to the peripheral, the enable state of the PDMA channel is cleared in the PSI-L RT enable register, but the teardown bit remains high. A teardown completion indication is sent back across the status pins of the PSI-L in the form of a credit response with sccnt=0. Upon completion, no further packet processing occurs until the Host re-configures the channel. If the channel fails to teardown because the peripheral has stopped responding, or if the UDMA-P transmission stops on a data boundary that is not compatible with the static TR configuration, the flush bit in the RT enable register can be set to ensure that all data can be properly flushed from the internal pipe.

#### 11.3.1.4.2.4.8 Tx Channel Reset

In the unlikely event that channel synchronization is corrupted, a channel may fail to teardown gracefully, even with flush enabled. If this occurs, the channel may be reset by clearing the enable bit in the PSI-L Enable register. This causes a local reset of the entire channel, including TR and pairing registers. Note that it does not reset the UDMA-P peer. Resetting the UDMA-P peer is also required before re-initializing and re-pairing the channel.

#### 11.3.1.4.2.4.9 Tx Debug/State Register

The debug/state registers are supplied to give software applications additional information about the PDMA than they would need in regular operation, but which may be useful in debug situations. The registers appear on the PSI-L bus, near the static TR registers. For transmit, they are defined as in [Table 11-86](#).

**Table 11-86. Tx Debug/State Register**

| Name     | PSIL Addr | Field | Description                                                                                                                                                                                                                                                   |
|----------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Y        | 0x402     | 15:0  | This field holds the current Y count. In X-Y FIFO mode, this is the number of X sized samples yet to write to the peripheral for the DMA event being serviced. In MCAN mode, this field holds the next write offset to use when writing to the CAN TX buffer. |
| InEvent  | 0x403     | 31    | When set, the PDMA is in the middle of processing a FIFO event.                                                                                                                                                                                               |
| Flush    | 0x403     | 30    | When set, the PDMA is processing in a flushing state, where it runs without waiting for DMA requests and without writing data to the peripheral. It is only operating its internal state machine to allow internal data pipes to drain properly.              |
| Pause    | 0x403     | 29    | When set, the PDMA waiting in a paused state. This bit will clear when data starts flowing again from the UDMA-P.                                                                                                                                             |
| Data     | 0x403     | 28    | When set, there is a non-zero amount of data still waiting to be written to the peripheral.                                                                                                                                                                   |
| XData    | 0x403     | 27    | When set, there is enough data still waiting to be written to the peripheral to start servicing a peripheral DMA event.                                                                                                                                       |
| State    | 0x403     | 23:20 | This code reflects the current state of the PDMA channel, and is specific to the current implementation.                                                                                                                                                      |
| EventCnt | 0x403     | 19:16 | This field holds the number of backlogged DMA events yet to be serviced.                                                                                                                                                                                      |

#### 11.3.1.4.2.5 Receive Operation

#### 11.3.1.4.2.5.1 Source (Rx) Channel Allocation

A total of 3 source channels are provided within the DMA for concurrent transfers from the various attached peripherals into the Rx per channel buffers and on to the PSI-L Rx Interface. Each Rx channel requires a single PSI-L thread. The Rx channels are allocated as follows.

| Rx DMA Channel | Function        | Channel Type | Trigger Type | Data FIFO Address | Strobe MMR Address | Control FIFO Address |
|----------------|-----------------|--------------|--------------|-------------------|--------------------|----------------------|
| 0              | McASP 0 Rx Ch 0 | XY           | edge         | 000002B08000      | 00000000000000     | 00000000000000       |
| 1              | McASP 1 Rx Ch 0 | XY           | edge         | 000002B18000      | 00000000000000     | 00000000000000       |
| 2              | McASP 2 Rx Ch 0 | XY           | edge         | 000002B28000      | 00000000000000     | 00000000000000       |

#### 11.3.1.4.2.5.2 Source Channel Initialization

After reset, all threads/channels in the PDMA will be idle and waiting for work to be assigned to them. To initiate PDMA operation, the Host must first pair the channel with a remote data source (normally a UDMA-P channel), set up the static TR for the channel, and enable the thread.

##### 11.3.1.4.2.5.2.1 PSI-L Source Thread Pairing Registers

###### 11.3.1.4.2.5.2.1.1 Peer Thread ID Register (PSIL Address 0x000)

| Bits  | Field           | Reset | Description                                                                                                                                       |
|-------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | ThreadPriority  | 0x0   | This field is hard coded to 0x0 and is not writable                                                                                               |
| 28:24 | PeerThreadWidth | 0x0   | Datapath width of paired peer destination thread. This field is encoded as follows: 0 = 32-bit, 1 = 64-bit, 2 = 128 bit, 3 = 256 bit, 4 = 512 bit |
| 23:16 | -               | 0x0   | Reserved.                                                                                                                                         |
| 15:0  | Peer ThreadID   | 0x0   | Thread ID to which all non-Transfer Response, non-Config messages from this thread will be sent.                                                  |

###### 11.3.1.4.2.5.2.1.2 Peer Credit Register (PSIL Address 0x001)

| Bits | Field     | Reset | Description                                                                       |
|------|-----------|-------|-----------------------------------------------------------------------------------|
| 31:8 | -         | 0x0   | Reserved.                                                                         |
| 7:0  | CreditCnt | 0x0   | Free entries in destination thread. Legal range is 0 - 128 in number of elements. |

###### 11.3.1.4.2.5.2.1.3 Enable Register (PSIL Address 0x002)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                          |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the RX channel is disabled. When disabled, the channel ignores all credit returns, and will not generate egress data. A one to zero transition on this bit fully resets the channel. |
| 30:0 | -      | 0x0   | Reserved.                                                                                                                                                                                                                            |

#### 11.3.1.4.2.5.2.2 PSI-L Source Thread Realtime Enable/Count Registers

##### 11.3.1.4.2.5.2.2.1 RT Enable Register (PSIL Address 0x408)

| Bits | Field  | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | enable | 0x0   | When set, the channel is enabled. When cleared, the RX channel is disabled. When disabled, the channel ignores all DMA events from the peripheral. It maintains proper data transfers with the UDMA-P such that the credit handshake is not disrupted. However, unlike teardown, it does not close out the current open packet. Thus the teardown bit should always be used to disable an RX channel instead of manually clearing this bit. Failing to use teardown may result in stale data remaining in the internal RX FIFO, which would also prevent the channel from going idle without a channel reset.<br>Note that this bit cannot be changed from 0 to 1 if the global enable bit in the peer enable register is 0. |
| 30   | tdown  | 0x0   | When set, the channel will commence a RX channel teardown procedure. It will stop on the next FIFO boundary. It then clears the DMA event count and ignores all future DMA events from the peripheral.<br>After stopping peripheral reads, the PDMA sends a teardown message to the UDMA-P that also closes the current packet with an EOP. If no packet is open at the time of the teardown, the message also includes SOP. The EOP teardown message may or may not contain final packet data.<br>Once the channel teardown is complete and ready to be reused, the enable bit is cleared.                                                                                                                                  |
| 29   | pause  | 0x0   | When set, the channel is in a paused state. It will stop on the next FIFO boundary. It continues to accept and count DMA events from the peripherals, but will not act on them. The pause bit can be cleared and data will resume. Pause will not stop teardown from completing.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 28:2 | -      | 0x0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1    | idle   | 0x0   | This is a read-only bit that signifies that the Paused or Disabled channel is also idle. This bit is read only and can only become set if pause is set or enable is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0    | free   | 0x0   | Free Run: 0 = channel honors the emudbg suspend signal, 1 = channel will free run, regardless of the value of emudbg suspend.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 11.3.1.4.2.5.2.2.2 Source Thread Byte Count Register (PSIL Address 0x404)

| Bits | Field | Reset | Description                                                                                                                                                                                                                                                                                                  |
|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | bytes | 0x0   | This register contains the number of bytes that have been read from the VBUSP mapped peripheral. The register is write to decrement, so running counts can be tracked by reading register and then writing back the value that was read. It will wrap on overflow. It will reset to zero on a channel reset. |

#### 11.3.1.4.2.5.2.3 PSI-L Source Thread Pairing

After reset, all threads on PSI-L are uninitialized and unpaired. The Host pairs each source PDMA channel with (typically) a corresponding destination channel in the UDMA-P. The PDMA thread is configured to point to the UDMA-P thread, and the UDMA-P thread is configured to point to the PDMA thread. Once paired, the source channels in the PDMA send all their data to the source channel in the UDMA-P, and the destination channel in the UDMA-P never sees any data other than data from the source channel in the PDMA.

#### 11.3.1.4.2.5.2.4 Static Transfer Request Setup

After reset, all channels in the PDMA are idle and waiting for work to be assigned to them. To initiate PDMA operation, the Host sends configuration transactions across PSIL and sets up the static TR for each destination channel. The format of the TR is identical for each DMA mode, consisting of an X, Y, and Z parameter, but the field interpretation varies.

##### 11.3.1.4.2.5.2.4.1 X-Y FIFO Mode Static TR

In X-Y FIFO mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | When set, enables VBUSP burst mode on this channel. See the XY burst description for more information.                                                                                                                                                                                                                     |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                              |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each write which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, 4 = 64 bits, and 5-7 = RESERVED                                                                                          |
| Y     | 0x400     | 11:0  | Element count. This field specifies how many elements to transfer each time a trigger is received on the channel.                                                                                                                                                                                                          |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                     |
| Z     | 0x401     | 23:0  | FIFO count. This field specifies how many full FIFO operations comprise a complete packet. When the count has been reached, the PDMA will close the packet with an 'EOP' indication. If this parameter is set to NULL, then no packet delineation is supplied by the PDMA and all framing is controlled via the UDMA-P TR. |

##### 11.3.1.4.2.5.2.4.2 MCAN Mode Static TR

In MCAN mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                         |
|-------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | Not used                                                                                                                                                                                                                                                            |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                       |
| X     | 0x400     | 26:24 | Not used                                                                                                                                                                                                                                                            |
| Y     | 0x400     | 11:0  | Buffer Size. This field specifies how many bytes should be read from an MCAN RX buffer. This field includes the 8 byte MCAN header on the initial packet fragment. A buffer size less than 16 is treated as 16, and a buffer size greater than 72 is treated as 72. |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                              |

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z     | 0x401     | 23:0  | Buffer Count. This field specifies how many MCAN RX buffers should be read before closing the CPPI packet with an 'EOP' indication. When this count is greater than 1, multiple MCAN RX buffers will be read into a single CPPI packet buffer. The 8 byte MCAN header will be skipped on subsequent MCAN buffer reads. Setting this field to NULL will suppress all packet delineation, and should be avoided. |

#### 11.3.1.4.2.5.2.4.3 AASRC Mode Static TR

AASRC mode is similar to X-Y FIFO mode, the static TR consists of the following information.

| Param | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst | 0x400     | 31    | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Acc32 | 0x400     | 30    | When set, enables 32-bit access mode. On a 32-bit PDMA, all accesses will have XCNT=4 to support legacy IP that is not fully VBUSP compliant. This bit is ignored if the PDMA VBUSP port is not 32 bits wide.                                                                                                                                                                                                                                                                                               |
| X     | 0x400     | 26:24 | Element size. This field specifies how much data is transferred in each read which is performed by the DMA. This field is encoded as follows: 0 = 8 bits, 1 = 16 bits, 2 = 24 bits, 3 = 32 bits, and 4-7 = RESERVED                                                                                                                                                                                                                                                                                         |
| Y     | 0x400     | 11:0  | FIFO element count. In AASRC mode, a channel can service multiple FIFOs using a list supplied in its FIFO configuration. This field specifies how many times to service the FIFO list, hence how many elements to transfer from each FIFO, each time a trigger is received on the channel. Note for each loop specified by the value of Y, the entire list is processed. For example, if the FIFO list is 0, 1, 2, 3, and Y is set to 2 loops, the FIFOs are serviced in the order: 0, 1, 2, 3, 0, 1, 2, 3. |
| EOL   | 0x401     | 31    | EOL Mode. Normally, when the Z count of FIFO operations has been reached, the PDMA will close the packet with an 'EOP' indication. When this flag is set, the PDMA will instead trigger an EOL at the completion of Z.                                                                                                                                                                                                                                                                                      |
| Z     | 0x401     | 23:0  | FIFO count. This field specifies how many full DMA request operations comprise a complete packet. When the count has been reached, the PDMA will close the packet with an 'EOP' indication. If this parameter is set to NULL, then no packet delineation is supplied by the PDMA and all framing is controlled via the UDMA-P TR.                                                                                                                                                                           |

#### 11.3.1.4.2.5.2.4.4 AASRC RxFifoConfig (PSIL Address 0x405)

This register describes the FIFO list to be processed for this RX channel.

| Bits  | Field       | Reset | Description                                                                                                                                                                                                                                                                                                   |
|-------|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | GroupMode   | 0x0   | When set, the channel is in 'Group Mode'. It will look for Group Mode DMA requests, and access the Group Mode FIFOs. When clear, the channel is 'Stream Mode'. It will look for Stream FIFO DMA requests, and access the Stream Mode FIFOs.                                                                   |
| 30    | DmaReqReset | 0x0   | When set, resets any latched DMA request using the DmaReqMask. This bit is self-clearing. It should be used to synchronize the AASRC event status with the PDMA in the event that the AASRC has been previously used and it is not known if the PDMA may have latched, and is holding, previous DMA requests. |
| 23:20 | LastSlot    | 0x0   | This is the index (0-15) of the last slot in the RX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                     |

| Bits  | Field      | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16 | FirstSlot  | 0x0   | This is the index (0-15) of the first slot in the RX FIFO ordering table used by this channel. The ordering table is read to get the FIFO index to access for each slot, starting with the first and ending with the last.                                                                                                                                                                                                                                                                            |
| 15:0  | DmaReqMask | 0x0   | This field holds a set of flags indicating which AASRC DMA requests must fire in order for this channel to activate. In Steam Mode, these 16 flags correspond to the 16 DMA requests for each RX FIFO. The flags corresponding to all RX FIFOs involved with the channel should be set to 1. In Group Mode, these flags indicate which Group Mode DMA requests must fire. In this case, only bits 3:0 are relevant and only one bit should be set to 1 as a DMA channel only services a single group. |

#### 11.3.1.4.2.5.2.4.5 AASRC RxOrderTable0 (PSI-L Address 0x406)

This table is filled with FIFO index values. RX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all RX threads.

| Bits  | Field  | Reset | Description              |
|-------|--------|-------|--------------------------|
| 31:28 | Entry7 | 7     | RX FIFO Index for slot 7 |
| 27:24 | Entry6 | 6     | RX FIFO Index for slot 6 |
| 23:20 | Entry5 | 5     | RX FIFO Index for slot 5 |
| 19:16 | Entry4 | 4     | RX FIFO Index for slot 4 |
| 15:12 | Entry3 | 3     | RX FIFO Index for slot 3 |
| 11:8  | Entry2 | 2     | RX FIFO Index for slot 2 |
| 7:4   | Entry1 | 1     | RX FIFO Index for slot 1 |
| 3:0   | Entry0 | 0     | RX FIFO Index for slot 0 |

#### 11.3.1.4.2.5.2.4.6 AASRC RxOrderTable1 (PSI-L Address 0x407)

This table is filled with FIFO index values. RX channels reference a starting and ending 'slot' in this table for each transfer. The actual FIFO accessed by the DMA for each slot is determined by the FIFO index stored in this table. Note: This is a single register that is shared by all RX threads.

| Bits  | Field   | Reset | Description               |
|-------|---------|-------|---------------------------|
| 31:28 | Entry15 | 15    | RX FIFO Index for slot 15 |
| 27:24 | Entry14 | 14    | RX FIFO Index for slot 14 |
| 23:20 | Entry13 | 13    | RX FIFO Index for slot 13 |
| 19:16 | Entry12 | 12    | RX FIFO Index for slot 12 |
| 15:12 | Entry11 | 11    | RX FIFO Index for slot 11 |
| 11:8  | Entry10 | 10    | RX FIFO Index for slot 10 |
| 7:4   | Entry9  | 9     | RX FIFO Index for slot 9  |
| 3:0   | Entry8  | 8     | RX FIFO Index for slot 8  |

#### 11.3.1.4.2.5.2.5 PSI-L Source Thread Enables

PSI-L source threads must be enabled in order to process peripheral DMA requests and send data. When disabled, DMA requests are ignored.

Once a thread is paired, the TR has been set up and the enable is asserted, the channel is armed and ready to be triggered to perform the specified set of read transactions.

#### 11.3.1.4.2.5.3 Data Transfer

Packet reception is accomplished within the PDMA by moving data from structures that are located in memory accessible via the VBUSP Memory Interface(s) onto the Receive PSI-L Interface. On the Rx side of the PDMA, these transfers are always reads. Data is read from an attached memory mapped space and packed into the Rx Per Channel Buffer for that channel. At a later time, the data is moved from the Rx Per Channel FIFO to a remote peer DMA entity via the Rx PSI-L interface

The sequences of logical transactions that are performed by the PDMA on the Memory I/F during receive is dependent on the channel type. The following sections describe what happens for the different channel types.

##### 11.3.1.4.2.5.3.1 X-Y FIFO Mode Channel

The PDMA channel remains idle until a pulse is detected on the associated input DMA request event pin. Once the pulse is detected, the DMA sequentially issues a total of 'Y' parameter reads of 'X' parameter bytes from the data\_address specified in the tchan\_info parameter for the channel. Each read that the DMA performs is a single 'X' element in size (no large bursts). Once the total specified number of transactions has been completed, the channel returns to an idle state and waits until it is triggered again. The read transfers that are performed are accomplished as quickly as possible given availability of data in the Rx channelized FIFO, and given the arbitration that may occur as a result of other channels also using the same read unit.

###### 11.3.1.4.2.5.3.1.1 X-Y FIFO Burst Mode

The burst mode for XY is designed to allow the PDMA to burst across a FIFO region, while extracting out the 'sample size' from each data phase. For example, it can read a "burst" of multiple 32-bit words from a McASP, and grab only 24-bits from each data phase.

It uses the same registers as standard XY mode, where X is the encoded sample size, and Y is the number of samples to read/write per DMA request. Setting bit 31 of the XY register enables burst.

The following are the rules for enabling burst mode. Incompatible peripherals do not need to enable burst, or can enable it on RX without enabling it on TX.

- The VBUSP address will increment throughout the burst
- Bursts are sub-divided to fit into a 64-byte transfer window
- One sample is transferred for every bus data phase
  - Cannot burst one byte samples from a 16-bit peripheral on a 32-bit bus
  - Cannot burst 64-bit samples on a 32-bit bus (configure for 2 32-bit samples instead)
- PDMA 'gaps' the byte enables on writes as needed

##### 11.3.1.4.2.5.3.2 MCAN Mode Channel

The PDMA channel remains idle until a pulse is detected on the associated input DMA request event pin. The DMA event pins are mapped from the CAN filter event bits. The event bits determine the channel and one of two CAN buffers to use for the RX operation. This allows the RX buffers on the CAN to be configured in a ping/pong fashion, preventing the loss of CAN packet data. When an event is received, the PDMA starts copying bytes out of the corresponding CAN buffer. The number of bytes copied is equal to the value of the 'Y' parameter in the channel configuration. Once all data has been copied from the buffer, the PDMA transfers ownership of the buffer back to the CAN by writing a CAN register. It then waits for another RX DMA event. The PDMA can copy multiple CAN RX buffers to the same CPPI packet. It will not close out the CPPI packet until it has copied out a number of RX buffers equal to the 'Z' parameter in the channel configuration. On subsequent RX buffer copies, the MCAN skips the first 8 bytes of the RX buffer, which is the MCAN packet header.

The mapping of MCAN filter events to MCAN channels and buffer is important for properly configuring the DMA. The mapping is defined as follows.

| CAN FE2 | CAN FE1 | CAN FE0 | Description                            |
|---------|---------|---------|----------------------------------------|
| 0       | 0       | 0       | Not used                               |
| 0       | 0       | 1       | Not used                               |
| 0       | 1       | 0       | PDMA CAN channel offset 0, RX buffer 0 |

| CAN FE2 | CAN FE1 | CAN FE0 | Description                            |
|---------|---------|---------|----------------------------------------|
| 0       | 1       | 1       | PDMA CAN channel offset 0, RX buffer 1 |
| 1       | 0       | 0       | PDMA CAN channel offset 1, RX buffer 2 |
| 1       | 0       | 1       | PDMA CAN channel offset 1, RX buffer 3 |
| 1       | 1       | 0       | PDMA CAN channel offset 2, RX buffer 4 |
| 1       | 1       | 1       | PDMA CAN channel offset 2, RX buffer 5 |

By using two filter entries in the CAN, software can setup a ping/pong buffer for a particular RX packet ID. For example, the following two filter entries set up a ping/pong using RX buffers 0 and 1 for packet ID 5 on CAN RX channel 0.

| Filter Entry | Packet Match ID | Filter Event Bits |
|--------------|-----------------|-------------------|
| 0            | 5               | 0x2               |
| 1            | 5               | 0x3               |

#### 11.3.1.4.2.5.3.3 AASRC Channel

The AASRC channel is controlled primarily via the channel's RxFifoConfig register. This register holds 3 basic pieces of information:

- Whether the channel uses AASRC Stream Mode or Group Mode
- The slot range in the order table used (from designated first slot to designated last slot)
- The AASRC DMA request event(s) that must fire before the channel becomes active

The channel remains idle until a pulse is detected on ALL associated input DMA request event pins required by the RxFifoConfig setting. The pulses for the individual events are latched and held by the PDMA until they all arrive.

Once the channel activates, it starts reading FIFO index values from the RxOrderTable, starting at the configured 'First Slot' and ending with the 'Last Slot'. The actual FIFO indices used are obtained from the ordering table. For example, say FirstSlot=3 and LastSlot=5. If the first 6 slots of the ordering table were: 0, 2, 4, 6, 8, 10, the FIFOs read for the event would be 6, 8, and 10, because 'slot 3' of the table contains 6, and it would proceed through 'slot 5' of the table which contains 10.

The X and Y registers are still used as they are in a normal X-Y mode. When accessing each FIFO, the setting of X determines the sample byte width read from the FIFO. The value of 'Y' determines how many times the entire FIFO list is processed for each activation of the channel.

Once the total specified number of transactions has been completed, the channel returns to an idle state and waits until it is triggered again. The read transfers that are performed are accomplished as quickly as possible given availability of data in the TX channelized FIFO, and given the arbitration that may occur as a result of other channels also using the same write unit.

#### 11.3.1.4.2.5.4 Receive PSI-L Interface Transactions

When an entire word has been packed into the Rx Per Channel Buffer for a given channel, a one word data phase transfer is initiated for that channel/thread on the Rx PSI-L interface, and the data is popped from the Rx Per Channel FIFO. The value sources for the output pins on the PSI-L interface are described in [Table 11-87](#).

**Table 11-87. PSI-L Interface Output Pins**

| Pin               | Output Value / Source From PDMA                                                                                   |
|-------------------|-------------------------------------------------------------------------------------------------------------------|
| strm_o_req        | This signal is asserted when the PDMA determines that there is at least 1 word of data in its TP-CC output FIFO   |
| strm_o_sthread_id | Set equal to the TP-CC DMA channel number which is on the interface for this cycle                                |
| strm_o_dthread_id | Set equal to the target thread ID value given in the PSI-L pairing configuration registers for this DMA channel   |
| strm_o_data_type  | Will be set to the proper PSI-L data type. The PDMA can send config response, PSI info word 0, and PSI data word. |

**Table 11-87. PSI-L Interface Output Pins (continued)**

| Pin             | Output Value / Source From PDMA                                                                                                                                                                                                       |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| strm_o_wnum     | Set equal to the packing lane for the current word within a contiguous transfer. This value will start at 0 for each new TR and will increment for each subsequent data phase in the TR.                                              |
| strm_o_lastw    | This signal will be asserted coincident with eop.                                                                                                                                                                                     |
| strm_o_xcnt     | The xcnt will be equal to the data path width in bytes.                                                                                                                                                                               |
| strm_o_worden   | The worden will be modulated to indicate which 32-bit words are valid within each control type data phase.                                                                                                                            |
| strm_o_data     | The data will be packed/left justified to comply to the big endian data ordering as required in the PSI-L I/F specification.                                                                                                          |
| strm_o_sop      | This signal is asserted for 1 data phase at the beginning of each new TR or data transfer packet.                                                                                                                                     |
| strm_o_eop      | This signal is asserted for 1 data phase at the end of each TR or data transfer packet.                                                                                                                                               |
| strm_o_sol      | This signal is set to zero unless the EOL bit is set in PSI-L register 0x401, in which case, it is set for 1 data phase at the start of a new set of transactions designated by the count set in the Z field of PSI-L register 0x401. |
| strm_o_eol      | This signal is set to zero unless the EOL bit is set in PSI-L register 0x401, in which case, it is set for 1 data phase at the end of a set of transactions designated by the count set in the Z field of PSI-L register 0x401.       |
| strm_o_priv     | Set to zero.                                                                                                                                                                                                                          |
| strm_o_privid   | Set to zero.                                                                                                                                                                                                                          |
| strm_o_virtid   | Set to zero.                                                                                                                                                                                                                          |
| strm_o_secure   | Set to zero.                                                                                                                                                                                                                          |
| strm_o_interest | Set to zero.                                                                                                                                                                                                                          |
| strm_o_ready    | Always asserted as the PDMA is always able to accept credit returns.                                                                                                                                                                  |

#### 11.3.1.4.2.5.5 Rx Pause

The Host initiates a channel pause by setting the pause bit in RT enable register. The paused channel can be resumed by clearing the register bit.

#### 11.3.1.4.2.5.6 Rx Teardown

The Host initiates a RX channel teardown by setting the tdown bit in the RT enable register for the target RX channel. The PDMA communicates the teardown state to the UDMA-P through the PSI-L data channel, to ensure that the teardown is not seen by the UDMA-P until all the previous PDMA data for the channel has been flushed.

The PDMA does not stop reading peripheral data until it reaches a FIFO boundary, as configured through the 'X' and 'Y' parameters in the static TR. It always attempts to complete the 'Y' count for the current event being processed. Upon reaching a stopping point, the PDMA then clears the enable bit in the pairing register; however, the teardown bit remains set. No further packet processing occurs until the Host re-configures the channel. The teardown process propagates to the UDMA-P and its final status can be checked there.

#### 11.3.1.4.2.5.7 Rx Channel Reset

In the unlikely event that channel synchronization is corrupted, a channel may fail to teardown gracefully. If this occurs, the channel may be reset by clearing the enable bit in the PSI-L enable register. This causes a local reset of the entire channel, including TR and pairing registers. Note that it does not reset the UDMA-P peer. Resetting the UDMA-P peer is also required before re-initializing and re-pairing the channel.

#### 11.3.1.4.2.5.8 Rx Debug/State Register

The debug/state registers are supplied to give software applications additional information about the PDMA than they would need in regular operation, but which may be useful in debug situations. The registers appear on the PSI-L bus, near the static TR registers. For receive, they are defined as in [Table 11-88](#).

**Table 11-88. Rx Debug/State Register**

| Name     | PSIL Addr | Field | Description                                                                                                                                                                                                                                                                                                                                                                          |
|----------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z*       | 0x402     | 31:16 | This field holds the lower 12 bits of the current Z count for legacy purposes. See register 0x40F below for the full width version of Z.                                                                                                                                                                                                                                             |
| Y        | 0x402     | 15:0  | This field holds the current Y count. In X-Y FIFO mode, this is the number of X sized samples yet to be read from the peripheral for the DMA event being serviced. In MCAN mode, this field holds the next read offset to use when read to the CAN RX buffer.                                                                                                                        |
| InEvent  | 0x403     | 31    | When set, the PDMA is in the middle of processing a FIFO event.                                                                                                                                                                                                                                                                                                                      |
| Tdown    | 0x403     | 30    | When set, the PDMA is processing a teardown operation. This bit is set simultaneously with the teardown bit in the source (RX) RT enable register. This bit will clear when the teardown is complete, regardless as to if the teardown bit in the pairing register is cleared or not. The teardown will propagate to the UDMA-P and its full completion status can be checked there. |
| Pause    | 0x403     | 29    | When set, the PDMA is stopped in a paused state. This bit will clear if the channel is un-paused or disabled.                                                                                                                                                                                                                                                                        |
| Space    | 0x403     | 28    | When set, there is a non-zero amount of internal FIFO space available to hold new read data.                                                                                                                                                                                                                                                                                         |
| XSpace   | 0x403     | 27    | When set, there is a enough internal FIFO space available to start servicing a peripheral DMA event.                                                                                                                                                                                                                                                                                 |
| Buffer   | 0x403     | 26    | This is the current RX buffer (0/1) for the current MCAN receive operation.                                                                                                                                                                                                                                                                                                          |
| State    | 0x403     | 23:20 | This code reflects the current state of the PDMA channel, and is specific to the current implementation.                                                                                                                                                                                                                                                                             |
| EventCnt | 0x403     | 19:16 | This field holds the number of backlogged DMA events yet to be serviced.                                                                                                                                                                                                                                                                                                             |
| Z        | 0x40F     | 31:0  | This field holds the full width value of the current Z count. In X-Y FIFO mode, this field holds the 1 based FIFO count of the FIFO being currently read, or the number of FIFO completions when the current operation completes. In MCAN mode, this field holds the zero based buffer index of the buffer currently being read, or the number of previously completed buffers.      |

### 11.3.1.5 PDMA Registers

## Chapter 12 **Peripherals**

---



This chapter describes the various peripheral modules instantiated in the device.

|                                                     |      |
|-----------------------------------------------------|------|
| <b>12.1 Audio Peripherals</b> .....                 | 1024 |
| <b>12.2 General Connectivity Peripherals</b> .....  | 1098 |
| <b>12.3 High-speed Serial Interfaces</b> .....      | 1243 |
| <b>12.4 Memory Interfaces</b> .....                 | 1351 |
| <b>12.5 Industrial and Control Interfaces</b> ..... | 1578 |
| <b>12.6 Camera Subsystem</b> .....                  | 1731 |
| <b>12.7 Timer Modules</b> .....                     | 1762 |
| <b>12.8 Internal Diagnostics Modules</b> .....      | 1808 |

## 12.1 Audio Peripherals

### 12.1.1 Multichannel Audio Serial Port (MCASP)

This section describes the Multichannel Audio Serial Port (MCASP).

#### 12.1.1.1 MCASP Overview

This section introduces the Multichannel Audio Serial Port (MCASP) module and describes its main functions and connections in the device.

The MCASP functions as a general-purpose audio serial port are optimized to the requirements of various audio applications. The MCASP module can operate in both transmit and receive modes. The MCASP is useful for time-division multiplexed (TDM) stream, Inter-IC Sound (I2S) protocols reception and transmission as well as for an inter-component digital audio interface transmission (DIT). The MCASP has the flexibility to gluelessly connect to a Sony/Philips digital interface (S/PDIF) transmit physical layer component.

Although inter-component digital audio interface reception (DIR) mode (this is, S/PDIF stream receiving) is not natively supported by the MCASP module, a specific TDM mode implementation for the MCASP receivers allows an easy connection to external DIR components (for example, S/PDIF to I2S format converters).

Figure 12-1 shows the MCASP modules overview.



- A.  $j$  represents a valid instance of MCASP in a domain
- B.  $i$  represents the maximum number of MCASP<sub>j</sub>\_AXR signals - 1.

**Figure 12-1. MCASP Modules Overview**

#### 12.1.1.1.1 MCASP Features

Each MCASP module includes the following main features:

- Independent serializer for each AXRx channel of each MCASP module
- Clock stop request/acknowledge protocol
- A single 32-bit buffer per serializer for transmit and receive operations
- Interconnect interface port for CBASSO

- Two independent clock generator modules for transmit and receive (clocking flexibility allows the MCASP to receive and transmit at different rates. For example, the MCASP can receive data at 48 kHz, but output up-sampled data at 96 kHz or 192 kHz)
- Each MCASP module functional clock can be generated:
  - Internally (controller mode)
  - Supplied over MCASP serial interface (target mode)
  - Has a controllable functional clock divide ratio
- Independent transmit and receive modules, each includes:
  - Programmable clock and frame sync generator
  - TDM streams from 2 to 32, and 384 time slots
  - Support for time slot sizes of 8, 12, 16, 20, 24, 28, and 32 bits
  - Data formatter for bit manipulation
- Glueless connection to audio Analog-to-Digital Converters (ADC), Digital-to-Analog Converters (DAC), codec, digital audio interface receiver (DIR), and S/PDIF transmit physical layer components
- Wide variety of I2S and similar bit-stream format
- Integrated digital audio interface transmitter (DIT):
  - S/PDIF, IEC60958-1, AES-3 formats
  - Enhanced channel status/user data RAM
- 384-slot TDM with external digital audio interface receiver (DIR) device
  - For DIR reception, an external DIR receiver integrated circuit should be used with I2S output format and connected to the MCASP receive section
- Support for 2 × DMA requests (one per direction):
  - 1 level-sensitive transmit direct memory access (DMA) request common for all of the MCASP serializers
  - 1 level-sensitive receive direct memory access (DMA) request common for all of the MCASP serializers
  - All transmit DMA requests are mapped to the device DMA controllers
- One transmit interrupt request common for all serializers
- One receive interrupt request common for all serializers
- Each of the Rx and Tx interrupts is propagated to different host processors via the device Interrupts

---

**Note**

Because a serializer receive and transmit channels data is shared on the same MCASP data pin, user can choose to have either Tx or Rx function from a serializer, not both at the same time.

---

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### **12.1.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

### 12.1.1.2 MCASP Environment

This section describes the MCASP application fields from an environment point of view (external connections). This section also lists the possible interfaces and describes the protocol and data format used in each case.

#### 12.1.1.2.1 MCASP Signals

Figure 12-2 shows all of the MCASP interface signals.



#### Note

i represents a MCASP instance. See the device datasheet for available domains and MCASP instances.

n represents a AXR signal from a MCASP instance. See the device datasheet for available domains and MCASP instances.

**Figure 12-2. MCASP Interface Signals**

Table 12-1 describes the MCASP I/O signals.

**Table 12-1. MCASP I/O Signals**

| Module Pin                         | Device Level Signal          | I/O <sup>(1)</sup> | Description                              | Module Pin Reset Value <sup>(2)</sup> |
|------------------------------------|------------------------------|--------------------|------------------------------------------|---------------------------------------|
| <b>MCASPi<sup>(3)</sup> module</b> |                              |                    |                                          |                                       |
| AXR0                               | MCASPi <sup>(3)</sup> _AXR0  | I/O                | Audio transmit/receive data - channel 0  | HiZ                                   |
| AXR1                               | MCASPi <sup>(3)</sup> _AXR1  | I/O                | Audio transmit/receive data - channel 1  | HiZ                                   |
| AXR2                               | MCASPi <sup>(3)</sup> _AXR2  | I/O                | Audio transmit/receive data - channel 2  | HiZ                                   |
| AXR3                               | MCASPi <sup>(3)</sup> _AXR3  | I/O                | Audio transmit/receive data - channel 3  | HiZ                                   |
| AXR4                               | MCASPi <sup>(3)</sup> _AXR4  | I/O                | Audio transmit/receive data - channel 4  | HiZ                                   |
| AXR5                               | MCASPi <sup>(3)</sup> _AXR5  | I/O                | Audio transmit/receive data - channel 5  | HiZ                                   |
| AXR6                               | MCASPi <sup>(3)</sup> _AXR6  | I/O                | Audio transmit/receive data - channel 6  | HiZ                                   |
| AXR7                               | MCASPi <sup>(3)</sup> _AXR7  | I/O                | Audio transmit/receive data - channel 7  | HiZ                                   |
| AXR8                               | MCASPi <sup>(3)</sup> _AXR8  | I/O                | Audio transmit/receive data - channel 8  | HiZ                                   |
| AXR9                               | MCASPi <sup>(3)</sup> _AXR9  | I/O                | Audio transmit/receive data - channel 9  | HiZ                                   |
| AXR10                              | MCASPi <sup>(3)</sup> _AXR10 | I/O                | Audio transmit/receive data - channel 10 | HiZ                                   |
| AXR11                              | MCASPi <sup>(3)</sup> _AXR11 | I/O                | Audio transmit/receive data - channel 11 | HiZ                                   |
| AXR12                              | MCASPi <sup>(3)</sup> _AXR12 | I/O                | Audio transmit/receive data - channel 12 | HiZ                                   |

Table 12-1. MCASP I/O Signals (continued)

| Module Pin                        | Device Level Signal          | I/O <sup>(1)</sup> | Description                                                             | Module Pin Reset Value <sup>(2)</sup> |
|-----------------------------------|------------------------------|--------------------|-------------------------------------------------------------------------|---------------------------------------|
| AXR13                             | MCASPi <sup>(3)</sup> _AXR13 | I/O                | Audio transmit/receive data - channel 13                                | HiZ                                   |
| AXR14                             | MCASPi <sup>(3)</sup> _AXR14 | I/O                | Audio transmit/receive data - channel 14                                | HiZ                                   |
| AXR15                             | MCASPi <sup>(3)</sup> _AXR15 | I/O                | Audio transmit/receive data - channel 15                                | HiZ                                   |
| ACLKX                             | MCASPi <sup>(3)</sup> _ACLKX | I/O                | Transmit bit clock                                                      | HiZ                                   |
| AFSX                              | MCASPi <sup>(3)</sup> _AFSX  | I/O                | Transmit frame synchronization                                          | HiZ                                   |
| ACLKR                             | MCASPi <sup>(3)</sup> _ACLKR | I/O                | Receive bit clock                                                       | HiZ                                   |
| AFSR                              | MCASPi <sup>(3)</sup> _AFSR  | I/O                | Receive frame synchronization                                           | HiZ                                   |
| MCASPi <sup>(3)</sup> _AHCLKX_I/O | AUDIO_EXT_REFCLK[0-1]        | I/O                | Transmit high-frequency controller clock. See <i>Module Integration</i> | HiZ                                   |
| MCASPi <sup>(3)</sup> _AHCLKR_I/O | AUDIO_EXT_REFCLK[0-1]        | I/O                | Receive high-frequency controller clock. See <i>Module Integration</i>  | HiZ                                   |

(1) I = Input; O = Output; I/O = Bidirectional

(2) HiZ = High Impedance

(3) i represents a MCASP instance. See the device datasheet for available domains and MCASP instances.

#### Note

MCASPi\_AHCLKR\_I/O and MCASPi\_AHCLKX\_I/O signals are multiplexed to AUDIO\_EXT\_REFCLK[0-1] device pins.

#### Note

For MCASPi\_ACLKR\_I/O, MCASPi\_ACLKX\_I/O, MCASPi\_AHCLKR\_I/O and MCASPi\_AHCLKX\_I/O signals to work properly, the RXACTIVE bit of the appropriate CTRLMMR\_PADCONFIGy registers should be set to 0x1 because of retiming purposes.

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

#### Note

A serializer AXR data pin is shared between the transmit and receive logic of that serializer. The direction of data is determined in the MCASP\_PDIR register and the function (Tx or Rx) is selected in the corresponding serializer control register MCASP\_SRCTLn (n = 0 to 15).

### 12.1.1.2.2 MCASP Protocols and Data Formats

#### 12.1.1.2.2.1 Protocols Supported

The MCASP supports a wide variety of protocols:

- Transmit section supports:
  - Wide variety of I2S and similar bit-stream formats
  - TDM streams from 2 to 32 time slots
  - S/PDIF, IEC60958-1, AES-3 formats
- Receive section supports:
  - Wide variety of I2S and similar bit-stream formats
  - TDM streams from 2 to 32 time slots

- TDM stream of 384 time slots specifically designed for easy interface to external digital interface receiver (DIR) device transmitting DIR frames to MCASP using the I2S protocol (one time slot for each DIR subframe)

The transmit and receive sections of the module may be individually programmed to support the following options on the basic serial protocol:

- Programmable clock and frame sync polarity (rising or falling edge): ACLKR/X, AFSR/X and AHCLKR/X\_I/O
- Slot length (number of bits per time slot): 2, 4, 8, 12, 16, 20, 24, 28, 32 bits supported
- Word length (bits per word): 2, 4, 8, 12, 16, 20, 24, 28, 32 bits; always less than or equal to the time slot length
- First-bit data delay: 0, 1, 2 bit clocks
- Left/right alignment of word inside slot
- Bit order: MSB first or LSB first
- Bit mask/pad/rotate function
  - Automatically aligns data internally in either Q31 or integer formats
  - Automatically masks nonsignificant bits (sets to 0, 1, or extends value of another bit)

---

**Note**

In I2S mode, the transmit and receive sections can support simultaneous transfers on up to all serial data pins operating as 192 kHz stereo channels.

---

In DIT mode for MCASP, additional features of the transmitters are:

- Transmit-only mode 384 time slots (subframe) per frame
- Biphasic encoded 3.3 V Output
- Channel status RAM (384 bits)
- User data RAM (384 bits)
- Support for consumer and professional applications
- Separate valid bit (V) for subframe A, B
- Stereo Support Only (Mono means send data 2 × via software)

In DIT mode, the transmitter can support a 192 kHz frame rate (stereo) on up to all serial data pins simultaneously (note that the internal bit clock for DIT runs two times faster than the equivalent bit clock for I2S mode, due to the need to generate Biphasic Mark Encoded Data).

---

**Note**

The MCASP does NOT natively support DIR-mode reception (this is, receiving in the S/PDIF format). To allow this, the MCASP can use a DIR-input to I2S-output converter implemented by an external device (this is, external DIR component). To facilitate reception in this case, the TDM mode of MCASP receivers logic is extended to support a non-standard 384-slot TDM stream.

---

**Note**

An external transceiver must be connected to the MCASP port in the device to translate the electrical signals delivered by the MCASP (1.2 V or 1.8 V LVCMS levels) to the electrical levels of the S/PDIF standard.

---

#### **12.1.1.2.2 Definition of Terms**

The serial bitstream transmitted or received by a MCASP serializer is a long sequence of 1s and 0s on an audio transmit/receive pins AXRn. However, the sequence has a hierarchical organization that can be described in terms of frames of data, slots, words, and bits.

A basic synchronous serial interface consists of three important components: clock, frame sync, and data. Figure 12-3 shows two of the three basic components: the clock signal (ACLKX/ACLKR) and the data signals

AXRn. [Figure 12-3](#) does not specify whether the clock is for transmit (ACLKX) or receive (ACLKR) because the definitions of terms apply to both receive and transmit interfaces. In operation, each transmitter and receiver uses the signals ACLKX and ACLKR as serial clock, respectively. Optionally, a receiver can use ACLKX as the serial clock when a transmitter and receiver (not from the same serializer) of the MCASP are configured to operate synchronously.

- Bit:

A bit is the smallest entity in the serial data stream. The beginning and end of each bit is marked by an edge of the serial clock. The duration of a bit is a serial clock period. A '1' is represented by a logic high on AXRn pins for the entire duration of the bit. A 0 is represented by a logic low on an AXRn pin for the entire duration of the bit.

- Word:

A word is a group of bits that make up the data being transferred between the MCASP and the external device. [Figure 12-3](#) shows an 8-bit word.

- Slot:

A slot consists of the bits that make up the word and can consist of additional bits used to pad the word to a convenient number of bits for the interface between the MCASP and the external device. In [Figure 12-3](#), the audio data consists of only 8 bits of useful data (8-bit word), but it is padded with four 0s (12-bit slot) to satisfy the desired protocol in interfacing to an external device. Within a slot, the bits can be shifted out of the MCASP on an AXRn pin with either MSB or LSB first.

When the word size is smaller than the slot size, the word can be aligned to the left of the slot (beginning) or to the right of the slot (end). The additional bits in the slot not belonging to the word can be padded with 0, 1, or with one of the bits (typically, the MSB or LSB) from the data word, this is, left-aligned words within a slot are terminated with padding bits and right-aligned words within a slot are preceded by padding bits to fit in the slot size. [Figure 12-4](#) shows these options.



mcasp-003

**Figure 12-3. Definition of Bit, Word, and Slot**


mcasp-004

**Figure 12-4. Bit Order and Word Alignment Within a Slot Examples**

- Frame

The third basic element of a synchronous serial interface is the frame synchronization signal, also referred to as frame sync in this chapter. A frame contains one or multiple slots, as determined by the desired protocol.

**Figure 12-5** shows an example frame of data and the frame definitions. In operation, the transmitter uses AFSX, and the receiver - AFSR signal. **Figure 12-5** does NOT specify whether the frame sync (FS) is for transmit (AFSX) or receive (AFSR) because the definitions of terms apply to both receive and transmit interfaces. In operation, each transmitter/receiver uses AFSX/AFSR as a frame synchronization signal, respectively. Optionally, the receiver can use AFSX as the frame sync when the transmitter and receiver of the MCASP are configured to operate synchronously. This example shows two slots in a frame (I2S format) and a frame-sync (FS) duration of a slot length.

This section shows only the generic definition of the frame sync. For more information about the frame-sync formats required for the transfer modes and protocols (TDM-mode and DIT-mode supported formats), see [Section 12.1.1.2.2.3, TDM Format](#) and [Section 12.1.1.2.2.5, S/PDIF-Coding Format](#).

---

**Note**

All of the MCASP serializers share the same, device pad accessible, clock and frame signals, as follows:

- AHCLKX\_I/O, ACLKX and AFSX for the transmitting section
  - AHCLKR\_I/O, ACLKR and AFSR for the receiving section
- 



**Figure 12-5. Definition of Frame and Frame-Sync Width**

The following terms are used throughout this chapter:

- TDM: Time-division multiplexed. See [Section 12.1.1.2.2.3, TDM Format](#) for details on the TDM protocol.
- I2S: Inter-Integrated Sound protocol, commonly used on audio interfaces. The MCASP supports the I2S protocol as part of the TDM mode (when configured as a 2-slot frame).
- DIT: Digital audio interface transmit. The MCASP supports transmitting in S/PDIF format on each AXRn data pin.
- DIR: Digital audio interface receive. The MCASP does NOT natively support receiving in S/PDIF format on AXRn data pins and requires an external DIR-to-TDM or DIR-to-I2S converter chip for a DIR-frame reception.
- Slot or time slot: For DIT/DIR format, a MCASP time slot corresponds to a DIT/DIR subframe.

#### 12.1.1.2.2.3 TDM Format

The TDM format is used to transfer data between the host CPU and one or more analog-to-digital converter (ADC), digital-to-analog converter (DAC), or S/PDIF receiver (DIR) devices. An example for a 6-slot (channel) TDM transmission on one MCASP data pin - AXRn is illustrated on [Figure 12-6](#).



(1) - Frame sync duration of 1 slot - length is shown. A single bit - duration of FS is also supported

(2) - Slot 0 of AXRn stream is being offset with 0-, 1-, and 2- clock cycle delay from the frame sync, respectively.

mcasp-006

**Figure 12-6. TDM Format - 6 channel example**

The TDM format uses three signals in a basic synchronous serial interface: data (AXRn), clock (CLK) and frame sync (FS). The data signal present on AXRn pin is fully synchronous to the serial clock (ACLKX or ACLKR). The data bits are grouped into words and slots (see also [Section 12.1.1.2.2.2](#)), the latter being also referred to as the "time-slots" or "channels" in TDM terminology. A frame consists of multiple time-slots. Each TDM frame is marked by the frame sync signal (AFSX or AFSR). The TDM transfer is continuous and periodic, with no delays between slots.

Within a certain frame, the last bit of slot N is followed immediately on the next serial clock with the first bit of the next slot N+1. On the boundary between two adjacent TDM-frames, the last bit of the last slot from the frame M, is followed immediately on the next clock cycle with the first bit of the first slot from the next frame M+1. For MCASP, there is an option to offset the first bit of the first slot with a 0-, 1-, or 2-cycle delay from the frame sync signal.

The frame sync - AFSX/AFSR only marks the beginning of slot 0 and start of a new frame. Since it does not determine the boundaries of a slot, there is a requirement for a connected transmitter and receiver to agree on the number of transferred bits per slot.

In a typical audio system involving MCASP module, a single TDM data frame is transferred during each sample period  $T_s$  of a data converter. The user has following choices to implement multiple channels:

- Use more data slots (on a price of higher speed serial clock) per frame transmitted/received on just one of the available MCASP data pins AXRn.
- Use less number of slots per TDM frame (requires a slower serial clock), making them available on several of the MCASP pins AXRn.

#### 12.1.1.2.2.4 I2S Format

The TDM transfer mode of the MCASP supports the I2S format when frame is configured to have 2 slots. The I2S format is specifically designed to transfer a stereo channel (left and right) over a single data pin AXRn. The "Slots" are also commonly referred to as "channels". The frame width duration in the I2S format equals size of a slot. The frame signal is also referred to as "word select" in the I2S format.

The I2S protocol is illustrated on [Figure 12-7](#).



(1) - The example shows I2S data MSB-first transmission with 1-clock cycle delay between FS and data MSB

mcasp-007

**Figure 12-7. I2S Format Overview**

#### 12.1.1.2.2.5 S/PDIF Coding Format

The MCASP transmitter supports the S/PDIF format with 3.3 V biphase-mark encoded output. The S/PDIF format is supported by the DIT- transfer mode of the MCASP. This section briefly discusses the S/PDIF coding format.

---

#### Note

The DIR- reception of S/PDIF format frames is NOT natively supported from the device MCASP. For this purpose, an external DIR-to-TDM transfer mode adapter can be used between the remote device S/PDIF transmitter output and the MCASP TDM-only compatible receiver input.

---

#### 12.1.1.2.2.5.1 Biphase-Mark Code

In S/PDIF format, the digital signal is coded using the biphase-mark code (BMC). For each serializer transmitter  $n$ , the clock, frame, and data are embedded in only one signal - the data signal  $AXR_n$ . In the BMC system, each data bit is encoded into two logical states (00, 01, 10, or 11) at the pin. These two logical states form a cell. The duration of the cell, which equals the duration of the data bit, is called a time interval. A logical 1 is represented by two transitions of the signal within a time interval, which corresponds to a cell with logical states 01 or 10. A logical 0 is represented by one transition within a time interval, which corresponds to a cell with logical states 00 or 11. In addition, the logical level at the start of a cell is inverted from the level at the end of the previous cell. [Figure 12-8](#) and [Table 12-2](#) show how data is encoded to the BMC format.

As shown in [Figure 12-8](#), the clock frequency is twice the unencoded data bit rate. In addition, the clock is always programmed to  $128 \times f_s$ , where  $f_s$  is the sample rate (see [Section 12.1.1.2.2.5.3, Frame Format](#), for details on how this clock rate is derived based on the S/PDIF format). The device receiving in S/PDIF format can recover the clock and frame information from the BMC signal.



**Figure 12-8. Biphase-Mark Code**

**Table 12-2. Biphase-Mark Encoder**

| Data (Unencoded) | Previous State at Pin AXRn | BMC-Encoded Cell Output at Pin AXRn |
|------------------|----------------------------|-------------------------------------|
| 0                | 0                          | 11                                  |
| 0                | 1                          | 00                                  |
| 1                | 0                          | 10                                  |
| 1                | 1                          | 01                                  |

#### 12.1.1.2.2.5.2 S/PDIF Subframe Format

Every audio sample transmitted in a subframe consists of 32 S/PDIF time intervals (or cells), numbered 0 to 31. Figure 12-9 shows a subframe.

- Time intervals 0–3 carry one of the three permitted preambles to signify the type of audio sample in the current subframe. The preamble is not encoded in BMC format, and therefore the preamble code can contain more than two consecutive 0 or 1 logical states in a row. See Table 12-3.
- Time intervals 4–27 carry the audio sample word in linear 2s-complement representation. The MSB is carried by time interval 27. When a 24-bit coding range is used, the LSB is in time interval 4. When a 20-bit coding range is used, time intervals 8–27 carry the audio sample word with the LSB in time interval 8. Time intervals 4–7 may be used for other applications and are designated auxiliary sample bits.
- If the source provides fewer bits than the interface allows (20 or 24), the unused LSBs are set to logical 0. For a nonlinear PCM audio application or a data application, the main data field can carry any other information.
- Time interval 28 carries the validity bit (V) associated with the main data field in the subframe.
- Time interval 29 carries the user data channel (U) associated with the main data field in the subframe.
- Time interval 30 carries the channel status information (C) associated with the main data field in the subframe. The channel status indicates if the data in the subframe is digital audio or some other type of data.
- Time interval 31 carries a parity bit (P) such that time intervals 4–31 carry an even number of 1s and an even number of 0s (even parity). As listed in Table 12-3, the preambles (time intervals 0–3) are also defined with even parity.



**Figure 12-9. S/PDIF Subframe Format**

As listed in [Table 12-3](#), the MCASP DIT generates only one polarity of preambles, and it assumes the previous logical state is 0. This is because the MCASP assures an even-polarity encoding scheme when transmitting in DIT mode. If an underrun condition occurs, the DIT resynchronizes to the correct logic level on the AXRn pin before continuing with the next transmission.

**Table 12-3. Preamble Codes**

| Preamble Code <sup>(1)</sup> | Previous Logical State | Logical States on pin AXRn <sup>(2)</sup> | Description                     |
|------------------------------|------------------------|-------------------------------------------|---------------------------------|
| B (or Z)                     | 0                      | 1110 1000                                 | Start of a block and subframe 1 |
| M (or X)                     | 0                      | 1110 0010                                 | Subframe 1                      |
| W (or Y)                     | 0                      | 1110 0100                                 | Subframe 2                      |

(1) Historically, preamble codes are referred to as B, M, and W. For use in professional applications, preambles are referred to as Z, X, and Y, respectively.

(2) The preamble is not BMC-encoded. Each logical state is synchronized to the serial clock. These eight logical states make up time slots (cells) 0 to 3 in the S/PDIF stream.

#### 12.1.1.2.2.5.3 Frame Format

An S/PDIF frame is composed of two subframes (see [Figure 12-10](#)). For linear coded audio applications, the rate of frame transmission normally corresponds exactly to the source sampling frequency  $f_s$ . The S/PDIF format clock rate is therefore  $128 \times f_s$  ( $128 = 32$  cells per subframe  $\times 2$  clocks per cell  $\times 2$  subframes per sample). For example, for an S/PDIF stream at a 192-kHz sampling frequency, the serial clock is  $128 \times 192$  kHz = 24.58 MHz.

In 2-channel operation mode, the samples taken from both channels are transmitted by time multiplexing in consecutive subframes. Both subframes contain valid data (cell 28 validity bits for A- and B- channels, both set to '0'). The first subframe (left or A channel in stereophonic operation and primary channel in monophonic operation) normally starts with preamble M. However, the preamble of the first subframe changes to preamble B once every 192 frames to identify the start of the block structure used to organize the channel status information. The second subframe (right or B channel in stereophonic operation and secondary channel in monophonic operation) always starts with preamble W.

In single-channel operation mode in a professional application, the frame format is the same as in the 2-channel mode. Data is carried in the first subframe and may be duplicated in the second subframe. If the second subframe is not carrying duplicate data, cell 28 (validity bit) is set to logical 1.



**Figure 12-10. S/PDIF Frame Format**

**12.1.1.3 Integration**

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.1.1.4 MCASP Functional Description

In the text throughout this section a single instance of MCASP is described assuming that all modules are functionally identical. For module availability and integration differences, see [Section 12.1.1.2, MCASP Environment, and Module Integration](#).

##### 12.1.1.4.1 MCASP Block Diagram

**Figure 12-11. MCASP Module Block Diagram**

---

##### Note

The internal and external clocks mentioned in this section are with respect to clock and frame-sync generator modules.

---

#### 12.1.1.4.2 MCASP Clock and Frame-Sync Configurations

There are three scenarios to provide clock source signals for the Tx part and four scenarios for the Rx part of the MCASP serializers. The first three scenarios are identical between the Tx and Rx part of the MCASP. They feature an asynchronous operation between receiver and transmitter channels using independent Tx/Rx bit rate clock sources (either internal or external).

In the first scenario, the transmit - XCLK and receive - RCLK serial clocks (clock at the bit rate) are generated internally by passing through a couple of clock dividers off the internal functional clock source (AUXCLK). In this case, the bit rate clock is generated internally and is driven out on the pin ACLKX for the Tx part and pin ACLKR for the Rx part, respectively. An internally generated high-frequency clock can be optionally driven out onto the AHCLKX pin for the Tx part to serve as a reference clock for other components in the system.

In the second scenario, an external for the device clock, is passed on the ACLKX (for the TX part) and ACLKR (for the RX part) pins which are configured as inputs. In this case the Rx- /Tx- high-speed clock logic is bypassed for the XCLK/RCLK generation.

In the third (mixed) scenario, an externally driven (controller) high-frequency clock is applied on the AHCLKX (for the TX part) pin, which is configured as input. In this case the AHCLKX clock frequency can be divided down via programming the ACLKX associated divider to produce the necessary bit rate clock. The high-speed clock divider can NOT be used.

In the fourth clock generation scenario the bit rate clock for MCASP receivers - RCLK is derived from the bit rate clock of the MCASP transmitters - XCLK for a synchronous operation between transmitters and receivers. Hence, the whole receiver clock generator logic is bypassed.

A typical role of the MCASP frame sync signal is to carry the left/right clock (LRCLK) signal when transmitting and receiving stereo data.

For an asynchronous operation, the AFSX (Tx part) and AFSR (Rx part) frame synchronization signals can be sourced internally or delivered externally independently for the Tx and Rx channels. During synchronous operation the receive frame sync - AFSR signal is derived from the transmit frame sync - AFSX signal. A synchronous and asynchronous mode applies to bit rate clock and frame sync signals at the same time.

##### 12.1.1.4.2.1 MCASP Transmit Clock

The transmit high-speed and transmit clock configuration is controlled by the following registers:

- [MCASP\\_ACLKXCTL](#)
- [MCASP\\_AHCLKXCTL](#)

In case, the transmit bit clock, ACLKX, is generated internally, the [MCASP\\_ACLKXCTL\[5\]](#) CLKXM bit must be set to 1. Thus, the clock is divided down by a programmable bit clock divider (the [MCASP\\_ACLKXCTL\[4-0\]](#) CLKXDIV bit field) from the source signal.

If the transmit high-frequency controller clock, AHCLKX, is also sourced internally (that is first scenario described in [Section 12.1.1.4.2](#), the [MCASP\\_AHCLKXCTL\[15\]](#) HCLKXM bit must be set to 1. Thus, the clock is divided

down by a programmable high-clock divider (the *MCASP\_AHCLKXCTL[11-0]* HCLKDIV bit field) from the MCASP internal clock source AUXCLK.

Internally, the MCASP always shifts transmit data at the rising edge of the internal transmit clock - XCLK, (see [Figure 12-12](#)). The CLKXP mux determines if ACLKX needs to be inverted to become XCLK. If *MCASP\_ACLKXCTL[7]* CLKXP = 0, the CLKXP mux directly passes ACLKX signal to XCLK. As a result, the MCASP shifts transmit data at the rising edge of ACLKX. If *MCASP\_ACLKXCTL[7]* CLKXP = 1, the CLKX mux passes the inverted version of ACLKX to XCLK. As a result, the MCASP shifts transmit data at the falling edge of ACLKX.

It can be seen in [Figure 12-12](#) that XCLK is propagated to the Rx clock logic, to allow an internally synchronous operation between MCASP transmitters and receivers. This is used for example in the MCASP loopback mode.

#### Note

The polarity of ACLKX can be controlled in the *MCASP\_ACLKXCTL[7]* CLKXP bit, regardless of ACLKX signal being internally or externally sourced.

In addition, there is an option to invert polarity of the AHCLKX controller high speed clock via writing the *MCASP\_AHCLKXCTL[14]* HCLKXP bit.

#### Note

In a similar way, the polarity of AHCLKX clock can be controlled in the *MCASP\_AHCLKXCTL[14]* HCLKXP bit, regardless of the AHCLKX signal being internally or externally sourced.

[Figure 12-12](#) presents the block diagram of the transmit clock generator.



**Figure 12-12. Transmit Clock Generator Block Diagram**

---

### Note

In this device:

- ACLKX is mapped on the device ball ACLKX
- internal AHCLKX is mapped on the device balls AUDIO\_EXT\_REFCLK[0-1]
- external AHCLKX is mapped on MCASPi\_AHCLKX clock from the Device Configuration

For more information about MCASP integration, see [Section 12.1.1.2, MCASP Environment](#), and [Module Integration](#).

---

#### 12.1.1.4.2.2 MCASP Receive Clock

The MCASP receive clock generator is built on a very similar to the transmit clock generator (but independent) circuit.

The receive clock configuration is controlled by the following registers:

- *MCASP\_ACLKRCTL*
- *MCASP\_AHCLKRCTL*

In case, the receive bit clock, ACLKR, is generated internally (but asynchronously to XCLK), the *MCASP\_ACLKRCTL[5]* CLKRM bit must be set to 1. Thus, the clock is divided down by a programmable bit clock divider (the *MCASP\_ACLKRCTL[4-0]* CLKRDIV bit field) from the source signal.

If the receive high-frequency controller clock, AHCLKR, is also sourced internally (that is, first scenario described in [Section 12.1.1.4.2](#)) and the *MCASP\_AHCLKRCTL[15]* HCLKRM bit must be set to 1. Thus, the clock is divided down by a programmable high-clock divider (the *MCASP\_AHCLKRCTL[11-0]* HCLKRDIV bit field) from the MCASP internal clock source AUXCLK.

---

### Note

The polarity of ACLKR can be controlled in the *MCASP\_ACLKRCTL[7]* CLKRP bit, regardless of ACLKR signal being internally or externally sourced.

In a similar way, the polarity of AHCLKR clock can be controlled in the *MCASP\_AHCLKRCTL[14]* HCLKRP bit, regardless of the AHCLKR signal being internally or externally sourced.

---

There is an option for the MCASP receiver to be configured to operate synchronously to the ACLKX and AFSX signals. The XCLK output of the Tx Clock generator (see [Figure 12-12](#) and [Figure 12-13](#)) becomes source of the receive clock (RCLK output), when the *MCASP\_ACLKRCTL[6]* ASYNC bit in the transmit clock control register is set to '0b0'. For more information, refer to [Section 12.1.1.4.2.4](#).

[Figure 12-13](#) presents the block diagram of the receive clock generator.



mcasp-014

**Figure 12-13. Receive Clock Generator Block Diagram**

#### Note

In this device:

- ACLKR is mapped on the device ball ACLKR
- internal AHCLKX is mapped on the device balls AUDIO\_EXT\_REFCLK[0-1]
- external AHCLKR is mapped on Device Configuration MCASPi\_AHCLKR from Device Configuration

For more information about MCASP integration, see [Section 12.1.1.2, MCASP Environment, and , Module Integration](#).

#### 12.1.1.4.2.3 Frame-Sync Generator

There are two different modes for frame sync: burst and TDM. The MCASP frame sync generator logic is illustrated in [Figure 12-14](#). The I/O buffers are not part of the MCASP module, and are not shown in the figure.



mcasp-015

Figure 12-14. Frame Sync Generator Block Diagram

#### Note

For more on MCASP integration, see [Section 12.1.1.2, MCASP Environment, and Module Integration](#).

**For the transmit logic**, following frame-sync generator configurations can be selected:

- Internally/externally generated frame-sync via configuring MCASP\_AFSXCTL[1] FSXM bit
- Frame-sync polarity: Rising edge or falling edge via configuring MCASP\_AFSXCTL[0] FSXP bit
- Frame-sync width: "single bit" or "single word" via configuring MCASP\_AFSXCTL[4] FXWID bit
- Frame sync mode - the appropriate frame sync generation pattern for the selected transfer mode is defined in the MCASP\_AFSXCTL[15-7] XMOD bit field, as follows:
  - For DIT mode (384 slots) - MCASP\_AFSXCTL[15-7] XMOD = 0x180
  - For I2S mode (2 TDM slots) - MCASP\_AFSXCTL[15-7] XMOD = 0x2
  - For TDM mode (from 3 to 32 TDM slots) - MCASP\_AFSXCTL[15-7] XMOD bit field set in range 0x3 - 0x20
- Bit delay: 0, 1, or 2 cycles before the first data bit. This delay is defined in MCASP\_XFMT[17-16] XDATDLY bit field

**For the receive logic**, following frame-sync generator configurations can be selected:

- Internally/externally generated frame-sync via configuring MCASP\_AFSRCTL[1] FSRM bit
- Frame-sync polarity: Rising edge or falling edge via configuring MCASP\_AFSRCTL[0] FSRP bit
- Frame-sync width: "single bit" or "single word" via configuring MCASP\_AFSRCTL[4] FRWID bit

- Frame sync mode - the appropriate frame sync generation pattern for the selected transfer mode is defined in the MCASP\_AFSRCTL[15-7] RMOD bit field, as follows:
  - For I2S mode (2 TDM slots) - MCASP\_AFSRCTL[15-7] RMOD = 0x2
  - For TDM mode (from 3 to 32 TDM slots) - MCASP\_AFSRCTL[15-7] RMOD set in range 0x3 - 0x20
  - For the special 384-slot TDM mode - MCASP\_AFSRCTL[15-7] RMOD = 0x180
- Bit delay: 0, 1, or 2 cycles before the first data bit. This delay is defined in the MCASP\_RFMT[17-16] RDATDLY bit field
- Selecting the source (AFSX or AFSR) of receiver internal frame synchronization. This is done in the same bit - MCASP\_ACLKXCTL[6] ASYNC, used to define the receiver internal clock source. For more details, refer to [Section 12.1.1.4.2.4, Synchronous and Asynchronous Transmit and Receive Operations](#).

Regardless of the AFSX/AFSR being internally generated or externally sourced, the polarity of AFSX/AFSR is determined by FSXP/FSRP, respectively, to be either rising or falling edge. If FSXP/FSRP = 0, the frame sync polarity is rising edge. If FSXP/FSRP = 1, the frame sync polarity is falling edge.

---

#### Note

Certain restrictions apply to the receive and transmit logic settings, when the *MCASP\_ACLKXCTL[6]* ASYNC bit is set to 0b0. They are described in [Section 12.1.1.4.2.4](#).

---

### **12.1.1.4.2.4 Synchronous and Asynchronous Transmit and Receive Operations**

#### **Synchronous Transmit and Receive Operations -**

When the *MCASP\_ACLKXCTL[6]* ASYNC bit is written to 0b0, the transmit and receive sections operate synchronously to the transmit section clock and transmit frame sync signals.

Though Rx section may have a different data format, it has to be configured to have the same slot size than the transmit section one. As shown on the [Figure 12-13](#), with the ASYNC bit set to 0b0, the RCLK becomes an inverted version of the transmit clock generator XCLK output.

When the *MCASP\_ACLKXCTL[6]* ASYNC = 0b0, both Rx and Tx sections use the same clock and frame sync signals. For this reason, they must be aligned on the following settings:

- MCASP\_DITCTL[0] DITEN = 0 (that is, transmission in TDM mode is enabled)
- The total number of bits per frame must be the same (that is, RSSZ \* RMOD product value must equal XSSZ \* XMOD product value)
- The settings in the MCASP\_ACLKRCTL register are NOT considered
- FSXM must match FSRM
- FXWID must match FRWID

For all other settings, the transmit and receive sections may be programmed independently.

#### **Asynchronous Transmit and Receive Operations -**

When the *MCASP\_ACLKXCTL[6]* ASYNC = 0b1, Tx and Rx operate independently from each other with separate clock and frame sync signals.

---

#### Note

Synchronous transmit and receive operations are allowed only in the MCASP TDM (I2S) mode (this is, when MCASP\_DITCTL[0] DITEN = 0b0).

---

### **12.1.1.4.3 MCASP Serializers**

The MCASP serializers shift serial data in (Rx) and out (Tx) of the MCASP. A given serializer n consists of a shift register (XSRn) with a single-entry data buffer XRBUFn used either for transmitting (write accessible in the MCASP\_XBUFn register) or for receiving (read accessible in the MCASP\_RBUFn register) data. In addition, each serializer has a dedicated control register (MCASP\_SRCTLn) and a serial bidirectional data pin - AXRn. The register MCASP\_SRCTLn allows n-th serializer to be configured as a transmitter, receiver, or as inactive.

There are transmit and receive data formatting units to support data alignment options of the MCASP which are shared between all Tx and Rx serializers, respectively.

A given serializer XRSRn shifter configured as a receiver in the MCASP\_SRCTLn register, shifts in data through MCASP corresponding device level bidirectional data pad AXRn. A given serializer XRSRn shifter configured as a transmitter in the MCASP\_SRCTLn register, shifts out data on MCASP corresponding device level bidirectional data pad AXRn (n = 0 to 15).

The serializer is clocked from the transmit section clock (ACLKX signal) if configured to transmit or clocked from the receive section clock (ACLKR signal) if configured to receive. A serializer configured to transmit and receive operates in lockstep, which means that for MCASP there are at most a couple of zones, one for transmit and one for receive.

Figure 12-15 shows the serializer block diagram.



**Figure 12-15. Individual Serializer and Connections Within MCASP**

**Transmission on the n-th serializer is performed as follows:**

The MCASP is serviced by writing data into the MCASP\_XBUFn register, which is an alias of the serializer data buffer - XRBUFn for transmit function. The data automatically passes through the transmit format unit before reaching the XRBUFn register in the serializer. The data is then copied from the XRBUFn to XRSRn and shifted out from AXRn synchronously to the serial clock.

**Reception from the n-th serializer is performed as follows:**

The data is shifted into the MCASP XRSRn serializer register through the AXRn pin, bit by bit. Once the entire slot becomes available within the XRSRn shift register, the data is copied into the serializer data buffer - XRBUFn, and can be accessed in the MCASP\_RBUFn register, which is an alias of the serializer data buffer - XRBUFn for receive function. When software reads the data from this register, the MCASP passes the data through the receive format unit, hence it returns the formatted data.

**Serializer controls:**

A serializer n is configured as inactive via setting MCASP\_SRCTLn[1-0] SRMOD bit field to 0x0.

For a transmitting serializer, the MCASP\_SRCTLn[3-2] DISMOD bitfield, defines the AXRn pin output state, during inactive slots (HIGH, LOW or Hi-Z).

Transmit function for the n-th serializer is selected via setting MCASP\_SRCTLn[1-0] SRMOD bit field to 0x1.

Receive function for the n-th serializer is selected via setting MCASP\_SRCTLn[1-0] SRMOD bit field to 0x2 (n = 0 to 15).

In the DIT-transmission mode (that is S/PDIF format data transmission): in addition to the data, the serializer shifts out other DIT-specific information accordingly (preamble, user data, etc.). For more information, see [Section 12.1.1.2.2.5, S/PDIF Coding Format](#).

#### 12.1.1.4.4 MCASP Format Units

The MCASP has one transmit data formatting unit and one receive data formatting unit, shared between the device MCASP serializers. These units automatically remap the data bits within the transmitted or received words between a natural format for the device processors (for example, a Q31 representation) and the required format for the external serial device (for example I2S format). During the remapping process, the format unit can also mask off certain bits.

Since all transmitters share the same data formatting unit, the MCASP only supports one transmit format at a time. For example, the MCASP does NOT transmit in "I2S format" on serializer 0, while transmitting "Left Justified" on serializer 1. Likewise, the receiver section of the MCASP only supports one data format at a time, and this format applies to all receiving serializers.

---

#### Note

The MCASP can transmit in one format while receiving in a completely different format.

---

The bit mask and pad stage of each of Tx and Rx format units includes a full 32-bit mask register, allowing selected individual bits to either pass through the stage unchanged, or be masked off. The bit mask and pad then pad the value of the masked off bits by inserting either a 0, a 1, or one of the original 32 bits as the pad value. The last option allows for sign-extension when the sign bit is selected to pad the remaining bits. The rotate right stage performs bitwise rotation by a multiple of 4 bits (between 0 and 28 bits), programmable by the MCASP\_RFMT/MCASP\_XFMT register. Note that this is a rotation process, not a shifting process, so bit 0 gets shifted back into bit 31 during the rotation. The bit order - reversal stage either passes all 32 bits directly through, or swaps them. This allows for either MSB or LSB first data formats. If bit order reversal is not enabled, then the MCASP will naturally transmit and receive in an LSB first order. Finally, note that the RDATDLY/XDATDLY bits in the MCASP\_RFMT/MCASP\_XFMT also determine the data format. For example, the difference between I2S format and left-justified is determined by the delay between the frame sync edge and the first data bit of a given time slot. For I2S format, RDATDLY/XDATDLY should be set to a 1-bit delay, whereas for left-justified format, it should be set to a 0-bit delay. The combination of all the options in the MCASP\_RFMT/MCASP\_XFMT register means that the MCASP supports a wide variety of data formats, both on the serial data lines, and in the device CPU data representation.

#### 12.1.1.4.4.1 Transmit Format Unit

The MCASP transmit formatting unit consists of three stages :

- Bit mask (masks off bits)
- Rotate right (aligns data within word)
- Bit reversal (selects between MSB-first or LSB-first)

[Figure 12-16](#) shows the transmit formatting unit.

The MCASP transmitter supports serial formats of:

- Slot (or Time slot) size = 8, 12, 16, 20, 24, 28, 32 bits
- Word size  $\leq$  Slot size
- Alignment: when more bits/slot than bits/words, then:
  - Left aligned = word shifted first, remaining bits are pad
  - Right aligned = pad bits are shifted first, word occupies the last bits in slot
- Order of bits shifted out:
  - MSB: most-significant bit of word is shifted out first, last bit is LSB
  - LSB: least-significant bit of word is shifted out last, last bit is MSB

Hardware support for these serial formats comes from the programmable options in the bitstream format register - MCASP\_XFMT:

- XRVRS: bit reverse (1) or no bit reverse (0)
- XROT: rotate right by 0, 4, 8, 12, 16, 20, 24, or 28 bits
- XSSZ: transmit slot size of 8, 12, 16, 20, 24, 28, or 32 bits



mcasp-017

**Figure 12-16. Transmit Format Unit**

As shown in Figure 12-16, the data to the transmit format unit can come from the configuration port (CFG) or the data port (DATA). The selection is made through the MCASP\_XFMT[3] XBUSEL bit. According to port type selected, data transfer has different behaviour. For more details, refer to the [Section 12.1.1.4.10.1.3, Transfers Through the DATA Port](#), and [Section 12.1.1.4.10.1.4, Transfers Through the Configuration \(CFG\) Bus](#).

In the transmit format unit (TFU), the input data bits are first masked-off with the MCASP\_XMASK[31-0] XMASK contents. The masked data is then right-rotated to the MCASP\_XFMT[2-0] XROT bit field positions, to produce the output word for a TDM- or DIT- transmission.

The bit mask stage includes a full 32-bit mask register, allowing selected individual bits to pass through the stage unchanged or be masked off.

#### 12.1.1.4.4.1.1 TDM Mode Transmission Data Alignment Settings

The TDM-mode transmission settings are relevant for I2S-protocol and protocols using more than 2 TDM-slots.

XSSZ should always be programmed to match the slot size of the serial stream.

---

**Note**

Note that, TDM word size is not directly programmed into the MCASP, but rather is used to determine the rotation needed in the XROT field.

---

The [Table 12-4](#) show the XRVRS and XROT fields for each serial format and for both integer and Q31 fractional internal representations.

The [Table 12-4](#) assumes that all slot size (SLOT in [Table 12-4](#)) and word size (WORD in [Table 12-4](#)) options are multiples of 4, since the transmit rotate right unit only supports rotation by multiples of 4. However, the bit mask/pad unit does allow for any number of significant digits. For example, a Q31 number may have 19 significant digits (word) and be transmitted in a 24-bit slot; this would be formatted as a word size of 20 bits and a slot size of 24 bits. However, it is possible to set the bit mask unit to only pass the 19 most-significant digits (program the mask value to FFFF E000h). The digits that are not significant can be set to a selected pad value, which can be any one of the significant digits, a fixed value of 0, or a fixed value of 1.

The transmit bit mask/pad unit operates on data as an initial step of the transmit format unit, and the data is aligned in the same representation as it is written to the transmitter (typically Q31 or integer).

**Table 12-4. MCASP TFU TDM Mode Settings**

| Bit Stream Order         | Bit Stream Alignment | Internal Numeric Representation | MCASP_XFMT bits           |       |
|--------------------------|----------------------|---------------------------------|---------------------------|-------|
|                          |                      |                                 | XROT <sup>(1)</sup>       | XRVRS |
| MSB first <sup>(2)</sup> | Left aligned         | Q31 fraction                    | 0                         | 1     |
| MSB first                | Right aligned        | Q31 fraction                    | SLOT - WORD               | 1     |
| LSB first                | Left aligned         | Q31 fraction                    | 32 - WORD                 | 0     |
| LSB first                | Right aligned        | Q31 fraction                    | 32 - SLOT                 | 0     |
| MSB first <sup>(2)</sup> | Left aligned         | Integer                         | WORD                      | 1     |
| MSB first                | Right aligned        | Integer                         | SLOT                      | 1     |
| LSB first                | Left aligned         | Integer                         | 0                         | 0     |
| LSB first                | Right aligned        | Integer                         | (32 - (SLOT - WORD)) % 32 | 0     |

(1) WORD = Word size rounded up to the nearest multiple of 4; SLOT = slot size; % = modulo operator

(2) To transmit in I2S format, select MSB first, left aligned, and also select XDATDLY = 01 (1 bit delay)

#### 12.1.1.4.4.1.2 DIT Mode Transmission Data Alignment Settings

In case of a DIT-mode (S/PDIF protocol) transmission, while left-aligned Q31 data should be right-rotated to a multiple by 4 positions, no right-rotation is required for a right-aligned Q31 data. Because this is a rotation process, not a shifting process, bit 0 gets shifted back into bit 31 during the process.

The MCASP\_XFMT[17-16] XDATDLY bit field must be set to a 0-bit delay (0x0 value).

For left-aligned Q31 data, the following transmit format unit settings process the data into right-aligned data, ready for transmission:

- MCASP\_XFMT[2-0] XROT =
  - 0x2 (rotate right by 8 bits) - for a 24-bit output audio data
  - 0x3 (rotate right by 12 bits) - for a 20-bit output audio data
  - 0x4 (rotate right by 16 bits) - for a 16-bit output audio data
- MCASP\_XFMT[15] XRVRS = 0x0 – Bit reversal is not enabled; the MCASP naturally transmits and receives in a LSB-first order.
- MCASP\_XMASK[32] XMASK = 0xFFFFF00 – 0xFFFF0000
- MCASP\_XFMT[14-13] XPAD = 0x0 (Pad extra bits with 0s.)

For right-aligned data, the following transmit format unit settings process the data into right-aligned audio data ready for transmission:

- MCASP\_XFMT[2-0] XROT = 0x0 (rotate right by 0 bits regardless of the audio word length)

- MCASP\_XFMT[15] XRVRS = 0x0 – Bit reversal is not enabled; the MCASP naturally transmits and receives in a LSB-first order.
- MCASP\_XMASK[32] XMASK = 0x00FFFFFF – 0x0000FFFF
- MCASP\_XFMT[14-13] XPAD = 0x0 (Pad extra bits with 0s.)

The example settings provided in [Table 12-5](#) should be applied to MCASP in cases of DIT-transmitting a Q31 data as a 24-bit, 20-bit and 16-bit left- or right- aligned audio word, respectively. Note that the listed settings let the MCASP TFU preserve the most significant bits and cut only the LSBs of the original Q31 CPU data:

**Table 12-5. MCASP TFU DIT-Mode Example Settings**

| Output Audio Word Alignment | Audio Word Length | Right-rotation (multiple of 4-bit positions) | XMASK      | XROT |
|-----------------------------|-------------------|----------------------------------------------|------------|------|
| LEFT                        | 16                | 16                                           | 0xFFFF0000 | 0x4  |
| LEFT                        | 20                | 12                                           | 0xFFFFF000 | 0x3  |
| LEFT                        | 24                | 8                                            | 0xFFFFF00  | 0x2  |
| RIGHT                       | 16                | 0                                            | 0x0000FFFF | 0x0  |
| RIGHT                       | 20                | 0                                            | 0x000FFFFF | 0x0  |
| RIGHT                       | 24                | 0                                            | 0x0FFFFFFF | 0x0  |

Assuming that a Q31 data word 0xFA5AFxxx (where x-marked nibbles of the data are applied as padding bits of the word) is generated on the MCASP CFG (peripheral) port. To transmit a left-aligned 20-bit version of same word, preserving the MSBs, according to the [Table 12-5](#), the user must set XMASK = 0xFFFFF000, and to select a right-rotation to 12 positions (XROT = 0x3).

- After applying 0-s (XPAD = 0) as masking-off bits at the first TFU stage, word is transformed to the word 0xFA5AF000.
- After a rotation by 12 positions to the right is performed in TFU, the 20-bit output word obtained is: 0x000FA5AF. Thus the word gets ready for transmission being mapped with its LS-bit as bit 8 and its MS-bit as bit 27 within a S/PDIF bitstream. This word is shifted in a LSB-to-MSB order (XRVRS = 0x0) out of the XRSR register during a DIT-transmission.

Assuming that a right-aligned Q31 data word - 0x yyyyE4B4 is generated by software on the MCASP CFG (peripheral) port (with the presumption that y-marked nibbles of the input data are applied as padding bits). To transmit a right-aligned 16-bit version of same word, preserving the MSBs, according to the table MCASP TFU Example Settings, user is supposed to set XMASK = 0x0000FFFF, and to select right-rotation to 0 positions (XROT = 0x0).

- After masking-off with 0s at first TFU stage, word is transformed to 0x0000E4B4.
- Since no rotation is applied, the 16-bit output word obtained is actually the one obtained in the masking stage – 0x0000E4B4.

The above examples use internal representation in integer and Q31 notation, but other fractional notations are also possible.

#### 12.1.1.4.4.2 Receive Format Unit

The MCASP receive formatting unit consists of three stages:

- Bit mask (masks off bits)
- Rotate right (aligns data within word)
- Bit reversal (selects between MSB first or LSB first)

[Figure 12-17](#) shows the receive format unit (RFU).


mcasp-018

**Figure 12-17. Receive Format Unit**

The MCASP receiver supports serial formats of:

- Slot or time slot size = 8, 12, 16, 20, 24, 28, 32 bits
- Word size  $\leq$  Slot size
- Alignment when more bits are available per slot than bits per word within the slot, then:
  - Left aligned = word shifted first, remaining bits are pad
  - Right aligned = pad bits are shifted first, word occupies the last bits in slot
- Order of bits shifted out:
  - MSB: most-significant bit of word is shifted out first, last bit is LSB
  - LSB: least-significant bit of word is shifted out last, last bit is MSB

Hardware support for these serial formats comes from the programmable options in the receive bitstream format register - MCASP\_RFMT:

- RRVRS: bit reverse (1) or no bit reverse (0)
- RROT: rotate right by 0, 4, 8, 12, 16, 20, 24, or 28 bits
- RSSZ: receive slot size of 8, 12, 16, 20, 24, 28, or 32 bits

As shown on [Figure 12-17](#), the data processed in the RFU can be output to host CPU through the configuration port (CFG) or the data port (DATA). The selection is made through the MCASP\_RFMT[3] RBUSEL bit. According to port type selected, data transfer has different behaviour. For more details, refer to the [Section 12.1.1.4.10.1.3, Transfers Through the DATA Port](#), and [Section 12.1.1.4.10.1.4, Transfers Through the Configuration \(CFG\) Bus](#).

#### 12.1.1.4.4.2.1 TDM Mode Reception Data Alignment Settings

RSSZ should always be programmed to match the slot size of the serial stream.

---

### Note

Note that the word size is not directly programmed into the MCASP, but rather is used to determine the rotation needed in the RROT field.

---

Table 12-6 shows the RRVRS and RROT fields for each serial format and for both integer and Q31 fractional internal representations.

**Table 12-6. MCASP RFU Settings**

| Bit Stream Order         | Bit Stream Alignment | Internal Numeric Representation | MCASP_RFMT bits           |       |
|--------------------------|----------------------|---------------------------------|---------------------------|-------|
|                          |                      |                                 | RROT <sup>(1)</sup>       | RRVRS |
| MSB first <sup>(2)</sup> | Left aligned         | Q31 fraction                    | SLOT                      | 1     |
| MSB first                | Right aligned        | Q31 fraction                    | WORD                      | 1     |
| LSB first                | Left aligned         | Q31 fraction                    | (32 - (SLOT - WORD)) % 32 | 0     |
| LSB first                | Right aligned        | Q31 fraction                    | 0                         | 0     |
| MSB first <sup>(2)</sup> | Left aligned         | Integer                         | SLOT - WORD               | 1     |
| MSB first                | Right aligned        | Integer                         | 0                         | 1     |
| LSB first                | Left aligned         | Integer                         | 32 - SLOT                 | 0     |
| LSB first                | Right aligned        | Integer                         | 32 - WORD                 | 0     |

(1) WORD = Word size rounded up to the nearest multiple of 4; SLOT = slot size; % = modulo operator

(2) To receive in I2S format, select MSB first, left aligned, and also select RDATDLY = 01 (1 bit delay)

The Table 12-6 assumes that all slot size and word size options are multiples of 4; since the receive rotate right unit only supports rotation by multiples of 4. However, the bit mask/pad unit does allow for any number of significant digits. For example, a Q31 number may have 19 significant digits (word) and be received in a 24-bit slot; this would be formatted as a word size of 20 bits and a slot size of 24 bits. However, it is possible to set the bit mask unit to only pass the 19 most-significant digits (program the mask value to FFFF E000h). The digits that are not significant can be set to a selected pad value, which can be any one of the significant digits, a fixed value of 0, or a fixed value of 1. The receive bit mask/pad unit operates on data as the final step of the receive format unit (see Figure 12-17), and the data is aligned in the same representation as it is read from the receiver (typically Q31 or integer).

#### 12.1.1.4.5 MCASP State-Machines

The receive and transmit sections have independent state machines.

Each state-machine controls the interactions between the various units in the MCASP Rx and Tx sections, respectively. In addition, each state-machine keeps track of error conditions and serial port status. No serial transfers can occur until the RX/TX state-machine is released from reset.

The transmit state-machine is controlled by the transmit bitstream format register (MCASP\_XFMT) and it reports the MCASP status and error conditions in the transmitter status register (MCASP\_XSTAT).

Similarly, the receive state-machine is controlled by the receive bitstream format register (MCASP\_RFMT) and it reports the MCASP status and error conditions in the receiver status register (MCASP\_RSTAT).

#### 12.1.1.4.6 MCASP TDM Sequencers

There are separate TDM sequencers for the transmit section and the receive section. Each TDM sequencer keeps track of the slot count. In addition, the TDM sequencer checks the bits of the MCASP\_RTDM/MCASP\_XTDM register and determines if the MCASP should receive/transmit in that time slot.

There are two possibilities for a slot: The MCASP either performs Rx/Tx operations during the time slot (transmit/receive bit is active), or the MCASP skips Rx/Tx operations during the time slot (transmit/receive bit is inactive). In the latter case, no transfers between the XRBUF and XRSR registers in the serializer would occur during that time slot.

In addition, during time of inactive slots, the serializers programmed as transmitters place their data output pins - AXR<sub>n</sub> in a predetermined state - logic low, high, or high impedance (tri-stated) as programmed in each serializer control MCASP\_SRCTL<sub>n</sub>[3-2] DISMOD register. Refer also to [Section 12.1.1.4.9.2.1, TDM Time Slots Generation and Processing](#), for details on how DMA event or interrupt generations are handled during inactive time slots in TDM mode.

**In case of a DIT-transmission (S/PDIF transfers):** the time division multiplexing (TDM) sequencer is used to count the 384 subframes (slots) in the DIT block. If currently transmitting slot 1, slot 2 (next value of the TDM slot counter) should be used during the encode phase to select the appropriate C, V, and U bit, because the data encoded and written to a MCASP\_XBUFn register during the current time slot (slot 1) is actually shifted out on the next time slot (n = 0 to 15).

The transmit TDM sequencer is controlled by the MCASP\_XTDM register and reports the current transmit slot to the MCASP\_XTDMslot[9-0] XSLOTCNT bit field.

#### 12.1.1.4.7 MCASP Software Reset

The MCASP can be put into reset through the global transmit and receive control register (*MCASP\_GBLCTL*). A valid serial clock must be supplied to the MCASP to assert the software reset bits in the *MCASP\_GBLCTL* register.

#### 12.1.1.4.8 MCASP Power Management

[Table 12-7](#) describes power-management features available to the MCASP.

**Table 12-7. Local Power-Management Features**

| Feature                 | Registers                                     | Description                                                                |
|-------------------------|-----------------------------------------------|----------------------------------------------------------------------------|
| Target clock stop modes | <i>MCASP_PWRDLESYSCONFIG</i> [1-0 ] IDLE_MODE | Force-clock stop, no-clock stop, and smart-clock stop modes are available. |

#### CAUTION

No wakeup schema is supported for the MCASP. To ensure a correct behavior after enabling MCASP at device Device Configuration level, the user software is strongly recommended to choose *No Idle* mode, setting *MCASP\_PWRDLESYSCONFIG*[1-0] IDLE\_MODE bit field to 0x1. Before disabling MCASP at device Device Configuration level, user software is strongly recommended to choose a *Smart-Idle* mode, setting *MCASP\_PWRDLESYSCONFIG*[1-0] IDLE\_MODE bit field to 0x2.

#### 12.1.1.4.9 MCASP Transfer Modes

##### 12.1.1.4.9.1 Burst Transfer Mode

The MCASP supports a burst transfer mode, which is useful for nonaudio data such as passing control information between two processors. Burst transfer mode uses a synchronous serial format similar to the TDM mode. The frame sync generation is not periodic or time-driven as in TDM mode, but data driven, and the frame sync is generated for each data word transferred.

When operating in burst frame sync mode (see [Figure 12-18](#)), as specified for transmit (*MCASP\_AFSXCTL*[15-7] = 0 ) and receive (*MCASP\_AFSRCTL*[15-7] RMOD = 0), one slot is shifted for each active edge of the frame sync signal that is recognized. Additional clocks after the slot and before the next frame sync edge are ignored.

In burst frame sync mode, the frame sync delay may be specified as 0, 1, or 2 serial clock cycles. This is the delay between the frame sync active edge and the start of the slot. The frame sync signal lasts for a single bit clock duration (*MCASP\_AFSRCTL*[4] FRWID = 0, *MCASP\_AFSXCTL*[4] FXWID = 0).

For transmit, when generating the transmit frame sync internally, the frame sync begins when the previous transmission has completed and when all the XBUFn (for every serializer set to operate as a transmitter) has been updated with new data.

For receive, when generating the receive frame sync internally, frame sync begins when the previous transmission has completed and when all the RBUFn (for every serializer set to operate as a receiver) has been read.



Figure 12-18. Burst Frame Sync Mode

The control registers must be configured as follows for the burst transfer mode. The burst mode specific bit fields are in bold face:

- **MCASP\_PFUNC**: The clock, frame, data pins must be configured for MCASP function.
- **MCASP\_PDIR**: The clock, frame, data pins must be configured to the direction desired.
- **MCASP\_PDOOUT**, **MCASP\_PDIN**, **MCASP\_PDCLR**: Not applicable. Leave at default.
- **MCASP\_GBLCTL**: Follow the initialization sequence in [Section 12.1.1.5.1.2, MCASP Global Initialization](#), to configure this register.
- **MCASP\_AMUTE**: Not applicable. Leave at default.
- **MCASP\_DLBCCTL**: If loopback mode is desired, configure this register according to [Section 12.1.1.4.14, MCASP Loopback Modes](#), otherwise leave this register at default.
- **MCASP\_DITCTL**: DITEN must be left at default 0 to select non-DIT mode. Leave the register at default.
- **MCASP\_RMASK/MCASP\_XMASK**: Mask desired bits according to [Section 12.1.1.4.4, MCASP Format Units](#).
- **MCASP\_RFMT/MCASP\_XFMT**: Program all fields according to data format desired. See [Section 12.1.1.4.4, MCASP Format Units](#).
- **MCASP\_RFMT/MCASP\_XFMT**: Clear RMOD/XMOD bits to 0 to indicate burst mode. Clear FRWID/FXWID bits to 0 for single bit frame sync duration. Configure other fields as desired.
- **MCASP\_ACLKRCTL/MCASP\_ACLKXCTL**: Program all fields according to bit clock desired. See [Section 12.1.1.4.2, MCASP Clock and Frame-Sync Configurations](#).
- **MCASP\_AHCLKRCTL/MCASP\_AHCLKXCTL**: Program all fields according to high-frequency clock desired. See [Section 12.1.1.4.2, MCASP Clock and Frame-Sync Configurations](#).
- **MCASP\_RTDM/MCASP\_XTDM**: Program RTDMS0/XTDMS0 to 1 to indicate one active slot only. Leave other fields at default.
- **MCASP\_RINTCTL/MCASP\_XINTCTL**: Program all fields according to interrupts desired.
- **MCASP\_RCLKCHK/MCASP\_XCLKCHK**: Not applicable. Leave at default.
- **MCASP\_SRCTLn**: Program SRMOD to inactive/transmitter/receiver as desired. DISMOD is not applicable and should be left at default (n = 0 to 15).
- **MCASP\_DITCSRAi**, **MCASP\_DITCSRBi**, **MCASP\_DITUDRAi**, **MCASP\_DITUDRBi**: Not applicable. Leave at default (i = 0 to 5).

#### 12.1.1.4.9.2 Time-Division Multiplexed (TDM) Transfer Mode

The MCASP time-division multiplexed (TDM) transfer mode supports the TDM format discussed in [Section 12.1.1.2.2.3, TDM Format](#).

Transmitting data in the TDM transfer mode requires a minimum set of pins:

- **ACLKX** - transmit bit clock
- **AFSX** - transmit frame sync (or commonly called left/right clock)
- One or more serial data pins, **AXRn**, whose serializers are configured to transmit

For more details on MCASP transmitting serializers clock and frame sync options, refer to the [Section 12.1.1.4.2.1, Transmit Clock](#), and [Section 12.1.1.4.2.3, Frame-Sync Generator](#).

Similarly, to receive data in the TDM transfer mode requires a minimum set of pins:

- **ACLKR** - receive bit clock
- **AFSR** - receive frame sync (or commonly called left/right clock)
- One or more serial data pins, **AXRn**, whose serializers are configured to receive

For more details on MCASP receiving serializers clock and frame sync options, refer to [Section 12.1.1.4.2.2, Receive Clock](#), and [Section 12.1.1.4.2.3, Frame-Sync Generator](#).

The control registers must be configured as follows for the TDM mode. The TDM mode specific bit fields are highlighted in bold:

- **MCASP\_PFUNC**: The clock, frame, data pins must be configured for MCASP function.
- **MCASP\_PDIR**: The clock, frame, data pins must be configured to the direction desired.
- **MCASP\_PDOOUT, MCASP\_PDIN, MCASP\_PDCLR**: Not applicable. Leave at default.
- **MCASP\_GBLCTL**: Follow the initialization sequence is described in the [Section 12.1.1.5.2, MCASP Operational Modes Configuration](#).
- **MCASP\_AMUTE**: Leave this register at default state.
- **MCASP\_DLBCCTL**: If loopback mode is desired, configure this register according to [Section 12.1.1.4.14](#), otherwise leave this register at default.
- **MCASP\_DITCTL**: DITEN must be left at default 0 to select TDM mode (transmitters only).
- **MCASP\_RMASK/MCASP\_XMASK**: Mask desired bits according to [Section 12.1.1.4.4, MCASP Format Units](#).
- **MCASP\_RFMT/MCASP\_XFMT**: Program all fields according to data format desired. See the [Section 12.1.1.4.4, MCASP Format Units](#).
- **MCASP\_AFSRCTL/MCASP\_AFSXCTL**: Set RMOD/XMOD bits to (0x2 - 0x20) for Rx/Tx (2- 32 slots) TDM mode. In addition, set RMOD to 0x180 if 384-slot TDM stream has to be received by MCASP. Configure other fields as desired.
- **MCASP\_ACLKRCTL/MCASP\_ACLKXCTL**: Program all fields according to bit clock desired. For more information, refer to [Section 12.1.1.4.2, MCASP Clock and Frame-Sync Configurations](#).
- **MCASP\_AHCLKRCTL/MCASP\_AHCLKXCTL**: Program all fields according to high-frequency clock desired. For more details, refer to [Section 12.1.1.4.2, MCASP Clock and Frame-Sync Configurations](#).
- **MCASP\_RTDM/MCASP\_XTDM**: Program all fields according to the time slot characteristics desired.
- **MCASP\_XINTCTL**: Program all fields according to transmit interrupts desired.
- **MCASP\_RCLKCHK/MCASP\_XCLKCHK**: Program all fields according to clock checking desired.
- **MCASP\_SRCTLn**: Program all fields according to serializer operation desired (n = 0 to 15).

---

#### Note

The **MCASP\_DITCSRAi**, **MCASP\_DITCSRBi**, **MCASP\_DITUDRAi**, **MCASP\_DITUDRBi** (i = 0 to 5) settings are NOT applicable in TDM transfer modes. They have to be kept at their default values.

---

#### 12.1.1.4.9.2.1 TDM Time Slots Generation and Processing

TDM mode on the MCASP can extend to support multiprocessor applications, with up to 32 time slots per frame. For each of the time slots, the MCASP may be configured to participate or to be inactive by configuring MCASP\_XTDM and/or MCASP\_RTDM registers.

The TDM sequencer (separate ones for transmit and receive) functions in this mode. The TDM sequencer counts the slots beginning with the frame sync. For each slot, the TDM sequencer checks the respective bit in either MCASP\_XTDM or MCASP\_RTDM register to determine if the MCASP transmits/receives in that time slot.

---

**Note**

If a MCASP\_XTDM/MCASP\_RTDM bit defines an active slot (number of slot matches the bit position), the MCASP functions normally during that time slot; otherwise, the MCASP is inactive during that time slot; no update to the buffer occurs, and no event is generated. MCASP (transmit only) data pins are automatically set to a high-impedance state, 0, or 1 during that slot, as determined by bitfield MCASP\_SRCTLn[3-2] DISMOD (n = 0 to 15).

---

Figure 12-19 shows when the transmit DMA event - XINT is generated. See [Section 12.1.1.4.10.1, Data Ready Status and Event/Interrupt Generation](#) for details on data ready and the initialization period indication. The transmit DMA event for an active time slot (slot N) is generated during the previous time slot (slot N - 1), regardless of the previous time slot (slot N - 1) being active or inactive.

During an active transmit time slot (slot N), if the next time slot (slot N + 1) is configured to be active, the copy from XRBUFn to XRSRn generates the DMA event for time slot N + 1. If the next time slot (slot N + 1) is configured to be inactive, then the DMA event will be delayed to time slot M - 1. In this case, slot M is the next active time slot. The DMA event for time slot M is generated during the first bit time of slot M - 1.

The receive DMA event is generated after data is received in the buffer (looks back in time). If a time slot is disabled, then no data is copied to the buffer for that time slot and no DMA event is generated.



mcasp-019

**Figure 12-19. Transmit DMA Event (XINT) Generation in TDM Time Slots**

#### 12.1.1.4.9.2.2 Special 384-Slot TDM Mode for Connection to External DIR

The MCASP receiver also supports a 384 time slot TDM mode (DIR mode), to support S/PDIF receiver ICs whose natural block (block corresponds to MCASP frame) size is 384 samples. The receive TDM time slot register (MCASP\_RTDM) should be programmed to all 1s during reception of a DIR block. Other TDM functionalities (for example, inactive slots) are not supported (only the slot counter counts the 384 subframes in a block). To receive data in DIR mode, the following pins are typically needed:

- ACLKR - receive bit clock
- AFSR - receive frame sync (or commonly called left/right clock)
- In this mode, AFSR should be connected to a DIR which outputs a start of block signal, instead of LRCLK
- One or more serial data pins, AXRn, whose serializers have been configured to receive
- For this special DIR mode, the control registers can be configured just as for TDM mode, except set MCASP\_AFSRCTL[15-7] RMOD bit field to 384 (0x180) to receive 384 time slots

#### 12.1.1.4.9.3 DIT Transfer Mode

The DIT transfer mode of the MCASP also supports transmission of audio data in S/PDIF, AES-3, and IEC-60958 formats. These formats are designed to carry audio data between different systems through an optical or coaxial cable. The DIT mode applies only to a serializer configured as transmitter, not as receiver. For a description of the S/PDIF format, see [Section 12.1.1.2.2.5, S/PDIF Coding Format](#).

##### 12.1.1.4.9.3.1 Transmit DIT Encoding

When the MCASP operates in DIT mode, the data transmitted is output as a biphase-mark encoded bitstream, with preamble, channel status, user data, validity, and parity automatically stuffed into the bitstream by the MCASP. The MCASP includes separate validity bits for even/odd subframes and two 384-bit RAM modules to hold channel status and user data bits.

---

##### Note

The transmit TDM time slot register (MCASP\_XTDM) should be programmed to all 1s during DIT mode. TDM functionality is not supported in DIT mode, except that the TDM slot counter counts the DIT subframes.

---

To transmit data in DIT mode, the following pins are typically required:

- AHCLKX – transmit high-frequency controller clock (The internal clock source can be used instead.)
- One serial data pin (AXRn) of a serializer n configured to transmit.

For DIT Mode Transmission Data Alignment Settings see [Section 12.1.1.4.4.1.2, DIT Mode Transmission Data Alignment Settings](#).

If the MCASP is configured to transmit in the DIT mode on more than one serial data pin, the bit streams on all pins will be synchronized. In addition, although they will carry unique audio data, they will carry the same channel status, user data, and validity information.

The actual 24-bit audio data must always be in bit positions 23–0 after passing through the first three stages of the transmit format unit.

##### 12.1.1.4.9.3.2 Transmit DIT Clock and Frame-Sync Generation

The DIT transmitter works only in the following configuration:

- In the transmit frame control register (MCASP\_AFSXCTL):
  - Internally generated transmit frame sync, FSXM = 1
  - Rising-edge frame sync, FSXP = 0
  - Bit-width frame sync, FXWID = 0
  - 384-slot TDM, XMOD = 1 1000 0000b
- In the transmit clock control register (MCASP\_ACLKXCTL), ASYNC = 1
- In the transmit bitstream format register (MCASP\_XFMT), XSSZ = 1111 (32-bit slot size)

All combinations of AHCLKX and ACLKX are supported.

The following summarizes the register configurations required for DIT mode. DIT mode-specific bit fields are in **bold face**:

- **MCASP\_PFUNC**: The data pin - AXRn must be configured for MCASP function. If AHCLKX is used, it must also be configured for MCASP function. Other pins can be configured to function as GPIOs, if desired.
- **MCASP\_PDIR**: The data pin must be configured as output. If internal clock source AUXCLK is used as the reference clock, it may be output as the AHCLKX device level signal by configuring AHCLKX pin as an output.
- **MCASP\_GBLCTL**: Global initialization
- **MCASP\_AMUTE**: Leave this register at default state.
- **MCASP\_DITCTL**: The DITEN bit must be set to 0b1 to enable DIT mode. Configure other bits as desired.
- **MCASP\_XMASK**: Mask the desired bits, depending upon left-aligned or right-aligned internal data.

- MCASP\_XFMT: XDATDLY = 0. XRVRS = 0. XPAD = 0. XSSZ = Fh (32-bit slot). XBUSEL = configured as desired. The XROT bit is configured, as described in the [Section 12.1.1.4.4.1.2](#).
- MCASP\_AFSXCTL: Configure the bits according to former discussions.
- MCASP\_ACLKXCTL: ASYNC = 1. Program the CLKXDIV bits to obtain the bit clock rate desired. CLKXM = 1.
- MCASP\_AHCLKXCTL: Program the HCLKXDIV bits to obtain the high-frequency bit clock rate desired.
- MCASP\_XTDM: Set to FFFF FFFFh for all active slots for DIT transfers.
- MCASP\_XINTCTL: Program all fields according to the interrupts desired.
- MCASP\_XCLKCHK: Program all fields according to the clock checking desired.
- MCASP\_SRCTLn: Set SRMOD = 1 (transmitter) for the DIT pins (n = 0 to 15).
- MCASP\_DITCSRAi and MCASP\_DITCSRBi: Program the channel status bits as desired (i = 0 to 5).
- MCASP\_DITUDRAi and MCASP\_DITUDRBi: Program the user data bits as desired (i = 0 to 5).

#### Note

In DIT mode, the transmitter can support a 192 kHz frame rate (stereo) on up to 2 serial data pins simultaneously (note that the internal bit clock for DIT runs two times faster than the equivalent bit clock for TDM (I2S) mode, due to the need to generate Biphase Mark Encoded Data - see [Section 12.1.1.2.2.5.1, Biphase-Mark Code](#)).

#### 12.1.1.4.9.3.3 DIT Channel Status and User Data Register Files

The channel status registers (MCASP\_DITCSRAi and MCASP\_DITCSRBi) and user data registers (MCASP\_DITUDRAi and MCASP\_DITUDRBi) are not double-buffered. Typically, programmers use one of the synchronizing interrupts, such as the last slot, to create an event at a safe time so the register may be updated. In addition, the software reads the transmit TDM slot counter to determine which word of the register is being used (i = 0 to 5).

It is a software requirement to avoid writing to the word of user data and channel status that are being used to encode the current time slot; otherwise, it is undetermined whether old or new data is used to encode the bitstream.

The DIT subframe format is defined in [Section 12.1.1.2.2.5.2, S/PDIF Subframe Format](#). The channel status information (C) and user data (U) are defined in the following DIT control registers:

- MCASP\_DITCSRA0 to MCASP\_DITCSRA5: The 192 bits in these six registers contain the channel status information for the left channel within each frame.
- MCASP\_DITCSRA0 to MCASP\_DITCSRA5: The 192 bits in these six registers contain the channel status information for the right channel within each frame.
- MCASP\_DITCSRA0 to MCASP\_DITCSRA5: The 192 bits in these six registers contain the user data information for the left channel within each frame.
- MCASP\_DITCSRA0 to MCASP\_DITCSRA5: The 192 bits in these six registers contain the user data information for the right channel within each frame.
- The S/PDIF block format is shown in [Figure 12-10](#). There are 192 frames within a block (frame 0 to frame 191). There are two subframes within each frame (subframes 1 and 2 for the left and right channels, respectively).

The channel status and user data information sent on each subframe is summarized in [Table 12-8](#).

**Table 12-8. Channel Status and User Data for Each DIT Block**

| Frame                                                   | Subframe | Preamble | Channel Status Defined in: | User Data Defined in: |
|---------------------------------------------------------|----------|----------|----------------------------|-----------------------|
| <b>Defined by DITCSRA0, DITCSR0, DITUDRA0, DITUDRB0</b> |          |          |                            |                       |
| 0                                                       | 1 (L)    | B        | DITCSRA0[0]                | DITUDRA0[0]           |
| 0                                                       | 2 (R)    | W        | DITCSR0[0]                 | DITUDRB0[0]           |
| 1                                                       | 1 (L)    | M        | DITCSRA0[1]                | DITUDRA0[1]           |
| 1                                                       | 2 (R)    | W        | DITCSR0[1]                 | DITUDRB0[1]           |
| 2                                                       | 1 (L)    | M        | DITCSRA0[2]                | DITUDRA0[2]           |

**Table 12-8. Channel Status and User Data for Each DIT Block (continued)**

| Frame                                                    | Subframe | Preamble | Channel Status Defined in: | User Data Defined in: |
|----------------------------------------------------------|----------|----------|----------------------------|-----------------------|
| 2                                                        | 2 (R)    | W        | DITCSRB0[2]                | DITUDRB0[2]           |
| ...                                                      | ...      | ...      | ...                        | ...                   |
| 31                                                       | 1 (L)    | M        | DITCSRA0[31]               | DITUDRA0[31]          |
| 31                                                       | 2 (R)    | W        | DITCSRB0[31]               | DITUDRB0[31]          |
| <b>Defined by DITCSRA1, DITCSRB1, DITUDRA1, DITUDRB1</b> |          |          |                            |                       |
| 32                                                       | 1 (L)    | M        | DITCSRA1[0]                | DITUDRA1[0]           |
| 32                                                       | 2 (R)    | W        | DITCSRB1[0]                | DITUDRB1[0]           |
| ...                                                      | ...      | ...      | ...                        | ...                   |
| 63                                                       | 1 (L)    | M        | DITCSRA1[31]               | DITUDRA1[31]          |
| 63                                                       | 2 (R)    | W        | DITCSRB1[31]               | DITUDRB1[31]          |
| <b>Defined by DITCSRA2, DITCSRB2, DITUDRA2, DITUDRB2</b> |          |          |                            |                       |
| 64                                                       | 1 (L)    | M        | DITCSRA2[0]                | DITUDRA2[0]           |
| 64                                                       | 2 (R)    | W        | DITCSRB2[0]                | DITUDRB2[0]           |
| ...                                                      | ...      | ...      | ...                        | ...                   |
| 95                                                       | 1 (L)    | M        | DITCSRA2[31]               | DITUDRA2[31]          |
| 95                                                       | 2 (R)    | W        | DITCSRB2[31]               | DITUDRB2[31]          |
| <b>Defined by DITCSRA3, DITCSRB3, DITUDRA3, DITUDRB3</b> |          |          |                            |                       |
| 96                                                       | 1 (L)    | M        | DITCSRA3[0]                | DITUDRA3[0]           |
| 96                                                       | 2 (R)    | W        | DITCSRB3[0]                | DITUDRB3[0]           |
| ...                                                      | ...      | ...      | ...                        | ...                   |
| 127                                                      | 1 (L)    | M        | DITCSRA3[31]               | DITUDRA3[31]          |
| 127                                                      | 2 (R)    | W        | DITCSRB3[31]               | DITUDRB3[31]          |
| <b>Defined by DITCSRA4, DITCSRB4, DITUDRA4, DITUDRB4</b> |          |          |                            |                       |
| 128                                                      | 1 (L)    | M        | DITCSRA4[0]                | DITUDRA4[0]           |
| 128                                                      | 2 (R)    | W        | DITCSRB4[0]                | DITUDRB4[0]           |
| ...                                                      | ...      | ...      | ...                        | ...                   |
| 159                                                      | 1 (L)    | M        | DITCSRA4[31]               | DITUDRA4[31]          |
| 159                                                      | 2 (R)    | W        | DITCSRB4[31]               | DITUDRB4[31]          |
| <b>Defined by DITCSRA5, DITCSRB5, DITUDRA5, DITUDRB5</b> |          |          |                            |                       |
| 160                                                      | 1 (L)    | M        | DITCSRA5[0]                | DITUDRA5[0]           |
| 160                                                      | 2 (R)    | W        | DITCSRB5[0]                | DITUDRB5[0]           |
| ...                                                      | ...      | ...      | ...                        | ...                   |
| 191                                                      | 1 (L)    | M        | DITCSRA5[31]               | DITUDRA5[31]          |
| 191                                                      | 2 (R)    | W        | DITCSRB5[31]               | DITUDRB5[31]          |

#### 12.1.1.4.10 MCASP Data Transmission and Reception

The MCASP is serviced by writing data to the MCASP\_XBUFn registers for transmit operations, and by reading data from the MCASP\_RBUFn registers for receive operations. The MCASP sets status flags and notifies the software whenever data is ready to be serviced. The [Section 12.1.1.4.10.1, Data Ready Status and Event/Interrupt Generation](#), discusses data-ready status in details (n = 0 to 15).

The MCASP transmit/receive XRBUFn buffer can be accessed through one of the two peripheral ports of the device:

- DATA port: This port is dedicated to DMA initiated data transfers on the device for MCASP transmit (Tx) purposes.
- Configuration bus (CFG): The configuration bus- CFG port is used for peripheral configuration control and receive/transmit data transfers initiated by the host CPU in the device.

[Section 12.1.1.4.10.1.3, Transfers Through the Data Port \(DATA\)](#), and [Section 12.1.1.4.10.1.4, Transfers Through the Configuration Bus \(CFG\)](#), discuss how to perform transfers through the data port (DATA) and the configuration port (CFG), respectively.

A device CPU and DMA usages are discussed in [Section 12.1.1.4.10.1.5, Using the device CPUs for MCASP Servicing](#), and [Section 12.1.1.4.10.1.6, Using the DMA for MCASP Servicing](#), respectively.

MCASP DATA port allows DMAs to access the MCASP transmit buffer more efficiently on the CBASS0, using burst transfers. The physical addresses to access these registers are listed in [DMA Registers](#).

#### **12.1.1.4.10.1 Data Ready Status and Event/Interrupt Generation**

##### **12.1.1.4.10.1.1 Transmit Data Ready**

The transmit data ready flag - XDATA in the MCASP\_XSTAT register reflects the data ready status of XRBUF<sub>n</sub> buffers for all of the active slot transmitting serializers. The XDATA flag is set whenever data is transferred from a transmitting serializer buffer - XRBUF<sub>n</sub> to its corresponding XRSR<sub>n</sub> shift register. Thus, the XDATA bit indicates the global event that some of the serializers data buffer - XRBUF<sub>n</sub> is emptied and ready to accept new data from the host (CPU or DMA). The transmit data ready event is individually indicated per serializer in its corresponding control register MCASP\_SRCTL<sub>n</sub>[4] XRDY status bit. When this bit is set to 0b1, it notifies to host that this serializer Tx buffer must be serviced (written). When MCASP\_XBUF<sub>n</sub> is written to by the host, the MCASP\_SRCTL<sub>n</sub>[4] XRDY is deasserted to 0b0. As XDATA global flag is an OR-event of all active serializers XRDY flags, it indicates to software the moment, when write service operation has to be initiated by the MCASP host (XDATA=0b1). The XRDY flags have to be sequentially scanned by user software to determine which serializer MCASP\_XBUF<sub>n</sub> register has to be currently written. Once all requested MCASP\_XBUF<sub>n</sub> are written, the serializers control XRDY flags are cleared to 0b0. As a consequence, XDATA flag is deasserted to 0b0, to indicate to SW that write operation is completed for all serializers.

The global XDATA flag can be cleared when the MCASP\_XSTAT[5] XDATA bit is written to 0b1, or once MCASP\_XBUF<sub>n</sub> registers of all the serializers, that have previously raised their XRDY flags, are written with corresponding active slot data by the host.

Whenever XDATA is set, the XINT event is automatically generated on MCASP[0-2]\_XMIT\_DMA\_EVT line (if enabled in the MCASP\_XEVCTL register) to notify the DMA of the MCASP\_XBUF<sub>n</sub> empty status. An interrupt - MCASP[0-2]\_XMIT\_INTR\_PEND can be also generated if the XDATA interrupt is enabled in the MCASP\_XINTCTL register (for details, see [Section 12.1.1.4.12.1, Transmit Data Ready Interrupt](#)).

For DMA requests, the MCASP does not require that MCASP\_XSTAT register be read between DMA events. This means that, even if MCASP\_XSTAT register already has the XDATA flag set to 1 from a previous request, the next transfer triggers another DMA request.

Because the serializer acts in lockstep, only one DMA event is generated to indicate that the transmit serializer is ready to be written to with new data.

[Figure 12-20](#) shows the timing details of when XINT is generated at the MCASP boundary. In this example, as soon as the last bit (A0) of word A is transmitted, the MCASP sets the XDATA flag and generates an XINT event. However, it takes up to five MCASP interface clocks (XINT latency) before XINT is active at the MCASP boundary. Upon XINT, the CPU can begin servicing the MCASP by writing word C into the MCASP\_XBUF<sub>n</sub> (service time). The CPU must write word C into the MCASP\_XBUF<sub>n</sub> within the setup time required by the MCASP (setup time) (n = 0 to 15).

The maximum service time (see [Figure 12-20](#)) can be calculated as:

$$\text{Service Time} = \text{Time Slot} - \text{XINT Latency} - \text{Setup Time}$$



**Figure 12-20. Service Time Upon Transmit DMA Event (XINT)**

#### 12.1.1.4.10.1.2 Receive Data Ready

Similarly, the receive data ready flag - RDATA in the MCASP\_RSTAT register reflects the data ready status of XRBUF $n$  buffers for all of the active slot receiving serializers. The RDATA flag is set whenever data is transferred from a receiving serializer shift register XRSR $n$  to its corresponding XRBUF $n$  data buffer. Thus, the RDATA bit indicates the global event that some of the receivers data buffer - XRBUF $n$  already contains received data (this is, a buffer is full) and is ready to transfer it to the host. The receive data ready event is individually indicated per serializer in its corresponding control register MCASP\_SRCTL $n$  [5] RRDY status bit. When this bit is set to 0b1, it notifies to host that this serializer Rx buffer must be serviced (read). When MCASP\_RBUFn register is read from the host, the MCASP\_SRCTL $n$  [5] RRDY bit is deasserted to 0b0. As RDATA global flag is an OR-event of all active serializers RRDY flags, it indicates to software the moment, when read service operation has to be initiated by the MCASP host (RDATA = 0b1). The RRDY flags have to be sequentially scanned by user software to determine which serializer MCASP\_RBUFn register has to be currently read. Once all requested MCASP\_RBUFn registers are read, the serializers control RRDY flags are cleared to 0b0. As a consequence, RDATA flag is deasserted to 0b0, to indicate to SW that read operation is completed for all serializers.

The global RDATA flag can be cleared when the MCASP\_RSTAT[5] RDATA bit is written to 0b1, or once MCASP\_RBUFn registers of all the serializers, that have previously raised their RRDY flags, are read by the host.

Whenever RDATA flag is set, the RINT event is automatically generated on MCASP[0-2]\_REC\_DMA\_EVT line (if enabled in the MCASP\_PIDTCTL register) to notify the DMA of the MCASP\_RBUFn full status. An interrupt - MCASP[0-2]\_REC\_INTR\_PEND can be also generated if the RDATA interrupt is enabled in the MCASP\_RINTCTL register (for details, see [Section 12.1.1.4.12.1, Receive Data Ready Interrupt](#)).

[Figure 12-21](#) shows the timing details of when RINT event is generated at the MCASP boundary. In this example, as soon as the last bit (bit A0) of Word A is received, the MCASP sets the RDATA flag and generates an RINT event. However, it takes up to five MCASP interface clocks (RINT Latency) before RINT is active at the MCASP boundary. Upon RINT, the CPU can begin servicing the MCASP by reading Word A from the MCASP\_RBUFn (service time). The CPU must read Word A from the MCASP\_RBUFn register no later than the setup time required by the MCASP (Setup Time) ( $n = 0$  to 15).

The maximum service time (see [Figure 12-21](#)) can be calculated as:

$$\text{Service Time} = \text{Time Slot} - \text{RINT Latency} - \text{Setup Time}$$



**Figure 12-21. CPU Service Time Upon Receive Event (RINT)**

#### 12.1.1.4.10.1.3 Transfers Through the Data Port (DATA)

##### CAUTION

To perform internal transfers through the DATA port, clear the XBUSEL/RBUSEL bit to 0b0 in the MCASP\_XFMT/MCASP\_RFMT register, respectively. Failure to do so may result in software malfunction.

In a typical MCASP transfer scenario, the DMA Controller write accesses the XRBUF<sub>n</sub> transmit buffer through the MCASP data port (DATA) on CBASS0 Interconnect. CPU hosts can access both XRBUF<sub>n</sub> transmit and receive data buffers on their corresponding DATA port address via DATA port corresponding address. To perform transfers through the DATA port, simply have the DMA Controller write the MCASP Tx buffer through Interconnect DATA port location. Refer to *DMA Registers*. Although the transfer is passed through an integrated AFIFO transmit/receive buffer, the host (DMA or CPU) must follow the described below procedure to access the data buffers of each serializer, regardless the AFIFO is enabled or disabled. The AFIFO operation is described in [Section 12.1.1.4.11](#).

For accesses through the DATA port, the DMA/CPU services all the serializers through accessing only a single address. In addition, as can be seen in *DMA Registers*, the same physical DATA port address is used regardless of a read or write access is performed. The MCASP automatically cycles through the active slot transmitting/receiving serializers, internally generating the appropriate offsets.

##### Note

DATA port allows the DMA/CPU to automatically access only the data buffers. There is no way for DMA/CPU to access the MCASP configuration registers addressing their corresponding MCASP DATA port.

For transmit operations through the DATA port, the host must always write to the same transmit buffer DATA port address (which is same than the receive buffer DATA port address) to service all of the active slot transmitting serializers. Regardless of MCASP serializer 0 being configured inactive or active, the user software must always configure the destination address to match the DATA port location of TXBUF buffer (See *DMA Registers*).

In addition, the DMA/CPU must write the buffers of all transmitting serializers in incremental (although not necessarily consecutive) order. For example, if only serializers 1 and 3 are set up as active transmitters, to the same transmit buffer DATA port address twice - first data for serializer 1 and second data for serializer 3

upon each transmit data ready event. This exact servicing order must be followed so that data appears in the appropriate serializers.

---

**Note**

For write transfers through MCASP DATA port it is preferable to use DMA on corresponding Interconnect. This is because DMAs initiated traffic gets better advantage of the burst transfers supported by DATA port.

For receive operations through the DATA port, the DMA/CPU must always read from the same receive buffer DATA port address (which is same than the transmit buffer DATA port address) to service all of the active slot receiving serializers. Regardless of MCASP serializer 0 being configured inactive or active, the user software must always configure the DMA/CPU source address to match the DATA port location of RXBUF buffer (See *DMA Registers*).

In addition, reads from the receive buffer for all active slot receiving serializers through the Rx DATA port return data in incremental (although not necessarily consecutive) order. For example, if serializers 0, 1 and 3 are set up as active receivers, the CPU should read from the same receive buffer DATA port address three times to obtain data for serializers 0, 1 and 3 in this exact order, upon each receive data ready event.

---

**Note**

To service a serializer for a transmit or receive operation through the MCASP DATA port, the initiator always writes (preferably DMA) and reads from the same address (refer to *DMA Registers*), respectively.

---

**Note**

When transmitting through the DATA port, the DMA/CPU must write data (at the same address) to each serializer configured as *active* (active slot selected in MCASP\_XTDM) and *transmit* (Tx enabled in MCASP\_SRCTLn) within each time slot. Failure to do so results in a buffer underrun condition (see [Section 12.1.1.4.15.1, Buffer Underrun Error - Transmitter](#)). Similarly, when DMA/CPU receives, data must be read from each serializer configured as *active* (active slot selected in MCASP\_RTDM) and *receive* (Rx enabled in MCASP\_SRCTLn) within each time slot. Failure to do so results in a buffer overrun condition (see [Section 12.1.1.4.15.2, Buffer Overrun Error - Receiver](#)) (n = 0 to 15).

#### **12.1.1.4.10.1.4 Transfers Through the Configuration Bus (CFG)**

**CAUTION**

To perform internal transfers through the configuration bus, set the XBUSEL/RBUSEL bit to 1 in the MCASP\_XFMT/MCASP\_RFMT registers, respectively. Failure to do so may result in software malfunction.

---

**Note**

MCASP[0-2] whose data ports are accessible directly via CBASS0 do not support FIFO/constant addressing modes. Incrementing transfers must be used instead.

In this method, the CPU accesses the XRBUFn transmit or receive buffer through corresponding configuration bus (CFG) address.

The exact XRBUFn transmit/receive buffer physical address for any particular serializer is determined by adding the transmit/receive buffer alias register offset for that particular serializer to the base address of MCASP CFG port actual for CBASS0 accesses. The XRBUFn buffer of the n-th serializer configured as a transmitter is aliased

- MCASP\_XBUFn in the CFG port address space. For example, the XRBUF2 transmit buffer is mapped as the MCASP\_XBUF2 register. Similarly, the XRBUFn buffer of the n-th serializer configured as a receiver is aliased
- MCASP\_RBUFn in the CFG port address space. For example, the XRBUF3 receive buffer is mapped as the MCASP\_RBUF3 register.

Accessing the XRBUF through the DATA port (see [Section 12.1.1.4.10.1.3](#)) is different than CFG port accesses because the DATA port access demands the same physical address, regardless of transfer direction or current channel index, while accessing through the peripheral configuration port - CFG, the CPU must provide the exact MCASP\_XBUFn or MCASP\_RBUFn address upon accessing n-th serializer TX or RX buffer, respectively. For more details about MCASP\_XBUFn and MCASP\_RBUFn addresses corresponding to MCASP CFG port, see *CFG Registers* (n = 0 to 15).

#### 12.1.1.4.10.1.5 Using a Device CPU for MCASP Servicing

The device CPUs can be used to service the MCASP transmit channels through interrupts (upon MCASP[0-2]\_XMIT\_INTR\_PEND and MCASP[0-2]\_REC\_INTR\_PEND interrupts). Because these interrupt events are connected to device COMPUTE\_CLUSTER0, PRUSS, MAIN2MCU\_LVL\_INTRTR0, R5FSS0/1\_INTRTR0, C66SS0/1\_INTRTR0, R5FSS0/1 modules, they could be software mapped to input interrupt lines of any device CPU. Another way to service the transmit and receive channels, a polling of the XDATA bit in the MCASP\_XSTAT register and RDATA bit in the MCASP\_RSTAT register can be performed by device CPUs, respectively. As discussed in [Section 12.1.1.4.10.1.3, Transfers Through the Data Port \(DATA\)](#), and [Section 12.1.1.4.10.1.4, Transfers Through the Configuration Bus \(CFG\)](#), the device CPUs can access MCASP XRBUF serializer buffer through their corresponding DATA and CFG port locations.

To use the device CPUs to service the MCASP through interrupts, the XDATA/RDATA bit must be enabled in the respective MCASP\_XINTCTL/MCASP\_RINTCTL registers, to generate interrupts MCASP[0-2]\_XMIT\_INTR\_PEND/MCASP[0-2]\_REC\_INTR\_PEND to the device CPUs upon data ready

#### 12.1.1.4.10.1.6 Using the DMA for MCASP Servicing

---

##### Note

The associated static Transfer Request (TR) operations of PDMA0, located in front of MCASP, must be configured to match the MCASP configuration. For more information, refer to chapter *DMA Controllers*.

The typical scenario is to use the DMA to service the MCASP transmit and receive logic through the DATA port. The transfer passes through integrated AFIFO transmit/receive buffer. If AFIFO is enabled, DMA requests are collected and fed to a device DMA controller (see [Figure 12-11](#)). The data transfer is managed by the AFIFO according to generated transmit and receive events in the MCASP and data is fed to transmit buffers and fetched from receive buffers as described in [Section 12.1.1.4.11, MCASP Audio FIFO \(AFIFO\)](#). The generation of transmit and receive request is described below. After generation of transmit/receive DMA events from MCASP module, these events are collected in AFIFO and on specific AFIFO conditions described in [Section 12.1.1.4.11, MCASP Audio FIFO \(AFIFO\)](#) the requests (transmit or receive) are forwarded to a DMA controller via MCASP[0-2]\_XMIT\_DMA\_EVT and MCASP[0-2]\_REC\_DMA\_EVT outputs. If the AFIFO is disabled (default state) it is transparent for the MCASP module and all request are directly sent to the DMA controller.



**Figure 12-22. DMA Transmit and Receive Event in an Audio Example – One Event**

In transmit mode, the DMA event - XINT (MCASP[0-2]\_XMIT\_DMA\_EVT output), which is triggered upon each XDATA transition from 0 to 1, is used to service the MCASP TXBUFn transmit buffers. In receive mode, the DMA event RINT (MCASP[0-2]\_REC\_DMA\_EVT output) which is triggered upon each RDATA transition from 0 to 1, is used to service the MCASP RXBUFn receive buffers.

Figure 12-22 is an example of an audio system with six audio channels (LF, RF, LS, RS, C and LFE) transmitted or received through the MCASP signals - AXR0, AXR1 and AXR2. It shows the points at which events XINT/ RINT are triggered.

In Figure 12-22, a Tx DMA event XINT is triggered on each time slot. In the example, XINT is triggered for each of the transmit audio channel time slot (time slot for channels LF, LS, and C; and time slot for channels RF, RS, LFE). Transmit DMA events are generated automatically upon transmit data ready, provided that DMA TX requests generation is enabled in the MCASP\_XEVTCCTL register. Similarly, Rx DMA event RINT is triggered for each of the receive audio channel time slot. Receive DMA events are generated automatically upon receive data ready, provided that DMA RX requests generation is enabled in the MCASP\_PIDTCTL register.

#### 12.1.1.4.11 MCASP Audio FIFO (AFIFO)

The AFIFO contains two FIFOs: one Read FIFO (RFIFO), and one Write FIFO (WFIFO). The RFIFO and the WFIFO are the same size: 64 32-bit Words. To ensure backward compatibility with existing software, both the Read and Write FIFOs are disabled by default. See Figure 12-23 for a high-level block diagram of the AFIFO. The AFIFO may be enabled/disabled and configured via the MCASP\_WFIFOCTL and MCASP\_RFIFOCTL registers. Note that if the Read or Write FIFO is to be enabled, it must be enabled prior to initializing the receive/transmit section of the MCASP.



**Figure 12-23. MCASP Audio FIFO (AFIFO) Block Diagram**

#### 12.1.1.4.11.1 AFIFO Data Transmission

When the Write FIFO is disabled, transmit DMA requests pass through directly from the MCASP to the host/DMA controller. Whether the WFIFO is enabled or disabled, the MCASP generates transmit DMA requests as needed; the AFIFO is “invisible” to the MCASP. When the Write FIFO is enabled, transmit DMA requests from the MCASP are sent to the AFIFO, which in turn generates transmit DMA requests to the host/DMA controller. If the Write FIFO is enabled, upon a transmit DMA request from the MCASP, the WFIFO writes WNUMDMA 32-bit words to the MCASP if and when there are at least WNUMDMA words in the Write FIFO. If there are not, the WFIFO waits until this condition has been satisfied. At that point, it writes WNUMDMA words to the MCASP (see description for the MCASP\_WFIFOCTL[7-0] WNUMDMA). If the host CPU writes to the Write FIFO, independent of a transmit DMA request, the WFIFO will accept host writes until full. After this point, excess data will be discarded. Note that when the WFIFO is first enabled, it will immediately issue a transmit DMA request to the host. This is because it begins in an empty state, and is therefore ready to accept data.

##### 12.1.1.4.11.1.1 Transmit DMA Event Pacer

The AFIFO may be configured to delay making a transmit DMA request to the host until the Write FIFO has enough space for a specified number of words. In this situation, the number of transmit DMA requests to the

host or DMA controller is reduced. If the Write FIFO has space to accept WNUMEV 32-bit words, it generates a transmit DMA request to the host and then waits for a response. Once WNUMEV words have been written to the FIFO, it checks again to see if there is space for WNUMEV 32-bit words. If there is space, it generates another transmit DMA request to the host, and so on. In this fashion, the Write FIFO will attempt to stay filled. Note that if transmit DMA event pacing is desired, MCASP\_WFIFOCTL[15-8] WNUMEV bit field should be set to a non-zero integer multiple of the value in MCASP\_WFIFOCTL[7-0] WNUMDMA bit field. If transmit DMA event pacing is not desired, then the value in MCASP\_WFIFOCTL[15-8] WNUMEV bit field should be set equal to the value in MCASP\_WFIFOCTL[7-0] WNUMDMA bit field.

#### 12.1.1.4.11.2 AFIFO Data Reception

When the Read FIFO is disabled, receive DMA requests pass through directly from MCASP to the host/DMA controller. Whether the RFIFO is enabled or disabled, the MCASP generates receive DMA requests as needed; the AFIFO is “invisible” to the MCASP. When the Read FIFO is enabled, receive DMA requests from the MCASP are sent to the AFIFO, which in turn generates receive DMA requests to the host/DMA controller. If the Read FIFO is enabled and the MCASP makes a receive DMA request, the RFIFO reads RNUMDMA 32-bit words from the MCASP, if and when the RFIFO has space for RNUMDMA words. If it does not, the RFIFO waits until this condition has been satisfied; at that point, it reads RNUMDMA words from the MCASP (see description for the MCASP\_RFIFOCTL[7-0] RNUMDMA). If the host CPU reads the Read FIFO, independent of a receive DMA request, and the RFIFO at that time contains less than RNUMEV words, those words will be read correctly, emptying the FIFO.

#### 12.1.1.4.11.2.1 Receive DMA Event Pacer

The AFIFO may be configured to delay making a receive DMA request to the host until the Read FIFO contains a specified number of words. In this situation, the number of receive DMA requests to the host or DMA controller is reduced. If the Read FIFO contains at least RNUMEV 32-bit words, it generates a receive DMA request to the host and then waits for a response. Once RNUMEV 32-bit words have been read from the RFIFO, the RFIFO checks again to see if it contains at least another RNUMEV words. If it does, it generates another receive DMA request to the host, and so on. In this fashion, the Read FIFO will attempt to stay empty. Note that if receive DMA event pacing is desired, MCASP\_RFIFOCTL[15-8] RNUMEV bit field should be set to a non-zero integer multiple of the value in MCASP\_RFIFOCTL[7-0] RNUMDMA bit field. If receive DMA event pacing is not desired, then the value in MCASP\_RFIFOCTL[15-8] RNUMEV bit field should be set equal to the value in MCASP\_RFIFOCTL[7-0] RNUMDMA bit field.

#### 12.1.1.4.11.3 Arbitration Between Transmit and Receive DMA Requests

If both the WFIFO and the RFIFO are enabled and a transmit DMA request and receive DMA request occur simultaneously, priority is given to the transmit DMA request. Once a transfer is in progress, it is allowed to complete. If only the WFIFO is enabled and a transmit DMA request and receive DMA request occur simultaneously, priority is given to the transmit DMA request. Once a transfer is in progress, it is allowed to complete. If only the RFIFO is enabled and a transmit DMA request and receive DMA request occur simultaneously, priority is given to the receive DMA request. Once a transfer is in progress, it is allowed to complete.

#### 12.1.1.4.12 MCASP Events and Interrupt Requests

Table 12-9 lists all the transmit event flags. Table 12-10 lists all the receive event flags. Source of each of these TX/RX events can be a TX/RX channel from any MCASP serializer configured as transmitter or receiver respectively.

**Table 12-9. TX Events**

| Event Mask <sup>(1)</sup> | Event Flag              | Map to <sup>(1)</sup>     | Description                    |
|---------------------------|-------------------------|---------------------------|--------------------------------|
| MCASP_XINTCTL[0] XUNDRN   | MCASP_XSTAT[0] XUNDRN   | MCASP[0-2]_XMIT_INTR_PEND | Transmit buffer underrun       |
| MCASP_XINTCTL[1] XSYNCERR | MCASP_XSTAT[1] XSYNCERR | MCASP[0-2]_XMIT_INTR_PEND | Unexpected transmit frame sync |
| MCASP_XINTCTL[2] XCKFAIL  | MCASP_XSTAT[2] XCKFAIL  | MCASP[0-2]_XMIT_INTR_PEND | Transmit clock failure         |

Table 12-9. TX Events (continued)

| Event Mask <sup>(1)</sup> | Event Flag              | Map to <sup>(1)</sup>     | Description                                                                                                                   |
|---------------------------|-------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| MCASP_XINTCTL[3] XDMAERR  | MCASP_XSTAT[7] XDMAERR  | MCASP[0-2]_XMIT_INTR_PEND | DATA port transmit error                                                                                                      |
| MCASP_XINTCTL[4] XLAST    | MCASP_XSTAT[4] XLAST    | MCASP[0-2]_XMIT_INTR_PEND | Transmit last slot interrupt                                                                                                  |
| MCASP_XINTCTL[5] XDATA    | MCASP_XSTAT[5] XDATA    | MCASP[0-2]_XMIT_INTR_PEND | Transmit data-ready interrupt                                                                                                 |
| MCASP_XINTCTL[7] XSTAfrm  | MCASP_XSTAT[6] XSTAfrm  | MCASP[0-2]_XMIT_INTR_PEND | Transmit start of frame interrupt                                                                                             |
| n.a.                      | MCASP_XSTAT[8] XERR     | n.a.                      | OR-event of all Tx-error events: (XDMAERR   XCKFAIL   XUNDRN   XSYNCERR). It is cleared ONLY when all error flags are cleared |
| n.a.                      | MCASP_XSTAT[3] XTDMslot | n.a.                      | Qualifies the current TDM slot as an odd or an even slot.                                                                     |

(1) Every MCASP module generates separate interrupt event.

Table 12-10. RX Events

| Event Mask <sup>(1)</sup> | Event Flag              | Map to <sup>(1)</sup>    | Description                                                                                                                      |
|---------------------------|-------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| MCASP_RINTCTL[0] ROVRN    | MCASP_RSTAT[0] ROVRN    | MCASP[0-2]_REC_INTR_PEND | Receive buffer overrun                                                                                                           |
| MCASP_RINTCTL[1] RSYNCERR | MCASP_RSTAT[1] RSYNCERR | MCASP[0-2]_REC_INTR_PEND | Unexpected receive frame sync                                                                                                    |
| MCASP_RINTCTL[2] RCKFAIL  | MCASP_RSTAT[2] RCKFAIL  | MCASP[0-2]_REC_INTR_PEND | Receive clock failure                                                                                                            |
| MCASP_RINTCTL[3] RDMAERR  | MCASP_RSTAT[7] RDMAERR  | MCASP[0-2]_REC_INTR_PEND | DATA port receive error                                                                                                          |
| MCASP_RINTCTL[4] RLAST    | MCASP_RSTAT[4] RLAST    | MCASP[0-2]_REC_INTR_PEND | Receive last slot                                                                                                                |
| MCASP_RINTCTL[5] RDATA    | MCASP_RSTAT[5] RDATA    | MCASP[0-2]_REC_INTR_PEND | Receive data-ready                                                                                                               |
| MCASP_RINTCTL[7] RSTAfrm  | MCASP_RSTAT[6] RSTAfrm  | MCASP[0-2]_REC_INTR_PEND | Receive start of frame                                                                                                           |
| n.a.                      | MCASP_RSTAT[8] RERR     | n.a.                     | OR-event of all Rx-error events: (RDMAERR   RCKFAIL   ROVRN   RSYNCERR). RERR event is cleared once all error flags are cleared. |
| n.a.                      | MCASP_RSTAT[3] RTDMslot | n.a.                     | Qualifies the current TDM slot as an odd or an even slot.                                                                        |

(1) Every MCASP module generates separate interrupt event.

Software has to read the MCASP\_XSTAT/MCASP\_RSTAT register to determine which event occurs at a global level for MCASP Tx/Rx logic. In addition user software has to scan the XRDY/RRDY read-only flags in the MCASP\_SRCTLn registers to determine which active serializer is the actual source of the event.

A Tx interrupt line (MCASP[0-2]\_XMIT\_INTR\_PEND) is asserted (active high) when one of the MCASP\_XSTAT notified events occurs, provided that it is enabled in its corresponding MCASP\_XINTCTL bit. Similarly, a Rx interrupt line (MCASP[0-2]\_REC\_INTR\_PEND) is asserted (active high) when one of MCASP\_RSTAT notified events occurs, provided that it is enabled in its corresponding MCASP\_RINTCTL bit. See also [Section 12.1.1.4.12.4, Multiple Interrupts](#) and the [Section 12.1.1.4.10.1, Data Ready Status and Event/Interrupt Generation](#) (n = 0 to 15).

#### 12.1.1.4.12.1 Transmit Data Ready Event and Interrupt

The transmit data-ready interrupt (XDATA) is generated if the MCASP\_XSTAT[5] XDATA bit is 1 and MCASP\_XINTCTL[5] XDATA bit is enabled. The [Section 12.1.1.4.10.1, Data Ready Status and Event/Interrupt Generation](#), provides details on when XDATA is set in the MCASP\_XSTAT register.

A transmit-start-of-frame interrupt (XSTAFRM) is triggered by the recognition of a transmit frame sync.

A transmit-last-slot interrupt (XLAST) is a qualified version of the data-ready interrupt (XDATA). It has the same behavior than the data-ready interrupt, but is further qualified by having the data requested belonging to the last slot (the slot that just ended is the next-to-last TDM slot, the current slot is the last slot).

#### 12.1.1.4.12.2 Receive Data Ready Event and Interrupt

The receive data-ready interrupt (RDATA) is generated if the MCASP\_RSTAT[5] RDATA bit is 1 and MCASP\_RINTCTL[5] RDATA bit is enabled. The [Section 12.1.1.4.10.1, Data Ready Status and Event/Interrupt Generation](#), provides details on when the MCASP\_RSTAT[5] RDATA bit is set.

A receiver start of frame (RSTAFRM) interrupt is triggered by the recognition of a receiver frame sync.

A receiver last slot (RLAST) interrupt is a qualified version of the data ready interrupt (RDATA). It has the same behavior as the data ready interrupt, but is further qualified by having the data in the buffer come from the last TDM time slot (the slot that just ended was last TDM slot).

#### 12.1.1.4.12.3 Error Interrupt

Upon detection, the following error conditions generate interrupt flags:

In the transmit status register (MCASP\_XSTAT):

- Transmit underrun (XUNDRN)
- Unexpected transmit frame sync (XSYNCERR)
- Transmit clock failure (XCKFAIL)
- Transmit DATA port error (XDMAERR)

Each interrupt source also has a corresponding enable bit in the transmit interrupt control register (MCASP\_XINTCTL). If the enable bit is set, an interrupt is requested when the interrupt flag is set in MCASP\_XSTAT. If the enable bit is not set, no interrupt request is generated. However, the interrupt flag may be polled.

In the receive status register (MCASP\_RSTAT) :

- Receiver overrun (ROVRN)
- Unexpected receive frame sync (RSYNCERR)
- Receive clock failure (RCKFAIL)
- Receive DATA port error (RDMAERR)

Each interrupt source also has a corresponding enable bit in the receive interrupt control register (MCASP\_RINTCTL). If the enable bit is set, an interrupt is requested when the interrupt flag is set in MCASP\_RSTAT. If the enable bit is not set, no interrupt request is generated. However, the interrupt flag may be polled.

#### 12.1.1.4.12.4 Multiple Interrupts

This only applies to interrupts and not to DMA requests. The following terms are defined:

- **Active Interrupt Request:** a flag in MCASP\_XSTAT is set and the interrupt is enabled in MCASP\_XINTCTL.
- **Outstanding Interrupt Request:** An interrupt request has been issued on one of the MCASP transmit interrupt port, but that request has not yet been serviced.
- **Serviced:** The CPUs write to MCASP\_XSTAT to clear one or more of the active interrupt request flags.

The first interrupt request to become active for the serializer with the interrupt flag set in MCASP\_XSTAT/ MCASP\_RSTAT and the interrupt enabled in MCASP\_XINTCTL/MCASP\_RINTCTL generates a request on the MCASP transmit or receive interrupt port.

If more than one interrupt request becomes active in the same cycle, a single interrupt request is generated on the MCASP transmit or receive interrupt port. Subsequent interrupt requests that become active while the first interrupt request is outstanding do not immediately generate a new request pulse on the MCASP transmit or receive interrupt port.

The interrupt is serviced with the CPU writing to MCASP\_XSTAT/MCASP\_RSTAT. If any interrupt requests are active after the write, a new request is generated on the MCASP transmit or receive interrupt port.

One outstanding interrupt request is allowed on each port, so a transmit and a receive interrupt request may both be outstanding at the same time.

#### 12.1.1.13 MCASP DMA Requests

The MCASP can generate one DMA request to the DMA controller to transmit (MCASP[0-2]\_XMIT\_DMA\_EVT) or receive (MCASP[0-2]\_REC\_DMA\_EVT) data. A DMA request to transmit data is generated if the MCASP\_XEVTCCTL[0] XDATDMA bit is cleared. A DMA request to receive data is generated if the MCASP\_PIDTCTL[0] RDATDMA bit is cleared.

#### 12.1.1.14 MCASP Loopback Modes

The MCASP features a digital loopback mode (DLB) that allows loopback test transfers in TDM mode between MCASP transmitters and receivers within the same device. In loopback mode, the output of a transmit serializer is connected internally to the input of a receive serializer. Therefore, a receiver data can be checked against a transmitter data to ensure that the MCASP settings are correct. Digital loopback mode applies to TDM mode only (2 to 32 slots in a frame). It does not apply to DIT mode (XMOD = 0x180) or burst mode (XMOD = 0).

Figure 12-24 shows the basic logical connection of the serializers in loopback mode.



mcasp-023

**Figure 12-24. MCASP Serializers Operation in Loopback Mode**

Two types of loopback connections are possible, selected by the ORD bit in the digital loopback control register - MCASP\_DLBCCTL as follows:

- ORD = 0: Outputs of odd serializers are connected to inputs of even serializers. If this mode is selected, the odd serializers must be configured as transmitters and even serializers as receivers.
- ORD = 1: Outputs of even serializers are connected to inputs of odd serializers. If this mode is selected, the even serializers must be configured as transmitters and odd serializers as receivers.

User can choose in software (the MCASP\_DLBCCTL[4] IOLBEN bit) between a MCASP module internal loopback and a device I/O level loopback.

When a **MCASP internal loopback** is selected (MCASP\_DLBCCTL[4] IOLBEN = 0b0 ), it is NOT necessary to configure *MCASP\_PFUNC* and *MCASP\_PDIR* registers for MCASP pin settings. Nevertheless, data can be optionally made externally visible at the I/O pin of the transmit serializer, if the pin is configured as a MCASP output pin by setting the corresponding *MCASP\_PFUNC* bit to 0 (this is, to function as MCASP, not GPIO) and *MCASP\_PDIR* bit to 1 (output).

When a **device I/O level loopback** is selected (MCASP\_DLBCCTL[4] IOLBEN = 0b1 ), the *MCASP\_PFUNC* and *MCASP\_PDIR* registers must be configured with the appropriate settings for all AXRn pins, according to ORD bit configuration.

In case of device I/O loopback, the connectivity is externally applied between device pads (this is, reaching device I/O buffers ).

When in loopback mode, the transmit clock and frame sync are used by both the transmit and receive sections of the MCASP. The transmit and receive sections operate synchronously. This is achieved by setting the MCASP\_DLBCCTL[3-2] MODE bit field to 0x1 and the *MCASP\_ACLKXCTL*[6] ASYNC bit to 0b0.

#### 12.1.1.4.14.1 Loopback Mode Configurations

This is a summary of the settings required for digital loopback mode for TDM format :

- The MCASP\_DLBCCTL[0] DLBEN bit must be set to 0b1 to enable a loopback mode. It must be kept at 0b0 during normal MCASP operation.
- The MCASP\_DLBCCTL[4] IOLBEN bit must be set to select between internal (MCASP local) loopback mode or device I/O level loopback mode.
- The MCASP\_DLBCCTL[3-2] MODE bit field must be set to 0x1 for both the transmit and receive sections to use the transmit clock and frame sync generator.
- The MCASP\_DLBCCTL[1] ORD bit must be programmed appropriately to select odd or even serializers to be transmitters or receivers.
- The corresponding serializers must be configured accordingly.
- The *MCASP\_ACLKXCTL*[6] ASYNC bit must be cleared to 0b0 to ensure synchronous transmit and receive operations.
- The MCASP\_AFSRCTL[15-7] RMOD bit field and MCASP\_AFSXCTL[15-7] XMOD bit field must be set within range (0x2 - 0x20) to indicate TDM mode.

---

#### Note

Loopback mode does not apply to DIT or burst mode, because MCASP receivers do NOT natively support DIR - reception.

---

#### 12.1.1.4.15 MCASP Error Reporting

The MCASP includes error-checking capability for the serial protocol and data underrun. In addition, the MCASP includes a timer that continually measures the high-frequency controller clock every 32 AHCLKX clock cycles. The value of the timer can be read to get a measurement of the clock frequency and has a minimum and maximum range setting that can set an error flag if the controller clock goes out of a specified range.

When one or more errors (software selectable) are detected, an interrupt can be generated if desired, based on one or more error sources.

#### 12.1.1.4.15.1 Buffer Underrun Error -Transmitter

A buffer underrun occurs when a serializer is instructed by the transmit state-machine to transfer data from XRBUFn buffer to XRSRn shift register, but the corresponding (MCASP\_XBUFn ) register has not yet been written with new data since the last time the transfer occurred. When this occurs, the transmit state-machine sets the XUNDRN flag.

An underrun is checked only once per time slot. The MCASP\_XSTAT[0] XUNDRN flag is set when an underrun condition occurs. Once set, the XUNDRN flag remains set until the host explicitly writes 1 to the XUNDRN bit to clear it (n = 0 to 15).

In DIT mode, a pair of BMC zeros is shifted out when an underrun occurs (four bit times at 128 bps). By shifting out a pair of zeros, a clock can be recovered on the receiver. To recover, reset the MCASP and restart with the proper initialization.

In TDM mode, during an underrun case, a long stream of zeros are shifted out causing the DACs to mute. To recover, reset the MCASP and start again with the proper initialization.

#### **12.1.1.4.15.2 Buffer Overrun Error-Receiver**

A buffer overrun occurs when a serializer is instructed to transfer data from XRSRn shift register to XRBUFn receiver buffer, but the corresponding MCASP\_RBUFn register has not yet been read since the last time the transfer occurred. When this occurs, the receiver state machine sets the overrun flag - ROVRN. However, the individual serializer writes over the data in the XRBUFn buffer register (destroying the previous sample) and continues shifting (n = 0 to 15).

An overrun is checked only once per time slot. The MCASP\_RSTAT[0] ROVRN flag is set when an overrun condition occurs. It is possible that an overrun occurs on one time slot but then the host catches up and does not cause an overrun on the following time slots. However, once the ROVRN flag is set, it remains set until the host explicitly writes a 1 to the ROVRN bit to clear the ROVRN bit.

#### **12.1.1.4.15.3 DATA Port Error - Transmitter**

A transmit DATA port error, as indicated by the MCASP\_XSTAT[7] XDMAERR bit, occurs when the DMA or device CPU writes more words to the DATA port of the MCASP than it should.

The MCASP\_XSTAT[7] XDMAERR = 0b1 indicates that the DMA or device CPU wrote too many words to the MCASP DATA port for a given transmit DMA event. Writing too few words results in a transmit underrun error setting the MCASP\_XSTAT[0] XUNDRN bit.

While XDMAERR occurs infrequently, an occurrence indicates a serious loss of synchronization between the MCASP and the DMA or device CPU. The MCASP transmitter and the DMA must be reinitialized to resynchronize them.

#### **12.1.1.4.15.4 DATA Port Error - Receiver**

A receive DATA port error, as indicated by the MCASP\_RSTAT[7] RDMAERR bit, occurs when the DMA or device CPU reads more words from the DATA port of the MCASP than it should.

The MCASP\_RSTAT[7] RDMAERR bit indicates that the DMA or device CPU read too many words from the MCASP DATA port for a given receive RINT event. Reading too few words results in a receiver overrun error setting the MCASP\_RSTAT[0] ROVRN bit.

While RDMAERR occurs infrequently, an occurrence indicates a serious loss of synchronization between the MCASP and the DMA or device CPU. The MCASP receiver and the DMA must be reinitialized to resynchronize them.

#### **12.1.1.4.15.5 Unexpected Frame Sync Error**

An unexpected frame sync occurs in when:

- in burst mode and TDM mode, the next active edge of the frame sync occurs early such that the current slot will not be completed by the time the next slot is scheduled to begin.
- in TDM mode, an unexpected frame sync occurs also if the frame sync does NOT occur exactly during the correct bit clock (not a cycle earlier or later) and before slot 0.

When an unexpected frame sync occurs, there are two possible actions depending upon when the unexpected frame sync occurs:

1. **Early:** An early unexpected frame sync occurs when the MCASP is in the process of completing the current frame and a new frame sync is detected (not including overlap that occurs due to a 1 or 2 bit frame sync delay). When an early unexpected frame sync occurs:
  - Error event flag is set (XSYNCERR, if an unexpected transmit frame sync occurs; RSYNCERR, if an unexpected receive frame sync occurs).

- Current frame is not resynchronized. The number of bits in the current frame is completed. The next frame sync, which occurs after the current frame is completed, will be resynchronized.
2. **Late:** A late unexpected frame sync occurs when there is a gap or delay between the last bit of the previous frame and the first bit of the next frame. When a late unexpected frame sync occurs (as soon as the gap is detected):
- Error event flag is set (XSYNCERR, if an unexpected transmit frame sync occurs; RSYNCERR, if an unexpected receive frame sync occurs).
  - Resynchronization occurs upon the arrival of the next frame sync.

Late frame sync is detected the same way in burst mode and TDM mode. However, in burst mode, late frame sync is not meaningful and its interrupt enable should not be set.

#### 12.1.1.4.15.6 Clock Failure Detection

##### 12.1.1.4.15.6.1 Clock Failure Check Startup

It is initially expected of the clock failure circuits to generate an error until at least one measurement is taken. Therefore, the clock failure interrupts, clock switch, and mute functions should not be enabled immediately, but only after a specific startup procedure.

To start the transmit clock failure check procedure:

1. Configure the transmit clock failure detect logic (XMIN, XMAX, XPS) in the transmit clock check control register (MCASP\_XCLKCHK).
2. Clear the transmit clock failure flag (XCKFAIL) in the transmit status register (MCASP\_XSTAT).
3. Wait until the first measurement is taken (> 32 AHCLKX clock periods).
4. Verify that no clock failure is detected.
5. Repeat Step 2 through Step 4 until the clock is running and is no longer issuing clock failure errors.
6. After the transmit clock is measured and falls within the acceptable range, the following can be enabled:
  - a. The transmit clock failure interrupt enable bit (XCKFAIL) in the transmitter interrupt control register (MCASP\_XINTCTL)

To start the receive clock failure check procedure:

1. Configure receive clock failure detect logic (RMIN, RMAX, RPS) in the receive clock check control register (MCASP\_RCLKCHK).
2. Clear receive clock failure flag (RCKFAIL) in the receive status register (MCASP\_RSTAT).
3. Wait until first measurement is taken (> 32 AHCLKR clock periods).
4. Verify no clock failure is detected.
5. Repeat steps 2–4 until clock is running and is no longer issuing clock failure errors.
6. After the receive clock is measured and falls within the acceptable range, the following may be enabled:
  - a. the receive clock failure (RCKFAIL) interrupt enable bit in the receive interrupt control register (MCASP\_RINTCTL)

##### 12.1.1.4.15.6.2 Transmit Clock Failure Check and Recovery

The transmit clock failure check circuit (see [Figure 12-25](#)) works off the internal MCASP interface clock and the external high-frequency serial clock (AHCLKX). It continually counts the number of interface clocks for every 32 high-rate serial clock (AHCLKX) periods, and stores the count in XCNT of the transmit clock check control register (MCASP\_XCLKCHK) every 32 high-rate serial clock cycles.

The logic compares the count against a user-defined minimum allowable boundary (XMIN), and automatically flags an interrupt (the MCASP\_XSTAT[2] XCKFAIL bit) when an out-of-range condition occurs. An out-of-range minimum condition occurs when the count is less than XMIN. The logic continually compares the current count (from the running interface clock counter) to the maximum allowable boundary (XMAX). This is so that if the external clock completely stops, the counter value is not copied to XCNT. An out-of-range maximum condition occurs when the count is greater than XMAX. The XMIN and XMAX fields are 8-bit unsigned values, and the comparison is performed using unsigned arithmetic.

An out-of-range count may indicate that an unstable clock was detected or that the audio source has changed and a new sample rate is being used.

For the transmit clock failure check circuit to operate correctly, the high-frequency serial clock divider must be taken out of reset.

If a clock failure is detected, the MCASP\_XSTAT[2] XCKFAIL transmit clock failure flag is set. This causes an interrupt if the MCASP\_XINTCTL[2] XCKFAIL transmit clock failure interrupt enable bit is set.



mcasp-024

**Figure 12-25. Transmit Clock Failure Detection Circuit Block Diagram**

#### 12.1.1.4.15.6.3 Receive Clock Failure Check and Recovery

The receive clock failure check circuit (see Figure 12-26) works off both the internal MCASP interface clock and the external high-frequency serial clock (AHCLKR). It continually counts the number of interface clocks for every 32 high rate serial clock (AHCLKR) periods, and stores the count in RCNT of the receive clock check control register (MCASP\_RCLKCHK) every 32 high rate serial clock cycles.

The logic compares the count against a user-defined minimum allowable boundary (RMIN) and automatically flags an event (the MCASP\_RSTAT[2] RCKFAIL bit) when an out-of-range condition occurs. An out-of-range minimum condition occurs when the count is smaller than RMIN. The logic continually compares the current count (from the running interface clock counter) against the maximum allowable boundary (RMAX). This is in case the external clock completely stops, so that the counter value is not copied to RCNT. An out-of-range maximum condition occurs when the count is greater than RMAX. Note that the RMIN and RMAX fields are 8-bit unsigned values, and the comparison is performed using unsigned arithmetic.

An out-of-range count may indicate either that an unstable clock was detected or that the audio source has changed and a new sample rate is being used.

In order for the receive clock failure check circuit to operate correctly, the high-frequency serial clock divider must be taken out of reset.



mcasp-025

**Figure 12-26. Receive Clock Failure Detection Circuit Block Diagram**

### 12.1.1.5 MCASP Programming Guide

This section describes the low-level hardware programming sequences for the configuration and use of the MCASP module.

#### 12.1.1.5.1 MCASP Global Initialization

##### 12.1.1.5.1.1 Surrounding Modules Global Initialization

This section identifies the requirements for initializing the surrounding modules when the MCASP module is used for the first time after a device reset. This initialization of surrounding modules is based on the integration and environment of the MCASP (for more information, see *Module Integration*, and *MCASP Environment* ).

**Table 12-11** describes the global initialization of surrounding modules.

**Table 12-11. Global Initialization of Surrounding Modules**

| Surrounding Modules  | Comments                                                                                                                                                            |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPSC3                | Module reset must be enabled. For more information about the module configuration, see <i>Reset</i> .                                                               |
| PLLCTRL0             | PLLCTRL0 configuration must be done to enable the clocks to the MCASP modules, see <i>Clocking</i> .                                                                |
| PLL4                 | PLL4 configuration must be done to enable the clocks to the MCASP modules, see <i>Clocking</i> .                                                                    |
| PLL2                 | PLL2 configuration must be done to enable the clocks to the MCASP modules, see <i>Clocking</i> .                                                                    |
| ATL                  | ATL configuration must be done to enable the clocks to the MCASP modules, see <i>Audio Tracking Logic (ATL)</i> .                                                   |
| COMPUTE_CLUSTER0     | Device INTCs must be configured to enable the interrupt request generation. For information about enabling COMPUTE_CLUSTER0 interrupts, see <i>Interrupts</i> .     |
| MAIN2MCU_LVL_INTRTR0 | Device INTCs must be configured to enable the interrupt request generation. For information about enabling MAIN2MCU_LVL_INTRTR0 interrupts, see <i>Interrupts</i> . |
| R5FSS0_CORE0/1       | Device INTCs must be configured to enable the interrupt request generation. For information about enabling R5FSS0_CORE0/1 interrupts, see <i>Interrupts</i> .       |
| PDMA0_MCASP_G0       | PDMA0_MCASP_G0 controllers configuration must be done to enable the module PDMA0_MCASP_G0 channel request, see <i>PDMA Controller</i> .                             |
| Interconnects        | For information about the CBASS0 interconnects configuration, see <i>System Interconnect</i> .                                                                      |

#### Note

NAVSS configuration (UMDA channel set-up) must be done in order to move data from/to MCASP via the PDMA Controller. For more information, see *Navigator Subsystem (NAVSS)*.

#### Note

The COMPUTE\_CLUSTER0, MAIN2MCU\_LVL\_INTRTR0, R5FSS0\_CORE0/1, and the PDMA0\_MCASP\_G0 configurations are required when the interrupt and DMA-based communication modes are used. Further initialization of the selected interrupt and DMA controllers of the host CPU must be done for full functionality of the MCASP DMA and interrupt lines.

#### 12.1.1.5.1.2 MCASP Global Initialization

##### 12.1.1.5.1.2.1 Main Sequence – MCASP Global Initialization for DIT-Transmission

The procedure in **Table 12-12** initializes the MCASP serializers transmitters to operate in DIT-mode (S/PDIF-transmission protocol) after a power-on reset (POR).

#### CAUTION

Before performing MCASP global initialization, If external clock ACLKR is used, it must be running already for proper synchronization of the MCASP\_GBLCTL register.

**Table 12-12. MCASP Transmitters Global Initialization for DIT-Mode Operation**

| Step                                                                                                | Register/Bit Field/Programming Model           | Value              |
|-----------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------|
| 1. Apply software reset to different MCASP components.                                              | MCASP_GBLCTL[12-8]                             | 0x00               |
| 2. Poll the bits to ensure the active reset value (0x00) is successfully latched into the register. | MCASP_GBLCTL[12-8]                             | =0x00              |
| 3. Configure the local power management.                                                            | MCASP_PWRDLESYSCONFIG[1-0] IDLE_MODE           | 0x1                |
| 4. Configure the transmit format unit.                                                              | See <a href="#">Section 12.1.1.5.1.2.1.1</a> . |                    |
| 5. Configure the transmit frame sync generator.                                                     | See <a href="#">Section 12.1.1.5.1.2.1.2</a> . |                    |
| 6. Configure the transmit clock generator.                                                          | See <a href="#">Section 12.1.1.5.1.2.1.3</a> . |                    |
| 7. Configure the TDM sequencer—set all slots active.                                                | MCASP_XTDM[31-0] XTDMS                         | 0xFFFF FFFF        |
| 8. Configure the desired n-th serializer (n=0 to 3) for transmit mode operation. <sup>(3)</sup>     | MCASP_SRCTLn [1-0] SRMOD; n = 0 to 15          | 0x1                |
| 9. Configure the MCASP pins functionality.                                                          | See <a href="#">Section 12.1.1.5.1.2.1.4</a> . |                    |
| 10. Enable the MCASP DIT - transmission mode.                                                       | MCASP_DITCTL[0] DITEN                          | 0x1 <sup>(2)</sup> |
| 11. Configure DIT-specific subframe fields.                                                         | See <a href="#">Table 12-17</a> .              |                    |
| 12. Release from reset state the divider that outputs the AHCLKX clock. <sup>(1)</sup>              | MCASP_GBLCTL[9] XHCLKRST                       | 0x1                |
| 13. Poll the bit to ensure that it is successfully latched in the register.                         | MCASP_GBLCTL[9] XHCLKRST                       | =0x1               |
| 14. Release from reset state the divider that outputs the ACLKX clock. <sup>(1)</sup>               | MCASP_GBLCTL[8] XCLKRST                        | 0x1                |
| 15. Poll the bit to ensure that it is successfully latched in the register.                         | MCASP_GBLCTL[8] XCLKRST                        | =0x1               |

- (1) During reset state the local MCASP internal clock dividers maintain a 1:1 ratio at their outputs. The values stored in the MCASP\_AHCLKXCTL and MCASP\_ACLKXCTL registers are ignored; hence, the transmission clock does not stop during the reset state of the dividers.
- (2) This globally configures all active transmitters to operate in DIT-mode.
- (3) For an unused serializer n, write MCASP\_SRCTLn [1-0] SRMOD = 0x0 to disable it (n = 0 to 15).

### 12.1.1.5.1.2.1.1 Subsequence – Transmit Format Unit Configuration for DIT-Transmission

The procedure in [Table 12-13](#) configures the transmit frame format unit of the MCASP module for a DIT-transmission.

#### Note

- The first transmit data bit always has a 0-bit delay.
- The bitstream is always transmitted in least-significant-bit (LSB)-first order.
- Pad value for extra bits in a certain slot is always 0.

**Table 12-13. Transmit Format Unit Configuration for DIT-Transmission**

| Step                                                  | Register/Bit Field/Programming Model | Value  |
|-------------------------------------------------------|--------------------------------------|--------|
| Configure the slot size to 32 bits.                   | MCASP_XFMT[7-4] XSSZ                 | 0xF    |
| <b>IF:</b> the data to transmit is left- aligned      | Software test condition              |        |
| Set data mask in the range 0xFFFF FF00 – 0xFFFF 0000. | MCASP_XMASK[31-0] XMASK              | 0x-(1) |
| Rotate data right by a multiple-of-4- bit positions.  | MCASP_XFMT[2-0] XROT                 | 0x-(1) |
| <b>ELSE</b>                                           |                                      |        |
| Set data mask in the range 0x00FF FFFF– 0x0000 FFFF.  | MCASP_XMASK[31-0] XMASK              | 0x-(1) |
| Rotate data right by 0-bit positions.                 | MCASP_XFMT[2-0] XROT                 | 0x0    |
| <b>ENDIF</b>                                          |                                      |        |

**Table 12-13. Transmit Format Unit Configuration for DIT-Transmission (continued)**

| Step                                                                                            | Register/Bit Field/Programming Model | Value |
|-------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Select to write data to active serializers transmit buffers using peripheral (CFG) or DATA port | MCASP_XFMT[3] XBUSEL                 | 0x-   |

(1) Refer to [Section 12.1.1.4.4.1, Transmit Format Unit](#) and [Section 12.1.1.4.4.1.2, DIT-Mode Transmission Data Alignment Settings](#).

#### 12.1.1.5.1.2.1.2 Subsequence – Transmit Frame Synchronization Generator Configuration for DIT-Transmission

The procedure in [Table 12-14](#) configures the transmit frame synchronization generator of the MCASP module.

---

#### Note

The frame synchronization signal is always rising-edge active and always has a single-bit width.

---

**Table 12-14. Transmit Frame-Synchronization Generator Configuration for DIT-Transmission**

| Step                                             | Register/Bit Field/Programming Model | Value |
|--------------------------------------------------|--------------------------------------|-------|
| Select 384-slot size block.                      | MCASP_AFSXCTL[15-7] XMOD             | 0x180 |
| Select internally-generated transmit frame sync. | MCASP_AFSXCTL[1] FSXM                | 0x1   |

#### 12.1.1.5.1.2.1.3 Subsequence – Transmit Clock Generator Configuration for DIT-Transmission

---

#### Note

By default, the ACLKX and AHCLKX clocks are generated only from the MCASP internal clock source.

---

The procedure in [Table 12-15](#) configures the transmit clock generator of the MCASP module.

**Table 12-15. Transmit Clock Generator Configuration in DIT-Mode**

| Step                                                                       | Register/Bit Field/Programming Model                                       | Value |
|----------------------------------------------------------------------------|----------------------------------------------------------------------------|-------|
| Set the divisor for the internally generated high frequency clock– AHCLKX. | MCASP_AHCLKXCTL[11-0] HCLKXDIV                                             | 0x-   |
| Set the divisor for the internally generated transmission clock– ACLKX.    | MCASP_ACLKXCTL[4-0] CLKXDIV                                                | 0x-   |
| Configure the transmit clock failure detect logic.                         | See <a href="#">Section 12.1.1.4.15.6.1, Clock Failure Check Startup</a> . |       |

#### 12.1.1.5.1.2.1.4 Subsequence - MCASP Pins Functional Configuration

The procedure in [Table 12-16](#) configures the MCASP pins for MCASP functionality.

**Table 12-16. MCASP Pins Functional Configuration**

| Step                                                                              | Register/Bit Field/Programming Model | Value |
|-----------------------------------------------------------------------------------|--------------------------------------|-------|
| Configure module different pins to have MCASP functionality.                      | MCASP_PFUNC[31-0]                    | 0x0   |
| Configure the MCASP pins as outputs:                                              | MCASP_PDIR[28] AFSX;                 | 0x1   |
| AFSX                                                                              | MCASP_PDIR[27] AHCLKX;               | 0x1   |
| AHCLKX                                                                            | MCASP_PDIR[26] ACLKX;                | 0x1   |
| ACLKX                                                                             | MCASP_PDIR[i] AXRi                   | 0x1   |
| Desired i-th MCASP data pin AXRi is configured as an output for DIT-transmission. |                                      |       |

#### 12.1.1.5.1.2.1.5 Subsequence – DIT-specific Subframe Fields Configuration

The procedure in [Table 12-17](#) configures the DIT-specific subframe fields as part of the S/PDIF format data.

**Table 12-17. DIT-Specific Subframe Fields Configuration**

| Step                                                                                   | Register/Bit Field/Programming Model                                                               | Value      |
|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|------------|
| Configure the valid bit value for odd time slots.                                      | MCASP_DITCTL[3] VB                                                                                 | 0x-        |
| Configure the valid bit value for even time slots.                                     | MCASP_DITCTL[2] VA                                                                                 | 0x-        |
| Configure the user data bit for each subframe A and B in a 384-slot S/PDIF block.      | MCASP_DITUDRAi[31-0] DITUDRAi, where i = 0 to 5<br>MCASP_DITUDRBi[31-0] DITUDRBi, where i = 0 to 5 | 0x-<br>0x- |
| Configure the channel status bit for each subframe A and B in a 384-slot S/PDIF block. | MCASP_DITCSRAi[31-0], where i = 0 to 5<br>MCASP_DITCSRBi[31-0], where i = 0 to 5                   | 0x-<br>0x- |

**12.1.1.5.1.2.2 Main Sequence – MCASP Global Initialization for TDM-Reception**

The procedure in [Table 12-18](#) initializes a MCASP serializer n receiver(s) to operate in TDM-mode (the only mode supported by MCASP receivers) after a power-on reset (POR). This is used for I2S (2-slot TDM) and other TDM-based audio protocols reception.

**CAUTION**

Before performing MCASP global initialization, If external clock ACLKR is used, it must be running already for proper synchronization of the *MCASP\_GBLCTL* register.

**Note**

The MCASP receivers support only TDM-frames (including 384-TDM frames) reception. DIT-frames reception (this is, S/PDIF stream) can be implemented indirectly via an external DIR-chip converter with DIT-input and TDM (I2S)-compatible output connected to device MCASP receiver input (TDM-only compatible).

**Table 12-18. MCASP Receivers Global Initialization for TDM-Mode Operation**

| Step                                                                                                                                                            | Register/Bit Field/Programming Model                                      | Value  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--------|
| 1. Apply software reset to different MCASP receive components.                                                                                                  | MCASP_GBLCTL[4-0]                                                         | 0x00   |
| 2. Poll the bits to ensure the active reset value (0x00) is successfully latched into the register.                                                             | MCASP_GBLCTL[4-0]                                                         | =0x00  |
| 3. Configure the local power management.                                                                                                                        | MCASP_PWRDLESYSCONFIG[1-0] IDLE_MODE                                      | 0x1    |
| 4. Configure the receive format unit.                                                                                                                           | See <a href="#">Section 12.1.1.5.1.2.2.1</a> .                            |        |
| 5. Configure the receive frame sync generator.                                                                                                                  | See <a href="#">Section 12.1.1.5.1.2.2.2</a> .                            |        |
| 6. Configure the receive clock generator.                                                                                                                       | See <a href="#">Section 12.1.1.5.1.2.2.3</a> .                            |        |
| 7. Program all bits - RTDMSk (where k = 0 to 31) according to the time slot characteristics desired (positions of active versus inactive slots within a frame). | MCASP_RTDM[k] RTDMSk , where k = 0 to 31                                  | 0x-    |
| 8. Configure the desired n-th serializer for receive mode operation. <sup>(4)</sup>                                                                             | MCASP_SRCTLn [1-0] SRMOD; n = 0 to 15                                     | 0x2    |
| 9. Configure the MCASP pins functionality.                                                                                                                      | See <a href="#">Section 12.1.1.5.1.2.2.4</a> .                            |        |
| 10. Optional: Configure a MCASP Rx channel for a loopback operation (TDM mode only) in MCASP_DLBCCTL [31-0].                                                    | See <a href="#">Section 12.1.1.4.14.1, Loopback Mode Configurations</a> . | 0x-(5) |
| 11. Release from reset state the divider that outputs the AHCLKR clock. <sup>(1)</sup><br>See also <sup>(2)</sup> .                                             | MCASP_GBLCTL[1] RHCLKRST                                                  | 0x1    |
| 12. Poll the bit to ensure that it is successfully latched in the register.<br>See also <sup>(2)</sup> .                                                        | MCASP_GBLCTL[1] RHCLKRST                                                  | =0x1   |

**Table 12-18. MCASP Receivers Global Initialization for TDM-Mode Operation (continued)**

| Step                                                                                                                                                                                                                                                                      | Register/Bit Field/Programming Model | Value |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| 13. Release from reset state the divider that outputs the ACLKR clock. <sup>(1)</sup><br>See also <sup>(3)</sup> .                                                                                                                                                        | MCASP_GBLCTL[0] RCLKRST              | 0x1   |
| 14. Poll the bit to ensure that it is successfully latched in the register.<br>See also <sup>(3)</sup> .                                                                                                                                                                  | MCASP_GBLCTL[0] RCLKRST              | =0x1  |
| (1) During reset state the local MCASP internal clock dividers maintain a 1:1 ratio at their outputs. The values stored in the MCASP_AHCLKRCTL and MCASP_ACLKRCTL registers are ignored; hence, the reception clock does not stop during the reset state of the dividers. |                                      |       |
| (2) This step is necessary even if external high-frequency serial clocks are used.                                                                                                                                                                                        |                                      |       |
| (3) This step can be skipped if external serial clocks are used and they are running.                                                                                                                                                                                     |                                      |       |
| (4) For an unused serializer n, write MCASP_SRCTLn [1-0] SRMOD = 0x0 to disable it (n = 0 to 15).                                                                                                                                                                         |                                      |       |
| (5) In this case the receiver clock and frame sync are derived from the MCASP transmitter logic, so MCASP_ACLKXCTL[6] ASYNC must be set to 0b0. Neither MCASP internal receiver clock and frame sync generators, nor external clock and frame sync source are used.       |                                      |       |

#### 12.1.1.5.1.2.2.1 Subsequence – Receive Format Unit Configuration in TDM Mode

The procedure in [Table 12-19](#) configures the receive frame format unit of the MCASP module for TDM slots reception.

**Table 12-19. Receive Format Unit Configuration for TDM-Reception**

| Step                                                                                                                                                                   | Register/Bit Field/Programming Model | Value  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------|
| Configure the desired TDM-slot size                                                                                                                                    | MCASP_RFMT[7-4] RSSZ                 | 0x-(1) |
| Set data mask out value (0x0000 0000 - 0xFFFF FFFF).                                                                                                                   | MCASP_RMASK[31-0] RMASK              | 0x-(2) |
| Select a padding value for masked-out bits.                                                                                                                            | MCASP_RFMT[14-13] RPAD               | 0x-    |
| Specify position (0x0-0x1F) of the bit in corresponding register MCASP_RBUFn which value to be used as a pad value in case MCASP_RFMT[14-13] RPAD = 0x2. (n = 0 to 15) | MCASP_RFMT[12-8] RPBIT               | 0x-    |
| Rotate data right by a multiple of 4- bit positions.                                                                                                                   | MCASP_RFMT[2-0] RROT                 | 0x-(3) |
| Received stream bit order (LSB- or MSB-first). Must be set to 0x1 for an I2S stream reception (MSB-first).                                                             | MCASP_RFMT[15] RRVRS                 | 0x-(3) |
| Specify a delay between frame sync and first bit of data in number of bits. Must be set to 0x1 for an I2S stream reception.                                            | MCASP_RFMT[17-16] RDATDLY            | 0x-    |
| Select to read data from active serializers receive buffers using peripheral (CFG) or DATA port                                                                        | MCASP_RFMT[3] RBUSEL                 | 0x-    |

- (1) Refer to [Section 12.1.1.4.4.2, Receive Format Unit](#), regarding options for received TDM-slot sizes.  
 (2) For more details on Rx masking value, refer to [Section 12.1.1.4.4.2.1, TDM - Mode Reception Data Alignment Settings](#)  
 (3) For more details on rotation and received TDM stream bit order, refer to [Section 12.1.1.4.4.2.1, TDM - Mode Reception Data Alignment Settings](#) and [Table 12-6, MCASP RFU Settings](#).

#### 12.1.1.5.1.2.2.2 Subsequence – Receive Frame Synchronization Generator Configuration in TDM Mode

The procedure in [Table 12-20](#) configures the transmit frame synchronization generator of the MCASP module.

##### Note

The same bit - MCASP\_ACLKXCTL[6] ASYNC which is used to determine if MCASP receivers and transmitters work synchronously on the same clock, is also used to define if receiver frame sync is derived from the transmit frame sync generator, or generated independently in the receiver (either internally or externally sourced). Hence, the settings in below table [Table 12-20](#) have no effect, if MCASP\_ACLKXCTL[6] ASYNC = 0.

**Table 12-20. Receive Frame-Synchronization Generator Configuration for TDM-Reception**

| Step                                                                                                                                                                                                                                                                                                                                                                  | Register/Bit Field/Programming Model | Value  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------|
| Select number of TDM slots per frame.<br>Must be set to 0x2, in case of an I2S-reception.<br>For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3</a> .                                                                                                                                                                                | MCASP_AFSRCTL[15-7] RMOD             | 0x-(1) |
| Choose the receive frame sync width -single bit/single word.<br>For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3</a> .                                                                                                                                                                                                             | MCASP_AFSRCTL[4] FRWID               | 0x-    |
| Select start of received frame sync polarity - rising / falling edge.<br>For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3</a> .                                                                                                                                                                                                    | MCASP_AFSRCTL[0] FSRP                | 0x-    |
| <b>IF</b> receive frame sync - FS is internally generated                                                                                                                                                                                                                                                                                                             | Software test condition              |        |
| Select internally- generated receive frame sync.<br>For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3</a> .                                                                                                                                                                                                                         | MCASP_AFSRCTL[1] FSRM                | 0b1    |
| If MCASP receiver is required to output internally generated frame, AFSR pin must be set as an output in step 9 of the sequence documented in the <a href="#">Table 12-18</a> . This must not be done in current step because the frame control register - MCASP_AFSXCTL must be appropriately configured prior to AFSR pin outputting a frame to an external device. | MCASP_PDIR[31] AFSR                  | 0b1    |
| <b>ELSE</b>                                                                                                                                                                                                                                                                                                                                                           |                                      |        |
| Select externally- generated receive frame sync.<br>For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3</a> .                                                                                                                                                                                                                         | MCASP_AFSRCTL[1] FSRM                | 0b0    |
| Setup the AFSR pin as input (device level: MCASPI_AFSR)                                                                                                                                                                                                                                                                                                               | MCASP_PDIR[31] AFSR                  | 0b0    |
| <b>ENDIF</b>                                                                                                                                                                                                                                                                                                                                                          |                                      |        |
| To generate MCASP receive frame sync in receiver logic, select an asynchronous frame sync.                                                                                                                                                                                                                                                                            | MCASP_ACLKXCTL[6] ASYNC              | 0b1    |

- (1) Must be set to 0x180 in case of 384-TDM slot frame reception from a DIR component I2S-output. For more details on TDM-frame settings, refer to *Module Integration*.

#### 12.1.1.5.1.2.2.3 Subsequence – Receive Clock Generator Configuration

The procedure in [Table 12-21](#) configures the receive clock generator of the MCASP module.

##### Note

The settings in below table [Table 12-21](#) have no effect, if MCASP\_ACLKXCTL[6] ASYNC = 0 (this is, receive clock is sourced from the inverted version of the transmit clock). For example, such is the case when MCASP loopback mode is used.

**Table 12-21. Receive Clock Generator Configuration**

| Step                                                                                                                                                                                                       | Register/Bit Field/Programming Model | Value |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| To use the MCASP receive clock generator, select an asynchronous receiver clock schema (ASYNC = 1). Otherwise an inverted version of transmit clock XCLK is used (receiver synchronized with transmitter). | MCASP_ACLKXCTL[6] ASYNC              | 0b1   |
| <b>IF</b> receive clock - RCLK is internally generated                                                                                                                                                     | Software test condition              |       |
| The high-speed receive clock - AHCLKR is internally generated based on AUXCLK                                                                                                                              | MCASP_AHCLKXCTL[15] HCLKRM           | 0b1   |

**Table 12-21. Receive Clock Generator Configuration (continued)**

| Step                                                                                                                                                                                                                                                                                                                                                                                       | Register/Bit Field/Programming Model                                       | Value |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------|
| Select the internal high-speed clock source polarity: non-inverted or inverted.                                                                                                                                                                                                                                                                                                            | MCASP_AHCLKXCTL[14] HCLKRP                                                 | 0x-   |
| Set the divisor for the internally generated high-frequency clock – AHCLKR in range (1 - 4096).                                                                                                                                                                                                                                                                                            | MCASP_AHCLKXCTL[11-0] HCLKRDIV                                             | 0x-   |
| Select an internally-generated receive clock.                                                                                                                                                                                                                                                                                                                                              | MCASP_ACLKXCTL[5] CLKRM                                                    | 0b1   |
| Receiver samples on rising/falling edge. Select Rx sampling on the rising edge if transmitter shifts out on falling edge, and vice versa.                                                                                                                                                                                                                                                  | MCASP_ACLKXCTL[7] CLKRP                                                    | 0x-   |
| Set the divisor for the internally generated receive clock – ACLKR in range (1 - 32).                                                                                                                                                                                                                                                                                                      | MCASP_ACLKXCTL[4-0] CLKRDIV                                                | 0x-   |
| Optional: If MCASP receiver is required to output internally generated clock, ACLKR pin must be set as an output in step 9 of the sequence documented in the <a href="#">Table 12-18</a> . This must not be done in current step because the clock control register - MCASP_ACLKRCTL must be appropriately configured prior to ACLKR pin outputting a receive clock to an external device. | MCASP_PDIR[29] ACLKR                                                       | 0b1   |
| <b>ELSE</b>                                                                                                                                                                                                                                                                                                                                                                                |                                                                            |       |
| Select an externally-generated receive clock. Note that in this case the AHCLKR signal path and the CLKRDIV divider are NOT used.                                                                                                                                                                                                                                                          | MCASP_ACLKXCTL[5] CLKRM                                                    | 0b0   |
| Receiver samples on rising/falling edge. Select Rx sampling on the rising edge if transmitter shifts out on falling edge, and vice versa.                                                                                                                                                                                                                                                  | MCASP_ACLKXCTL[7] CLKRP                                                    | 0x-   |
| Setup an input direction for the ACLKR pin                                                                                                                                                                                                                                                                                                                                                 | MCASP_PDIR[29] ACLKR                                                       | 0b0   |
| <b>ENDIF</b>                                                                                                                                                                                                                                                                                                                                                                               |                                                                            |       |
| Configure the transmit clock failure detect logic.                                                                                                                                                                                                                                                                                                                                         | See <a href="#">Section 12.1.1.4.15.6.1, Clock Failure Check Startup</a> . |       |

#### 12.1.1.5.1.2.2.4 Subsequence—MCASP Receiver Pins Functional Configuration

The procedure in [Table 12-22](#) configures the MCASP pins for MCASP functionality.

**Table 12-22. MCASP Receiver Pins Functional Configuration**

| Step                                                                      | Register/Bit Field/Programming Model                                 | Value                   |
|---------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------|
| Configure module different pins to have MCASP functionality.              | MCASP_PFUNC[31-0]                                                    | 0x0                     |
| Configure the MCASP pins direction:<br>AFSR<br>ACLKR                      | MCASP_PDIR[31] AFSR;<br>MCASP_PDIR[29] ACLKR;<br>MCASP_PDIR[n] AXRN; | 0x-(1)<br>0x-(2)<br>0x0 |
| Desired n-th MCASP data pin AXRn is configured as an input for receiving. |                                                                      |                         |

(1) See [Table 12-20](#).

(2) For more details on MCASP clock configurations, refer to [Table 12-21](#).

#### 12.1.1.5.1.2.3 Main Sequence – MCASP Global Initialization for TDM -Transmission

The procedure in [Table 12-23](#) initializes a MCASP serializer n transmitter(s) to operate in TDM-mode after a power-on reset (POR). This is used for I2S (2-slot TDM) and other TDM-based audio protocols transmission.

**CAUTION**

Before performing MCASP global initialization, If external clock ACLKR is used, it must be running already for proper synchronization of the MCASP\_GBLCTL register.

**Table 12-23. MCASP Transmitters Global Initialization for TDM-Mode Operation**

| Step                                                                                                                                                            | Register/Bit Field/Programming Model                                      | Value              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--------------------|
| 1. Apply software reset to different MCASP transmit components.                                                                                                 | MCASP_GBLCTL[12-8]                                                        | 0x00               |
| 2. Poll the bits to ensure the active reset value (0x00) is successfully latched into the register.                                                             | MCASP_GBLCTL[12-8]                                                        | =0x00              |
| 3. Configure the local power management.                                                                                                                        | MCASP_PWRDLESYSCONFIG[1-0] IDLE_MODE                                      | 0x1                |
| 4. Configure the transmit format unit.                                                                                                                          | See <a href="#">Section 12.1.1.5.1.2.3.1</a> .                            |                    |
| 5. Configure the transmit frame sync generator.                                                                                                                 | See <a href="#">Section 12.1.1.5.1.2.3.2</a> .                            |                    |
| 6. Configure the transmit clock generator.                                                                                                                      | See <a href="#">Section 12.1.1.5.1.2.3.3</a> .                            |                    |
| 7. Program all bits - XTDMSk, where k = 0 to 31, according to the time slot characteristics desired (positions of active versus inactive slots within a frame). | MCASP_XTDM[k] XTDMSk, where k = 0 to 31 <sup>(4)</sup>                    | 0x-                |
| 8. Configure the desired n-th serializer for transmit mode operation. <sup>(3)</sup>                                                                            | MCASP_SRCTLn[1-0] SRMOD; n = 0 to 15                                      | 0x1                |
| 9. Setup all active transmitters to operate in TDM mode.                                                                                                        | MCASP_DITCTL[0] DITEN                                                     | 0x0 <sup>(2)</sup> |
| 10. Configure the MCASP pins functionality.                                                                                                                     | See <a href="#">Section 12.1.1.5.1.2.3.4</a> .                            |                    |
| 11. Optional: Configure a MCASP Tx channel for loopback operation (TDM mode only) in MCASP_DLBCCTL [31-0].                                                      | See <a href="#">Section 12.1.1.4.14.1, Loopback Mode Configurations</a> . | 0x-                |
| 12. Release from reset state the divider that outputs the AHCLKR clock. See <sup>(1)</sup>                                                                      | MCASP_GBLCTL[9] XHCLKRST                                                  | 0x1                |
| 13. Poll the bit to ensure that it is successfully latched in the register.                                                                                     | MCASP_GBLCTL[9] XHCLKRST                                                  | =0x1               |
| 14. Release from reset state the divider that outputs the ACLKR clock. See <sup>(1)</sup>                                                                       | MCASP_GBLCTL[8] XCLKRST                                                   | 0x1                |
| 15. Poll the bit to ensure that it is successfully latched in the register.                                                                                     | MCASP_GBLCTL[8] XCLKRST                                                   | =0x1               |

- (1) During reset state the local MCASP internal clock dividers maintain a 1:1 ratio at their outputs. The values stored in the MCASP\_AHCLKXCTL and MCASP\_ACLKXCTL registers are ignored; hence, the transmission clock does not stop during the reset state of the dividers.
- (2) All active transmit channels operate either in TDM mode or in DIT mode depending on DITEN value. There is no option to choose Tx Mode between DIT and TDM separately per serializer transmitter.
- (3) For an unused serializer n, write MCASP\_SRCTLn [1-0] SRMOD = 0x0 to disable it (n = 0 to 15).
- (4) Appropriately program in the MCASP\_SRCTLn[3-2] DISMOD bit field, the desired level (high-impedance state, 0, or 1) at AXRn output, during time of inactive slots. Note, that this setting does NOT apply when all slots are programmed to be active within a frame (in particular DIT-mode) (n = 0 to 15).

#### 12.1.1.5.1.2.3.1 Subsequence – Transmit Format Unit Configuration in TDM Mode

The procedure in [Table 12-24](#) configures the transmit frame format unit of the MCASP module for TDM slots transmission.

**Table 12-24. Transmit Format Unit Configuration for TDM-Transmission**

| Step                                                                                                                                                                   | Register/Bit Field/Programming Model | Value  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------|
| Configure the desired TDM-slot size                                                                                                                                    | MCASP_XFMT[7-4] XSSZ                 | 0x-(1) |
| Set data mask out value (0x0000 0000 - 0xFFFF FFFF).                                                                                                                   | MCASP_XMASK[31-0] XMASK              | 0x-(2) |
| Select a padding value for masked-out bits.                                                                                                                            | MCASP_XFMT[14-13] XPAD               | 0x-    |
| Specify position (0x0-0x1F) of the bit in corresponding register MCASP_XBUFn which value to be used as a pad value in case MCASP_XFMT[14-13] XPAD = 0x2 (n = 0 to 15). | MCASP_XFMT[12-8] XPBIT               | 0x-    |
| Rotate data right by a multiple of 4- bit positions.                                                                                                                   | MCASP_XFMT[2-0] XROT                 | 0x-(3) |
| transmitted stream bit order (LSB- or MSB-first). Must be set to 0x1 for an I2S stream transmission (MSB-first).                                                       | MCASP_XFMT[15] XRVRS                 | 0x-(3) |

**Table 12-24. Transmit Format Unit Configuration for TDM-Transmission (continued)**

| Step                                                                                                                           | Register/Bit Field/Programming Model | Value |
|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Specify a delay between frame sync and first bit of data in number of bits. Must be set to 0x1 for an I2S stream transmission. | MCASP_XFMT[17-16] XDATDLY            | 0x-   |
| Select to write data to active serializers transmit buffers using peripheral (CFG) or DATA port                                | MCASP_XFMT[3] XBUSEL                 | 0x-   |

- (1) Refer to [Section 12.1.1.4.4.1, Transmit Format Unit](#), regarding options for transmitted TDM-slot sizes.  
 (2) For more details on Tx masking value, refer to [Section 12.1.1.4.4.1.1, TDM - Mode Transmission Data Alignment Settings](#)  
 (3) For more details on rotation and transmitted TDM stream bit order, refer to [Section 12.1.1.4.4.1.1, TDM - Mode Transmission Data Alignment Settings](#) and [Table 12-4, MCASP TFU TDM Mode Settings](#).

#### 12.1.1.5.1.2.3.2 Subsequence – Transmit Frame Synchronization Generator Configuration in TDM Mode

The procedure in [Table 12-25](#) configures the transmit frame synchronization generator of the MCASP module.

**Table 12-25. Transmit Frame-Synchronization Generator Configuration for TDM-Transmission**

| Step                                                                                                                                                                                                                                                                                                                                                                           | Register/Bit Field/Programming Model | Value |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Select number of TDM slots per frame (2 - 32). Must be set to 0x2, in case of an I2S-transmission. For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3, Frame-Sync Generator</a> .                                                                                                                                                             | MCASP_AFSXCTL[15-7] XMOD             | 0x-   |
| Choose the transmit frame sync width -single bit/single word. For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3, Frame-Sync Generator</a> .                                                                                                                                                                                                  | MCASP_AFSXCTL[4] FXWID               | 0x-   |
| Select start of transmit frame sync polarity - rising / falling edge. For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3, Frame-Sync Generator</a> .                                                                                                                                                                                          | MCASP_AFSXCTL[0] FSXP                | 0x-   |
| <b>IF</b> transmit frame sync - FS is internally generated                                                                                                                                                                                                                                                                                                                     | Software test condition              |       |
| Select internally- generated transmit frame sync. For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3, Frame-Sync Generator</a> .                                                                                                                                                                                                              | MCASP_AFSXCTL[1] FSXM                | 0b1   |
| If MCASP transmitter is required to output internally generated frame, AFSX pin must be set as an output in step 10 of the sequence documented in the <a href="#">Table 12-23</a> . This must NOT be done in current step because the frame control register - MCASP_AFSXCTL must be appropriately configured prior to AFSX pin outputting a frame sync to an external device. | MCASP_PDIR[28] AFSX                  | 0b1   |
| <b>ELSE</b>                                                                                                                                                                                                                                                                                                                                                                    |                                      |       |
| Select externally- generated transmit frame sync. For more details on frame-sync generator, refer to <a href="#">Section 12.1.1.4.2.3, Frame-Sync Generator</a> .                                                                                                                                                                                                              | MCASP_AFSXCTL[1] FSXM                | 0b0   |
| Setup the AFSX pin as input                                                                                                                                                                                                                                                                                                                                                    | MCASP_PDIR[28] AFSX                  | 0b0   |

#### 12.1.1.5.1.2.3.3 Subsequence – Transmit Clock Generator Configuration for TDM Cases

The procedure in [Table 12-26](#) configures the transmit clock generator of the MCASP module.

**Table 12-26. Transmit Clock Generator Configuration for TDM Cases**

| Step                                                                                 | Register/Bit Field/Programming Model | Value |
|--------------------------------------------------------------------------------------|--------------------------------------|-------|
| <b>IF</b> transmit clock - XCLK is internally generated                              | Software test condition              |       |
| <b>IF</b> high-speed transmit clock - AHCLKX is internally generated based on AUXCLK | Software test condition              |       |
| Select an internally-generated high-frequency clock.                                 | MCASP_AHCLKXCTL[15] HCLKXM           | 0b1   |

**Table 12-26. Transmit Clock Generator Configuration for TDM Cases (continued)**

| Step                                                                                                                                                                                                                                                                                                                                                                                                                | Register/Bit Field/Programming Model                                       | Value |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------|
| Select the high-frequency clock source polarity: non-inverted or inverted.                                                                                                                                                                                                                                                                                                                                          | MCASP_AHCLKXCTL[14] HCLKXP                                                 | 0x-   |
| Set the divisor for the internally generated high-frequency clock – AHCLKX in range (1 - 4096).                                                                                                                                                                                                                                                                                                                     | MCASP_AHCLKXCTL[11-0] HCLKXDIV                                             | 0x-   |
| Optional: If MCASP transmitter is required to output internally generated high-frequency clock, AHCLKX pin must be set as an output in step 10 of the sequence documented in the <a href="#">Table 12-23</a> . This must NOT be done in current step because the clock control register - MCASP_AHCLKXCTL must be appropriately configured prior to AHCLKX pin outputting a high-speed clock to an external device. | MCASP_PDIR[27] AHCLKX                                                      | 0b1   |
| <b>ELSE</b>                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                            |       |
| Select an externally-generated high frequency clock (HCLKXDIV divider can not be used).                                                                                                                                                                                                                                                                                                                             | MCASP_AHCLKXCTL[15] HCLKXM                                                 | 0b0   |
| Select the high-speed transmit clock source polarity: non-inverted or inverted.                                                                                                                                                                                                                                                                                                                                     | MCASP_AHCLKXCTL[14] HCLKXP                                                 | 0x-   |
| Setup an input directon for the AHCLKX pin                                                                                                                                                                                                                                                                                                                                                                          | MCASP_PDIR[27] AHCLKX                                                      | 0b0   |
| <b>ENDIF</b>                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                            |       |
| Select an internally-generated transmit clock.                                                                                                                                                                                                                                                                                                                                                                      | MCASP_ACLKXCTL[5] CLKXM                                                    | 0b1   |
| Transmitter samples on rising/falling edge. Select Tx shifting out data on the rising edge if receiver samples on falling edge, and vice versa.                                                                                                                                                                                                                                                                     | MCASP_ACLKXCTL[7] CLKXP                                                    | 0x-   |
| Set the divisor for the internally generated transmit clock – ACLKX in range (1 - 32).                                                                                                                                                                                                                                                                                                                              | MCASP_ACLKXCTL[4-0] CLKXDIV                                                | 0x-   |
| Optional: If MCASP transmitter is required to output internally generated clock, ACLKX pin) must be set as an output in step 10 of the sequence documented in the <a href="#">Table 12-23</a> . This must NOT be done in current step because the clock control register - MCASP_ACLKXCTL must be appropriately configured prior to ACLKX pin outputting a transmit clock to an external device.                    | MCASP_PDIR[26] ACLKX                                                       | 0b1   |
| <b>ELSE</b>                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                            |       |
| Select an externally-generated transmit clock. Note that in this case the AHCLKX signal path and the CLKXDIV divider are NOT used.                                                                                                                                                                                                                                                                                  | MCASP_ACLKXCTL[5] CLKXM                                                    | 0b0   |
| Transmitter samples on rising/falling edge. Select Tx shifting out data on the rising edge if receiver samples on falling edge, and vice versa.                                                                                                                                                                                                                                                                     | MCASP_ACLKXCTL[7] CLKXP                                                    | 0x-   |
| Setup an input directon for the ACLKX pin                                                                                                                                                                                                                                                                                                                                                                           | MCASP_PDIR[26] ACLKX                                                       | 0b0   |
| <b>ENDIF</b>                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                            |       |
| Configure the transmit clock failure detect logic.                                                                                                                                                                                                                                                                                                                                                                  | See <a href="#">Section 12.1.1.4.15.6.1, Clock Failure Check Startup</a> . |       |

**12.1.1.5.1.2.3.4 Subsequence—MCASP Transmit Pins Functional Configuration**

The procedure in [Table 12-27](#) configures the MCASP pins for MCASP functionality.

**Table 12-27. MCASP Transmit Pins Functional Configuration**

| Step                                                         | Register/Bit Field/Programming Model | Value |
|--------------------------------------------------------------|--------------------------------------|-------|
| Configure module different pins to have MCASP functionality. | MCASP_PFUNC[31-0]                    | 0x0   |

**Table 12-27. MCASP Transmit Pins Functional Configuration (continued)**

| Step                                                                          | Register/Bit Field/Programming Model                                                                                      | Value                             |
|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Configure the MCASP pins direction:<br>AFSX<br>AHCLKX<br>ACLKX                | <i>MCASP_PDIR[28] AFSR;</i><br><i>MCASP_PDIR[27] AHCLKR;</i><br><i>MCASP_PDIR[26] ACLKR;</i><br><i>MCASP_PDIR[n] AXRn</i> | 0x-(1)<br>0x-(2)<br>0x-(2)<br>0x1 |
| Desired n-th MCASP data pin AXRn is configured as an output for transmission. |                                                                                                                           |                                   |

(1) See Table 12-25.

### 12.1.1.5.2 MCASP Operational Modes Configuration

#### 12.1.1.5.2.1 MCASP Transmission Modes

##### 12.1.1.5.2.1.1 Main Sequence – MCASP DIT- /TDM- Polling Transmission Method

Figure 12-27 shows the MCASP DIT-/TDM- polling method.


**Figure 12-27. MCASP DIT- /TDM- Transmission Polling Method**

mcasp-026

These registers are for MCASP DIT-/TDM- transmission polling method: *MCASP\_XEVCTL*, *MCASP\_XSTAT*, *MCASP\_GBLCTL*, *MCASP\_XTDM*, *MCASP\_XBUFn*, *MCASP\_SRCTLn*, *MCASP\_DITUDRAi*, *MCASP\_DITUDRBi*, *MCASP\_DITCSRAi*, *MCASP\_DITCSRBi* (n = 0 to 15 and i = 0 to 5).

Table 12-28 summarizes the subprocess call for the DIT-/TDM- transmission polling mode.

**Table 12-28. Subprocess Call Summary for Main Sequence – MCASP DIT-/TDM- Transmission Polling Method**

| Subprocess Name | Cross-Reference              |
|-----------------|------------------------------|
| Error handling  | <a href="#">Figure 12-33</a> |

#### **12.1.1.5.2.1.2 Main Sequence – MCASP DIT- /TDM - Interrupt Transmission Method**

Figure 12-28 shows the initial setup for interrupt-based transmission.



mcasp-027

**Figure 12-28. Subsequence – DIT/TDM- Transmission Startup Procedure**

**Table 12-29** shows the configuration of the MCASP using an interrupt method for DIT-/TDM- transmission.

**Table 12-29. MCASP DIT-/TDM- Interrupt Transmission Model**

| Step                                                                                                                                                                      | Register/Bit Field/Programming Model                                                                                                         | Value             |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| Disable Tx DMA requests generation.                                                                                                                                       | MCASP_XEVTCCTL[0] XDATDMA                                                                                                                    | 0x1               |
| Enable the data ready event transmit interrupt.                                                                                                                           | MCASP_XINTCTL[5] XDATA                                                                                                                       | 0x1               |
| Optional: Enable the transmit error event interrupts.                                                                                                                     | MCASP_XINTCTL[2] XCKFAIL<br>MCASP_XINTCTL[1] XSYNCERR<br>MCASP_XINTCTL[0] XUNDRN                                                             | 0x1<br>0x1<br>0x1 |
| Optional: Enable the start of frame interrupt.<br>Optional: Enable the last slot data interrupt (useful for DIT user data/ channel status next S/PDIF frame info update). | MCASP_XINTCTL[7] XSTAFRM<br>MCASP_XINTCTL[4] XLAST                                                                                           | 0x1<br>0x1        |
| <b>IF</b> write transfer is through the MCASP DATA port (MCASP_XFMT[3] XBUSEL is set to 0b0).                                                                             | Software test condition (setting is done in step4 of the <i>MCASP Transmitters Global Initialization</i> - see <a href="#">Table 12-12</a> ) |                   |
| Enable the DATA port error based interrupt.                                                                                                                               | MCASP_XINTCTL[3] XDMAERR                                                                                                                     | 0x1               |
| <b>ELSE</b>                                                                                                                                                               |                                                                                                                                              |                   |
| Disable the DATA port error based interrupt.                                                                                                                              | MCASP_XINTCTL[3] XDMAERR                                                                                                                     | 0x0               |
| <b>ENDIF</b>                                                                                                                                                              |                                                                                                                                              |                   |
| DIT/TDM - Transmission Startup Procedure                                                                                                                                  | See <a href="#">Figure 12-28</a> .                                                                                                           |                   |

These registers are for MCASP DIT-/TDM- transmission startup procedure: *MCASP\_GBLCTL*, *MCASP\_XSTAT*.

#### 12.1.1.5.2.1.3 Main Sequence –MCASP DIT- /TDM - Mode DMA Transmission Method

**Table 12-30** shows the configuration of the ↓ using the DMA method for transmission. Possible interrupt error event servicing is also considered. shows the initial setup for DMA - based transmission.

#### Note

Because of the DATA port burst access capability with the DMA method, it is strongly recommended that DMA transfers are initiated through the MCASP DATA port.

**Table 12-30. MCASP DMA Transmission Model with Interrupt Events Servicing**

| Step                                                                                                                                                                                                                                                                                                                                                         | Register/Bit Field/Programming Model                                             | Value             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------------|
| <b>Recommended:</b> Select DATA port to access the transmit buffers.                                                                                                                                                                                                                                                                                         | MCASP_XFMT[3] XBUSEL                                                             | 0x0               |
| Enable the Tx DMA requests generation.                                                                                                                                                                                                                                                                                                                       | MCASP_XEVTCCTL[0] XDATDMA                                                        | 0x0               |
| Enable the Tx DMA error event, because of MCASP DATA port usage.                                                                                                                                                                                                                                                                                             | MCASP_XINTCTL[3] XDMAERR                                                         | 0x1               |
| Optional: Enable the transmit error event interrupts.                                                                                                                                                                                                                                                                                                        | MCASP_XINTCTL[2] XCKFAIL<br>MCASP_XINTCTL[1] XSYNCERR<br>MCASP_XINTCTL[0] XUNDRN | 0x1<br>0x1<br>0x1 |
| Optional: Enable the start of frame interrupt.<br>Optional: Enable the last slot data interrupt.                                                                                                                                                                                                                                                             | MCASP_XINTCTL[7] XSTAFRM<br>MCASP_XINTCTL[4] XLAST                               | 0x1<br>0x1        |
| Disable the data ready event transmit interrupt, as DMA is used to service this request.                                                                                                                                                                                                                                                                     | MCASP_XINTCTL[5] XDATA                                                           | 0x0               |
| DMA startup transmission procedure. This procedure is identical than the one shown in <a href="#">Figure 12-28</a> . The only difference is that DMA automatically services all the XINT events raised by the MCASP, and no CPU data processing intervention is required. The CPU is involved only in error handling shown in <a href="#">Figure 12-31</a> . | See <a href="#">Figure 12-28</a> .                                               |                   |

### 12.1.1.5.2.2 MCASP Reception Modes

#### 12.1.1.5.2.2.1 Main Sequence – MCASP Polling Reception Method

Figure 12-29 shows the MCASP polling reception method.

##### Note

The MCASP polling reception model considers the device CPUs as the accessor of audio data from the MCASP receive buffers.



**Figure 12-29. MCASP Polling Reception Method**

These registers are for MCASP reception polling method: MCASP\_RSTAT, MCASP\_XGBLCTL, MCASP\_RBUFn, MCASP\_SRCTLn (n = 0 to 15).

mcasp-028

Table 12-31 summarizes the subprocess call for the polling mode.

**Table 12-31. Subprocess Call Summary for Main Sequence – MCASP Reception Polling Method**

| Subprocess Name | Cross-Reference              |
|-----------------|------------------------------|
| Error handling  | <a href="#">Figure 12-34</a> |

**12.1.1.5.2.2.2 Main Sequence – MCASP TDM - Interrupt Reception Method**

Figure 12-30 shows the initial setup for interrupt-based reception.



mcasp-032

**Figure 12-30. Subsequence – TDM - Reception Startup Procedure**

Table 12-32 shows the configuration of the MCASP using an interrupt method for TDM- reception.

**Table 12-32. MCASP TDM- Interrupt Reception Model**

| Step                                                                                            | Register/Bit Field/Programming Model                                                                                                                    | Value             |
|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| Disable Rx DMA requests generation.                                                             | MCASP_PIDTCTL[0] RDATDMA                                                                                                                                | 0x1               |
| Enable the data ready event receive interrupt.                                                  | MCASP_RINTCTL[5] RDATA                                                                                                                                  | 0x1               |
| Optional: Enable the receive error event interrupts.                                            | MCASP_RINTCTL[2] RCKFAIL<br>MCASP_RINTCTL[1] RSYNCERR<br>MCASP_RINTCTL[0] ROVRN                                                                         | 0x1<br>0x1<br>0x1 |
| Optional: Enable the start of frame interrupt.<br>Optional: Enable the last slot data interrupt | MCASP_RINTCTL[7] RSTAFRM<br>MCASP_RINTCTL[4] RLAST                                                                                                      | 0x1<br>0x1        |
| <b>IF</b> read transfer is through the MCASP DATA port<br>(MCASP_RFMT[3] RBUSEL is set to 0b0). | Software test condition (setting is done in step4 of the<br><i>MCASP Receivers Global Initialization for TDM-Mode<br/>Operation - see Table 12-18</i> ) |                   |
| Enable the DATA port error based interrupt.                                                     | MCASP_RINTCTL[3] RDMAERR                                                                                                                                | 0x1               |
| <b>ELSE</b>                                                                                     |                                                                                                                                                         |                   |
| Disable the DATA port error based interrupt.                                                    | MCASP_RINTCTL[3] RDMAERR                                                                                                                                | 0x0               |
| <b>ENDIF</b>                                                                                    |                                                                                                                                                         |                   |
| TDM - Transmission Startup Procedure                                                            | See <a href="#">Figure 12-30</a> .                                                                                                                      |                   |

These registers are for MCASP TDM- interrupt reception model: MCASP\_XGBLCTL, MCASP\_RSTAT.

#### 12.1.1.5.2.2.3 Main Sequence – MCASP TDM - Mode DMA Reception Method

Table 12-33 shows the configuration of the MCASP using the DMA method for reception. Possible interrupt error event servicing is also considered. shows the initial setup for DMA - based transmission.

##### Note

Because of the DATA port burst access capability with the DMA method, it is strongly recommended that DMA transfers are initiated through the MCASP DATA port.

**Table 12-33. MCASP DMA Reception Model with Interrupt Events Servicing**

| Step                                                                                                                                                                                                                                                                                                                                                      | Register/Bit Field/Programming Model                                            | Value             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------|
| <b>Recommended:</b> Select DATA port to access the transmit buffers.                                                                                                                                                                                                                                                                                      | MCASP_RFMT[3] RBUSEL                                                            | 0x0               |
| Enable the Rx DMA requests generation.                                                                                                                                                                                                                                                                                                                    | MCASP_PIDTCTL[0] RDATDMA                                                        | 0x0               |
| Enable the Rx DMA error event, because of MCASP DATA port usage.                                                                                                                                                                                                                                                                                          | MCASP_RINTCTL[3] RDMAERR                                                        | 0x1               |
| Optional: Enable the receive error event interrupts.                                                                                                                                                                                                                                                                                                      | MCASP_RINTCTL[2] RCKFAIL<br>MCASP_RINTCTL[1] RSYNCERR<br>MCASP_RINTCTL[0] ROVRN | 0x1<br>0x1<br>0x1 |
| Optional: Enable the start of frame interrupt.<br>Optional: Enable the last slot data interrupt.                                                                                                                                                                                                                                                          | MCASP_RINTCTL[7] RSTAFRM<br>MCASP_RINTCTL[4] RLAST                              | 0x1<br>0x1        |
| Disable the data ready event receive interrupt, as DMA is used to service this request.                                                                                                                                                                                                                                                                   | MCASP_RINTCTL[5] RDATA                                                          | 0x0               |
| DMA startup reception procedure. This procedure is identical than the one shown in <a href="#">Figure 12-30</a> . The only difference is that DMA automatically services all the RINT events raised by the MCASP, and no CPU data processing intervention is required. The CPU is involved only in error handling shown in <a href="#">Figure 12-32</a> . | See <a href="#">Figure 12-30</a> .                                              |                   |

### 12.1.1.5.2.3 MCASP Event Servicing

#### 12.1.1.5.2.3.1 MCASP DIT/TDM- Transmit Interrupt Events Servicing

Figure 12-31 shows the flow of DIT/TDM- mode transmit interrupt events servicing for the MCASP module.



mcasp-029

**Figure 12-31. MCASP Transmit Interrupt Events Servicing**

### 12.1.1.5.2.3.2 MCASP TDM- Receive Interrupt Events Servicing

Figure 12-32 shows the flow of DIT-/TDM- mode transmit interrupt events servicing for the MCASP module.



mcasp-033

**Figure 12-32. MCASP Receive Interrupt Events Servicing**

These registers are for MCASP receive interrupt events servicing: MCASP\_RSTAT, MCASP\_RXBUFn, MCASP\_RFMT (n = 0 to 15).

Table 12-34 lists the subprocess call summary for receive interrupt events servicing.

**Table 12-34. Subprocess Call Summary for Receive Interrupt Events Servicing**

| Subprocess Name              | Cross-Reference                                                               |
|------------------------------|-------------------------------------------------------------------------------|
| MCASP receive error handling | <a href="#">Figure 12-34</a>                                                  |
| Start of frame handling      | <a href="#">Section 12.1.1.4.12.2, Receive Data Ready Event and Interrupt</a> |

#### 12.1.1.5.2.3.3 Subsequence – MCASP DIT/TDM -Modes Transmit Error Handling

[Figure 12-33](#) shows the transmit error handling schema for the MCASP, which can be implemented as part of the Tx interrupt service routine or as part of the Tx polling sequence.



mcasp-030

**Figure 12-33. MCASP Transmit Error Handling**

**Note**

- For more information about transmit clock failure handling, see [Section 12.1.1.4.15.6.2, Transmit Clock Failure Check and Recovery](#).
- For more information about transmit buffer underrun handling, see [Section 12.1.1.4.15.1, Buffer Underrun Error - Transmitter](#).
- For more information about DATA port Tx error handling, see [Section 12.1.1.4.15.3, DATA Port Error - Transmitter](#).
- For more information about unexpected Tx frame sync error handling, see [Section 12.1.1.4.15.5, Unexpected Frame Sync Error](#).

**12.1.1.5.2.3.4 Subsequence – MCASP Receive Error Handling**

Figure 12-34 shows the receive error handling schema for the MCASP, which can ONLY be implemented as part of the Rx polling sequence.



mcasp-031

**Figure 12-34. MCASP Receive Error Handling**

This register is for MCASP receive error handling: MCASP\_RSTAT.

---

**Note**

- For more information about receive clock failure handling, see [Section 12.1.1.4.15.6.3, Receive Clock Failure Check and Recovery](#).
  - For more information about receive buffer overrun handling, see [Section 12.1.1.4.15.2, Buffer Overrun Error - Receiver](#).
  - For more information about DATA port Rx error handling, see [Section 12.1.1.4.15.4, DATA Port Error - Receiver](#).
  - For more information about unexpected Rx frame sync error handling, see [Section 12.1.1.4.15.5, Unexpected Frame Sync Error](#).
-

## 12.2 General Connectivity Peripherals

This section describes the general connectivity peripherals in the device.

### 12.2.1 General-Purpose Interface (GPIO)

This chapter describes the General-Purpose Input/Output (GPIO) for the device.

#### 12.2.1.1 GPIO Overview

The General-Purpose Input/Output (GPIO) peripheral provides dedicated general-purpose pins that can be configured as either inputs or outputs. When configured as an output, the user can write to an internal register to control the state driven on the output pin. When configured as an input, user can obtain the state of the input by reading the state of an internal register.

In addition, the GPIO peripheral can produce host CPU interrupts and DMA synchronization events in different interrupt/event generation modes.

The device has one or more instances of GPIO modules. The GPIO pins are grouped into banks (16 pins per bank and 9 banks per module), which means that each GPIO module provides up to 144 dedicated general-purpose pins with input and output capabilities; thus, the general-purpose interface supports up to 432 (3 instances  $\times$  (9 banks  $\times$  16 pins)) pins. Since MCU\_GPIO0\_[23:143], GPIO0\_[87:143], and GPIO1\_[88:143] are reserved in this device, general purpose interface supports up to 198 pins.

Figure 12-35 presents the GPIO modules overview.



**Figure 12-35. GPIO Modules Overview**

- (1): x represents a valid instance of GPIO in a domain.
- (2): n represents the maximum number of GPIO signals -1.
- (3): CBASS0 represents the connectivity in the domain of the IP.
- (4): Some GPIO signals may be uni-directional. Consult the device datasheet for specifics.

#### 12.2.1.1.1 GPIO Features

Each channel in the GPIO modules has the following features:

- Supports 9 banks of 16 GPIO signals
- Supports up to 9 banks of interrupt capable GPIOs
- Interrupts:
  - Can enable interrupts for each bank of 16 GPIO signals
  - Interrupts can be triggered by rising and/or falling edge, specified for each interrupt capable GPIO signal
- Set/clear functionality:

- Firmware writes 1 to corresponding bit position(s) to set or to clear GPIO signal(s). This allows multiple firmware processes to toggle GPIO output signals without critical section protection (disable interrupts, program GPIO, re-enable interrupts, to prevent context switching to another process during GPIO programming).
- Separate Input/Output registers:
  - If preferred by firmware, some GPIO output signals can be toggled by direct write to the output register(s) in addition to set/clear.
  - Output register, when read in, reflects output drive status. This, in addition to the input register reflecting pin status, allows wired logic be implemented.

#### 12.2.1.1.2 *Unsupported Features*

See the *Module Integration* section for information about unsupported features.

---

##### Note

Some features may not be available. See *Module Integration* for more information.

---

### 12.2.1.2 GPIO Environment

This section describes the GPIO external connections (environment).

The general-purpose interface combines three GPIO modules for a flexible, user-programmable, general-purpose input/output (I/O) controller. The general-purpose interface implements functions that are not implemented with the dedicated controllers in the device and require simple input and/or output software-controlled signals. The GPIO allows a variety of custom connections and expands the I/O capabilities of the system to the real world.

The general-purpose interface can physically connect the device to a keyboard matrix and peripheral integrated circuits (ICs).

Figure 12-36 shows a typical application using the general-purpose interface.

#### 12.2.1.2.1 GPIO Interface Signals

Figure 12-36 shows all of the GPIO interface signals.



#### Note

*i* represents a GPIO instance. See the device datasheet for available domains and GPIO instances.

#### Note

See Module Integration section for signal specifics in GPIO.

**Figure 12-36. GPIO Interface Signals and Typical Application**

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

### 12.2.1.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.2.1.4 GPIO Functional Description

##### 12.2.1.4.1 GPIO Block Diagram

Figure 12-37 shows the general-purpose interface block diagram.



gpio\_005

- A. Some of the GPj pins are muxed with other device signals. For details, see the device-specific Datasheet.
- B. All GPINTj can be used as host CPU interrupts and synchronization events to the DMA.
- C. The RIS\_TRIG and FAL\_TRIG registers are internal to the GPIO module and are not visible to the host CPU.

**Figure 12-37. GPIO Block Diagram**

##### 12.2.1.4.2 GPIO Function

Each GPIO pin (GPj) can be independently configured as either an input or an output using the GPIO direction registers. The GPIO direction register (DIR) specifies the direction of each GPIO signal. Logic 0 indicates the GPIO pin is configured as output, and logic 1 indicates input.

When configured as output, writing a 0x1 to a bit in the set data register drives the corresponding GPj to a logic-high state. Writing a 0x1 to a bit in the clear data register drives the corresponding GPj to a logic-low state. The output state of each GPj can also be directly controlled by writing to the output data register.

For example, to set GP8 to a logic-high state, the software can perform one of the following:

- Write 100h to the GPIO0\_SET\_DATA01 register.
- Write 0h to the GPIO\_DIR01 register to configure as output pin.
- Read in GPIO\_OUT\_DATA01 register, change bit 8 to 0x1, and write the new value back to GPIO\_OUT\_DATA01.

To set GP8 to a logic-low state, the software can perform one of the following:

- Write 100h to the GPIO\_CLR\_DATA01 register.
- Write 0h to the GPIO\_DIR01 register to configure as output pin.
- Read in GPIO\_OUT\_DATA01 register, change bit 8 to 0x0, and write the new value back to GPIO\_OUT\_DATA01.

Note that writing a 0x0 to bits in the set data and clear data registers does not affect the GPIO pin state.

Also, for GPIO pins configured as input, writing to the set data, clear data, or output data registers does not affect the pin state.

For a GPIO pin configured as input, reading the input data register (IN\_DATA) will return the pin state. Reading the SET\_DATA register or the CLR\_DATA data register will return the value in OUT\_DATA, not the actual pin state. The pin state is available by reading the input data register. Note that when the direction is configured as input, the output state is determined by software's programming set/clear/output registers, and may not agree with the pin state, which is driven by an external device.

#### **12.2.1.4.3 Interrupt and Event Generation**

Each GPIO pin (GPj) can be configured to generate a host CPU interrupt (GPINTj) or a synchronization event to the DMA (GPINTj). Configuration is on per-bank basis. Each bit of the BINT\_EN parameter dictates YES/NO option for each bank. Bit 0 controls bank 0, bit 1 controls bank 1, and so on.

The interrupt and DMA event can be generated on the rising-edge, falling-edge, or on both edges of the GPIO signal. The edge detection logic is synchronized to the GPIO peripheral clock.

The direction of the GPIO pin does not need to be input when using the pin to generate the interrupt or DMA event. When the GPIO pin is configured as input, transitions on the pin trigger interrupts or DMA events. When the GPIO pin is configured as output, software can toggle the GPIO output register to change the pin state and in turn trigger the interrupt or DMA event.

Note that the direction of the pin need not be input for interrupt generation to work. When the GPINT pin is configured as input, transitions on the pin trigger interrupts. When the GPINT pin is configured as output, firmware can toggle the GPIO output register to change the pin state, and in turn trigger interrupts.

Each interrupt output of GPINT signal are available at the module boundary. Each group of 16 GPINT signals also has their masked interrupt outputs ORed together to generate a per bank interrupt, available at the module boundary. The idea is to either connect individual interrupts or per bank interrupts to the system interrupt controller.

##### **12.2.1.4.3.1 Interrupt Enable (per Bank)**

The GPIO\_BINTEN register provides interrupt enable/disable feature for each bank of 16 GPINT signals.

##### **12.2.1.4.3.2 Trigger Configuration (per Bit)**

Two internal registers, RIS\_TRIG and FAL\_TRIG, specify which edge of the GPj signal generates an interrupt or DMA event. Each bit in these two registers corresponds to a GPj pin. [Table 12-35](#) describes the host CPU interrupt and DMA event generation of GPj pin based on the bit settings of the RIS\_TRIG and FAL\_TRIG registers.

**Table 12-35. GPIO Interrupt and DMA Event Configuration Options**

| Clarifying configuration of GPIO interrupt generation<br>RIS_TRIG Bit n | FAL_TRIG Bit n | Host CPU Interrupt and DMA Event Generation                                               |
|-------------------------------------------------------------------------|----------------|-------------------------------------------------------------------------------------------|
| 0                                                                       | 0              | GPINTj interrupt and DMA event is disabled                                                |
| 0                                                                       | 1              | GPINTj interrupt and DMA event is triggered on falling edge of GPj signal                 |
| 1                                                                       | 0              | GPINTj interrupt and DMA event is triggered on rising edge of GPj signal                  |
| 1                                                                       | 1              | GPINTj interrupt and DMA event is triggered on both rising and falling edge of GPj signal |

The RIS\_TRIG and FAL\_TRIG registers are not directly accessible or visible to the host CPU. These registers are accessed indirectly through four registers: SET\_RIS\_TRIG, CLR\_RIS\_TRIG, SET\_FAL\_TRIG, and CLR\_FAL\_TRIG. Writing 1 to a bit on the SET\_RIS\_TRIG register sets the corresponding bit on the RIS\_TRIG register. Writing 1 to a bit of the CLR\_RIS\_TRIG register clears the corresponding bit on the RIS\_TRIG register. Writing to the SET\_FAL\_TRIG and CLR\_FAL\_TRIG registers works the same way on the FAL\_TRIG register.

Reading the SET\_RIS\_TRIG or CLR\_RIS\_TRIG register returns the value of the RIS\_TRIG register. Reading from the SET\_FAL\_TRIG and CLR\_FAL\_TRIG register returns the value of the FAL\_TRIG register.

To use the GPIO pins as sources for host CPU interrupts and DMA events, the associated bank interrupt enable register bit in GPIO\_BINTEN must also be set to 1. For example, to enable GPIO0\_19 (which is in bank 1), GPIO\_BINTEN[1] = 1 should be set to enable interrupts for bank 1.

#### 12.2.1.4.3.3 Interrupt Status and Clear (per Bit)

The INTSTAT registers provide interrupt status upon reading, and interrupt clear feature upon writing 1 to the corresponding bit position(s). Upon receiving an interrupt, the ISR can examine the interrupt status and clear the processed interrupts.

---

#### Note

The GPIO module generates an interrupt pulse on the individual GPINT interrupt in response to each occurrence of the specified edge condition. Therefore, for GPINT signals having their interrupts routed directly to the interrupt controller, it is not necessary to clear the status bits in this module. The interrupt status and clear register is a facility for the per-bank interrupt connection.

---

#### 12.2.1.4.4 GPIO Interrupt Connectivity

Because this device muxes GPIO signals with other functional signals, the availability of any particular GPIO and hence the usability of its associated interrupt will change based on the use case pin muxing. The large number of possible GPIO interrupt sources makes it impractical to route all interrupt events to each processing element. Since most applications do not typically require a large number of GPIO interrupts, the interrupt uncertainty is resolved by mapping all GPIO interrupts to a series of event muxes implemented using Interrupt Router (IntRouter) modules. These muxes allow any one of the available GPIO interrupts to be selected and passed on as an event to the various processor interrupt controllers and DMA controllers. Event selection is controlled through associated registers within each IntRouter.

The GPIO bank interrupts already represent a consolidation of the 16 GPIO interrupts associated with each bank and are routed directly to various interrupt controllers rather than through the GPIO IntRouters.

One of the GPIO pins has a potential use case as an Arm reset input and should therefore be routed as highest priority interrupt in the GIC and mapped to nFIQ in software.

Figure 12-38 shows the GPIO Interrupt Routers connectivity. Refer to *Interrupt Routers*, for more details on the GPIO Interrupt Routers connectivity.



A. (1): x represents a valid instance of GPIO in a domain.

**Figure 12-38. GPIO Interrupt Router Connectivity**

#### 12.2.1.4.5 Emulation Halt Operation

The GPIO peripheral is not affected by emulation halts.

### 12.2.1.5 GPIO Programming Guide

#### 12.2.1.5.1 GPIO Low-Level Programming Models

##### 12.2.1.5.1.1 Global Initialization

###### 12.2.1.5.1.1.1 Surrounding Modules Global Initialization

This section identifies the requirements for initializing the surrounding modules when the general-purpose interface module is to be used for the first time after a device reset. This initialization of surrounding modules is based on the environment and integration of the general-purpose interface. For more information, see *GPIO Environment and Module Integration*.

**Table 12-36. Global Initialization of Surrounding Modules**

| Surrounding Modules  | Comments                                                                                                                                                            |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPSC0                | Module reset must be enabled. For more information about the module configuration, see <i>Reset</i> .                                                               |
| PLLCTRL0             | Interface and functional clocks must be enabled. For more information about the module configuration, see <i>Clocking</i> .                                         |
| MCU_PLLCTRL0         | Interface and functional clocks must be enabled. For more information about the module configuration, see <i>Clocking</i> .                                         |
| GPIOOMUX_INTRTR0     | Device INTCs must be configured to enable the interrupt request generation. For information about enabling GPIOOMUX_INTRTR0 interrupts, see <i>Interrupts</i> .     |
| MCU_GPIOOMUX_INTRTR0 | Device INTCs must be configured to enable the interrupt request generation. For information about enabling MCU_GPIOOMUX_INTRTR0 interrupts, see <i>Interrupts</i> . |
| Interconnects        | For information about the MCU_CBASS0, and CBASS0 interconnects configuration, see <i>System Interconnect</i> .                                                      |

###### 12.2.1.5.1.1.2 GPIO Module Global Initialization

This procedure initializes the general-purpose Interface module after a power-on reset (POR) or software reset.

**Table 12-37. GPIO Global Initialization**

| Step                                                                 | Register/Bit Field/Programming Model   | Value |
|----------------------------------------------------------------------|----------------------------------------|-------|
| Configure GPIO channels as input or output of the corresponding bank | DIR                                    | -h    |
| <b>Interrupt requests configuration</b>                              |                                        |       |
| Configure detection events                                           | SET_RIS_TRIG<br>and/or<br>SET_FAL_TRIG | -h    |
| Clear interrupt status                                               | INTSTAT                                | FFFFh |
| Enable interrupts for desired banks [0:8]                            | GPIO_BINTEN[8-0]                       | -h    |

###### 12.2.1.5.1.2 GPIO Operational Modes Configuration

###### 12.2.1.5.1.2.1 GPIO Read Input Register

**Table 12-38. GPIO Read Input Register**

| Step                                            | Register/Bit Field/Programming Model | Value      |
|-------------------------------------------------|--------------------------------------|------------|
| Read interrupt status of the corresponding bank | INTSTAT                              | -h         |
| Read input register value                       | IN_DATA                              | -h         |
| Clear interrupt status                          | INTSTAT                              | FFFF FFFFh |

###### 12.2.1.5.1.2.2 GPIO Set Bit Function

**Table 12-39. GPIO Set Bit Function**

| Step                                                 | Register/Bit Field/Programming Model | Value |
|------------------------------------------------------|--------------------------------------|-------|
| Write 1h to set desired bit(s) in SET_DATA register. | SET_DATA                             | -h    |

**12.2.1.5.1.2.3 GPIO Clear Bit Function****Table 12-40. GPIO Clear Bit Function**

| Step                                                   | Register/Bit Field/Programming Model | Value |
|--------------------------------------------------------|--------------------------------------|-------|
| Write 1h to clear desired bit(s) in CLR_DATA register. | CLR_DATA                             | -h    |

## 12.2.2 Inter-Integrated Circuit (I2C) Interface

This section describes the Inter-Integrated Circuit (I2C) module in the device.

### 12.2.2.1 I2C Overview

The device contains multicontroller Inter-Integrated Circuit (I2C) controllers each of which provides an interface between a local host (LH), such as an Arm and any I<sup>2</sup>C-bus-compatible device that connects via the I<sup>2</sup>C serial bus. External components attached to the I<sup>2</sup>C bus can serially transmit and receive up to 8 bits of data to and from the LH device through the 2-wire I<sup>2</sup>C interface.

Each multicontroller I<sup>2</sup>C module can be configured to act like a target or controller I<sup>2</sup>C-compatible device.

I<sup>2</sup>C instances may be implemented with dedicated, I<sup>2</sup>C compliant, open-drain I/O buffers, or with standard LVCMS I/O buffers. The I<sup>2</sup>C instances associated with open-drain I/O buffers can support Hs-mode (up to 3.4 Mbps when the I/O buffers are operating at 1.8 V but limited to 400 kbps when the I/O buffers are operating at 3.3 V).

The I<sup>2</sup>C instances associated with standard LVCMS I/O buffers can support Fast-mode (up to 400 kbps). The LVCMS I/O buffers being used on these ports are connected such they emulate open-drain outputs. This emulation is achieved by forcing a constant low output and disabling the output buffer to enter the Hi-Z state.

Refer to the device specific datasheet for details on which instances support which buffer type.

For the specific I/O timing characteristics of the different I<sup>2</sup>C instances, see the device-specific Datasheet.

Figure 12-39 shows the I<sup>2</sup>C modules overview.



- A. (1): i = 0 to (number of devices - 1) in MCU Domain, if applicable.
- B. (2): i = 0 to (number of devices - 1) in MAIN Domain, if applicable.

Figure 12-39. I<sup>2</sup>C Modules Overview

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

Each multicontroller I<sup>2</sup>C module has the following features:

- Compliant with Philips I<sup>2</sup>C-bus specification version 2.1
- Supports a standard mode (up to 100 Kbps) and fast mode (up to 400 Kbps)
- Supports HS mode (up to 3.4 Mbps) only for instances with true open drain buffer and in 1.8 V mode
- 7-bit and 10-bit device addressing modes
- General call
- Start/Restart/Stop
- Multicontroller transmitter/target receiver mode
- Multicontroller receiver/target transmitter mode
- Combined controller transmit/receive and receive/transmit mode
- Built-in FIFO for buffered read
- Module enable/disable capability
- Programmable multitarget channel (responds to four separate addresses)
- Programmable clock generation
- 8-bit-wide data access
- Low power consumption
- Support Auto Idle mechanism
- Support Idle Request/Idle Acknowledge handshake mechanism
- Support for asynchronous wakeup mechanism
- Wide interrupt capability

#### 12.2.2.1.2 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.2.2.1.3 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

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

This section describes the I<sup>2</sup>C external connections (environment).

#### 12.2.2.2.1 I<sup>2</sup>C Typical Application

Figure 12-40 shows the multicontroller I<sup>2</sup>C and their related connections with I<sup>2</sup>C-compliant devices.



**Figure 12-40. I<sup>2</sup>C and Typical Connections to I<sup>2</sup>C Devices**

#### 12.2.2.2.1.1 I<sup>2</sup>C Pins for Typical Connections in I<sup>2</sup>C Mode

Figure 12-41 shows the multicontroller I<sup>2</sup>C pins used for typical connections with I<sup>2</sup>C devices.



1.  $i = 0$  to (number of devices - 1) in WKUP Domain, if applicable
2.  $i = 0$  to (number of devices - 1) in MCU Domain, if applicable
3.  $i = 0$  to (number of devices - 1) in MAIN Domain, if applicable

**Figure 12-41. I<sup>2</sup>C Interface Signals**

### 12.2.2.2.1.2 I<sup>2</sup>C Interface Typical Connections

Table 12-41 describes the I<sup>2</sup>C I/O signals.

**Table 12-41. I<sup>2</sup>C I/O Signals**

| Module Pin                     | Device Level Signal           | I/O <sup>(1)</sup> | Description                         | Module Pin Reset Value |
|--------------------------------|-------------------------------|--------------------|-------------------------------------|------------------------|
| <b>WKUP_I2Ci<sup>(2)</sup></b> |                               |                    |                                     |                        |
| SCL                            | WKUP_I2Ci <sup>(2)</sup> _SCL | I/O                | I <sup>2</sup> C serial clock line. | 1                      |
| SDA                            | WKUP_I2Ci <sup>(2)</sup> _SDA | I/O                | I <sup>2</sup> C serial data line.  | 1                      |
| <b>MCU_I2Ci<sup>(2)</sup></b>  |                               |                    |                                     |                        |
| SCL                            | MCU_I2Ci <sup>(2)</sup> _SCL  | I/O                | I <sup>2</sup> C serial clock line. | 1                      |
| SDA                            | MCU_I2Ci <sup>(2)</sup> _SDA  | I/O                | I <sup>2</sup> C serial data line.  | 1                      |
| <b>I2Ci<sup>(2)</sup></b>      |                               |                    |                                     |                        |
| SCL                            | I2Ci <sup>(2)</sup> _SCL      | I/O                | I <sup>2</sup> C serial clock line. | 1                      |
| SDA                            | I2Ci <sup>(2)</sup> _SDA      | I/O                | I <sup>2</sup> C serial data line.  | 1                      |

(1) I = Input; O = Output; I/O = Bidirectional

(2) i represents an I<sup>2</sup>C instance. See the device datasheet for available domains and I<sup>2</sup>C instances.

### 12.2.2.2.1.3

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

### 12.2.2.2.2 I<sup>2</sup>C Typical Connection Protocol and Data Format

#### 12.2.2.2.2.1 I<sup>2</sup>C Serial Data Format

The I<sup>2</sup>C controller operates in 8-bit word data format (byte write access supported for the last access). Each byte transmitted or received on the serial data line is 8 bits long. The number of bytes that can be transmitted or received is not restricted. The data is transferred with the most-significant bit (MSB) first. In receiver mode, each byte is followed by an acknowledge bit from the I<sup>2</sup>C module.

Figure 12-42 shows a typical I<sup>2</sup>C communication format.



**Figure 12-42. I<sup>2</sup>C Data Transfer**

#### 12.2.2.2.2.2 I<sup>2</sup>C Data Validity

The data on the serial data line (SDA) must be stable during the high period of the serial clock line. The high and low states of the data line can change only when the clock signal on the serial clock line (SCL) is low.

Figure 12-43 is an example of data validity requirements.



i2c-005

**Figure 12-43. I2C Bit Transfer on the I2C Bus**

#### 12.2.2.2.2.3 I2C Start and Stop Conditions

The I2C module generates start (S) and stop (P) conditions when it is configured as a controller.

- An S condition is a high-to-low transition on the serial data line while serial clock line is high.
- A P condition is a low-to-high transition on the serial data line while serial clock line is high.

The bus is considered busy after the S condition (the I2C\_IRQSTATUS\_RAW [12] BB bit is 1 to indicate that the bus is busy) and free after the P condition (the I2C\_IRQSTATUS\_RAW [12] BB bit is 0 to indicate that the bus is free).

Figure 12-44 shows the waveforms that occur during an S and a P condition.



i2c-006

**Figure 12-44. I2C S and P Condition Events**

#### Note

I2C controller does not support messages non-compliant with I<sup>2</sup>C standard. Void messages are non-standard I<sup>2</sup>C messages and will lockup the controller. A void message is a START condition followed by a STOP condition, in other words, while the bus is free the SDA line is pulled low (START) and then released (STOP). This would result in a timeout (software) of the next controller transfer which would never complete. A soft reset of the controller is recommended for recovery.

#### 12.2.2.2.4 I2C Addressing

The I2C module supports two data formats in fast/standard (F/S) and HS modes:

- 7-bit/10-bit addressing format
- 7-bit/10-bit addressing format with repeated start (Sr) condition

#### 12.2.2.2.4.1 Data Transfer Formats in F/S Mode

Figure 12-45 shows the I2C data transfer formats in F/S mode.



i2c-007

**Figure 12-45. I2C Data Transfer Formats in F/S Mode**

The first word after an S condition consists of 8 bits. In acknowledge mode, an extra dedicated acknowledgment bit is inserted after each byte.

In addressing formats with 7-bit addresses, the first byte is composed of 7 MSB target address bits and 1 least-significant bit (LSB) R/W\_ bit.

The LSB R/W\_ bit of the address byte indicates the transmission direction of the data bytes that follow it. If R/W\_ is 0, the controller writes data to the selected target; if it is 1, the controller reads data from the target.

In addressing formats with 10-bit addresses, the structure of the first byte is 11110XXY, where XX is the two MSBs of the 10-bit addresses, and Y is the R/W\_ bit. If the R/W\_ bit is 0, the next byte contains the last 8 bits of the target address. If the R/W\_ bit is 1, the next byte contains data transmitted from the target to the controller.

#### 12.2.2.2.4.2 Data Transfer Format in HS Mode

Figure 12-46 shows the I2C data transfer format in HS mode.



S = Start; Sr = repeated start; P = Stop; F/S = Fast/standard mode; HS = High-speed mode

i2c-008

**Figure 12-46. HS I2C Data Transfer in HS Mode**

Each multicontroller I2C can also operate in HS mode. In this case, after the S condition, the module, which is in F/S mode, writes the controller code address (0x00001XXX, where XXX is the variable portion of the controller code) on the bus. No device connected on the same bus acknowledges this address. The module switches the clock to the HS clock and after an Sr condition, and sends the target address and the data, as shown in Figure 12-46.

#### 12.2.2.2.5 I2C Controller Transmitter

In controller transmitter mode, data assembled in one of the previously described data formats is shifted out on the serial data line SDA in sync with the self-generated clock pulses on the serial clock line SCL. The clock pulses are inhibited and SCL is held low when the intervention of the processor is required (XUDF) after a byte is transmitted.

#### 12.2.2.2.6 I2C Controller Receiver

Controller receiver mode can be entered only from controller transmitter mode. With any of the address formats (a), (b), or (c) (see [Figure 12-45](#)), if R/W<sub>\_</sub> is high, the module enters controller receiver mode after the target address byte and bit R/W<sub>\_</sub> are transmitted. Serial data bits received on bus line SDA are shifted in synchronization with the self-generated clock pulses on SCL.

#### 12.2.2.2.7 I2C Target Transmitter

Target transmitter mode can be entered only from target receiver mode. With any of the address formats (a), (b), or (c) (see [Figure 12-45](#)), the target transmitter is entered if the target address byte is the same as its own address and bit R/W<sub>\_</sub> is transmitted, if R/W<sub>\_</sub> is high. The target transmitter shifts the serial data out on the data line SDA in sync with the clock pulses that are generated by the controller device. It does not generate the clock but it can hold clock line SCL low while intervention of the LH is required (XUDF).

#### 12.2.2.2.8 I2C Target Receiver

In this mode, serial data bits received on the bus line SDA are shifted-in in sync with the clock pulses on SCL that are generated by the controller device. It does not generate the clock but it can hold clock line SCL low while intervention of the LH is required (ROVR) after a byte is received.

#### 12.2.2.2.9 I2C Bus Arbitration

If two or more controller transmitters start a transmission on the same bus almost simultaneously, an arbitration procedure is invoked. The arbitration procedure uses the data presented on the serial bus by the competing transmitters. When a transmitter senses that a high signal it has presented on the bus has been overruled by a low signal, it switches to the target receiver mode, sets the arbitration lost (I2C IRQSTATUS\_RAW[0] AL) flag, and generates the arbitration lost interrupt. [I2C Arbitration Between Controller Transmitters](#) shows the arbitration procedure between two devices. The arbitration procedure gives priority to the device that transmits the serial data stream with the lowest binary value. If two or more devices send identical first bytes, arbitration continues on the subsequent bytes.



Figure 12-47. I2C Arbitration Between Controller Transmitters

#### 12.2.2.2.10 I2C Clock Generation and Synchronization

Under normal conditions, only one controller device generates the clock signal - SCL. However, there are two or more controller devices during the arbitration procedure, and the clock must be synchronized so that the data output can be compared. The wired-AND property of the clock line means that a device that first generates a low period of the clock line overrules the other devices. At this high/low transition, the clock generators of the other devices are forced to start generation of their own low period. The clock line is then held low by the device

with the longest low period, while the other devices that finish their low periods must wait for the clock line to be released before starting their high periods. A synchronized signal on the clock line is thus obtained, where the slowest device determines the length of the low period and the fastest device determines the length of the high period. If a device pulls down the clock line for a longer time, the result is that all clock generators must enter the WAIT-state. In this way a target can slow down a fast controller and the slow device can create enough time to store a received byte or prepare a byte to be transmitted (clock stretching).

#### Note

In case the SCL or SDA lines are stuck low, a bus clearing operation is supported:

- If the clock line (SCL) is stuck low, the preferential procedure is to reset the bus using the hardware reset signal if the I<sup>2</sup>C devices have hardware reset inputs. If the I<sup>2</sup>C devices do not have hardware reset inputs, cycle power to the devices to activate the mandatory internal power-on reset (POR) circuit.
- If the data line (SDA) is stuck low, the controller should send nine clock pulses. The device that held the bus low should release it sometime within those nine clocks. If not, then use the hardware reset or cycle power to clear the bus.

Figure 12-48 shows clock synchronization.



**Figure 12-48. I<sup>2</sup>C Clock Generators Synchronization**

### 12.2.2.3 I<sup>2</sup>C Functional Description

#### 12.2.2.3.1 I<sup>2</sup>C Block Diagram

##### Note

DMA mode and SCCB Protocol are not supported on this family of devices.

Figure 12-49 presents the multicontroller I<sup>2</sup>C block diagram.



- A.  $i = 0$  to number of devices in MCU domain -1.
- B.  $i = 0$  to number of devices in MAIN domain -1.

**Figure 12-49. I<sup>2</sup>C Block Diagram**

The ten multicontroller I<sup>2</sup>C can be configured in F/S I<sup>2</sup>C mode or HS I<sup>2</sup>C mode. The operation mode is selected by configuring the I<sup>2</sup>C\_CON[13-12] OPMODE bit field.

Table 12-42 lists the available operation modes.

**Table 12-42. I<sup>2</sup>C Operation Mode Selection**

| Operation Mode       | Value of I <sup>2</sup> C_CON[13-12] OPMODE |
|----------------------|---------------------------------------------|
| F/S I <sup>2</sup> C | 0x0                                         |
| HS I <sup>2</sup> C  | 0x1                                         |
| SCCB                 | 0x2                                         |
| Reserved (not used)  | 0x3                                         |

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

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

Each multicontroller I<sup>2</sup>C uses the SYS\_CLK functional clock in the Device Configuration section. The internal sampling clock INTERNAL\_CLK is generated by dividing the functional clock by the I<sup>2</sup>C\_PSC[7-0] PSC bit field value + 1 in F/S mode, or in the first phase of HS mode; or by directly using the functional clock in the second phase of HS mode (prescaler is bypassed).

The low time of the SCLL signal is determined by the I2C\_SCLL[7-0] SCLL bit field in F/S mode and in the first phase of HS mode; or by the I2C\_SCLL[15-8] HSSCLL bit field in the second phase of HS mode.

The high time of the SCLL signal is determined by the I2C\_SCLH[7-0] SCLH bit field in F/S mode and in the first phase of HS mode; or by the I2C\_SCLH[15-8] HSSCLH bit field in the second phase of HS mode.

**Table 12-43** lists the  $t_{low}$  and  $t_{high}$  values in controller mode only (in target mode, the I2C controller does not generate the I<sup>2</sup>C clock).

**Table 12-43. I<sup>2</sup>C  $t_{low}$  and  $t_{high}$  Values of the I<sup>2</sup>C Clock**

| Mode                  | Clock                                                     | $t_{low}$                                                      | $t_{high}$                                                         |
|-----------------------|-----------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------|
| F/S or HS first phase | INTERNAL_CLK = SYS_CLK / (I2C_PSC[7-0] PSC bit field + 1) | (I2C_SCLL[7-0] SCLL bit field value + 7) × INTERNAL_CLK period | (I2C_SCLH[7-0] SCLH bit field value + 5) × I2C_INTERNAL_CLK period |
| HS second phase       | SYS_CLK                                                   | (I2C_SCLL[15-8] HSSCLL bit field value + 7) × SYS_CLK period   | (I2C_SCLL[15-8] HSSCLL bit field value + 5) × I2C_SYS_CLK period   |

#### Note

For HS mode, the I2C\_SCLL[15-8] HSSCLL and I2C\_SCLL[7-0] SCLL bit fields must be programmed (the first phase of an HS transaction is performed at F/S speed).

For HS mode, the I2C\_SCLH[15-8] HSSCLH and I2C\_SCLH[7-0] SCLH bit fields must be programmed (the first phase of an HS transaction is performed at F/S speed).

#### Note

The equations in **Table 12-43** give the SCLL timing values for SCLL/SCLH/HSSCLL/HSSCLH at I2C controller outputs. Actual  $t_{low}$  and  $t_{high}$  periods may vary depending on the board (the load capacitance on the SCLL signal). If necessary, any adjustments to the SCLL/SCLH/HSSCLL/HSSCLH values must be determined by measurements of actual SCL signal on the board.

#### CAUTION

During active mode (the I2C\_CON[15] I2C\_EN bit is set to 1), make no changes to the I2C\_SCLL and I2C\_SCLH registers. Changes may result in unpredictable behavior.

**Table 12-44** lists the register values for obtaining the maximum I<sup>2</sup>C bit rates and the maximum period of the filtered spikes in F/S mode and HS mode.

**Table 12-44. I<sup>2</sup>C Register Values for Maximum I<sup>2</sup>C Bit Rates in I<sup>2</sup>C F/S, I<sup>2</sup>C HS Modes<sup>(1)</sup>**

|                              | I <sup>2</sup> C Mode for |           |                                | Description                                   |
|------------------------------|---------------------------|-----------|--------------------------------|-----------------------------------------------|
|                              | Standard Mode             | Fast Mode | High-Speed Mode <sup>(2)</sup> |                                               |
| SYS_CLK frequency (MHz)      |                           | 96        |                                |                                               |
| OCP_CLK frequency (MHz)      |                           | 133       |                                |                                               |
| I2C_PSC[7-0] PSC             | 23                        | 9         | 1                              | Prescaler value for F/S and HS modes          |
| INTERNAL_CLK frequency (MHz) | 4                         | 9.6       | 96                             |                                               |
| I2C_SCLL[7-0] SCLL           | 13                        | 7         | 115                            | Value for F/S mode and first phase of HS mode |
| I2C_SCLH[7-0] SCLH           | 15                        | 5         | 113                            | Value for F/S mode and first phase of HS mode |

**Table 12-44. I2C Register Values for Maximum I2C Bit Rates in I2C F/S, I2C HS Modes<sup>(1)</sup> (continued)**

|                                 | I <sup>2</sup> C Mode for |       |           | Description                                          |
|---------------------------------|---------------------------|-------|-----------|------------------------------------------------------|
| Maximum bit rate (Mbps)         | 0.1                       | 0.4   | 0.4       | F/S mode and first phase in HS mode maximum bit rate |
| Maximum filter period (ns)      | 250                       | 104.2 | 10        |                                                      |
| I2C_SCLL[15-8] HSSCLL           |                           |       | <b>12</b> | Values for second phase of HS mode                   |
| I2C_SCLH[15-8] HSSCLH           |                           |       | <b>5</b>  |                                                      |
| HS mode maximum bit rate (Mbps) |                           |       | 3.31      | HS mode maximum bit rate                             |
| Maximum filter period (ns)      |                           |       | 10        |                                                      |

(1) Programmable fields are in bold.

(2) HS mode is not supported on this family of devices.

#### Note

This table presents informative values only for the configuration parameters and the I<sup>2</sup>C bus performance obtained according to these values. The delays added by the analog pads are not considered in these figures.

#### Note

For MCU\_I2C[0-1]

For I2C[0-3]

I2Ci\_INTERNAL\_CLK freq = I2Ci\_SYS\_CLK / (PSC +1)

F/S filter period = 1 / I2Ci\_INTERNAL\_CLK

HS filter period = 1 / I2Ci\_SYS\_CLK freq

HS bit rate = I2Ci\_SYS\_CLK freq / (HSSCLL+ 7 + HSSCLH + 5)

FS bit rate = I2Ci\_INTERNAL\_CLK / (SCLL+ 7 + SCLH + 5)

#### 12.2.2.3.2.2 I2C Automatic Blocking of the I2C Clock Feature

This feature offers the possibility for the LH to command the blocking of the I<sup>2</sup>C clock after the target addressing phase, when the I2C controller is addressed by an external controller device using a certain Own Address.

The release of the I<sup>2</sup>C clock can be performed independently for each Own Address (I2C\_OA<sub>x</sub> and I2C\_OAx registers, where x = 1, 2, 3) by deasserting the corresponding bit in the I2C\_SBLOCK register.

#### 12.2.2.3.3 I2C Software Reset

Each multicontroller I2C supports the software reset by accessing the I2C\_SYSC[1] SRST bit (1: reset; 0: normal mode).

The software reset status can be checked by accessing the I2C\_SYSS[0] RDONE bit (1: reset is done; 0: reset is ongoing).

To do a software reset, the following steps must be done:

1. Ensure that the module is disabled (clear the I2C\_CON[15] I2C\_EN bit to 0).
2. Set the I2C\_SYSC[1] SRST bit to 1.
3. Enable the module by setting I2C\_CON[15] I2C\_EN bit to 1.
4. Check the I2C\_SYSS[0] RDONE bit until it is set to 1 to indicate the software reset is complete.

---

**Note**

The I2C\_CON[15] I2C\_EN bit can hold the functional clock domain of the multicontroller I2C in reset after the device reset has been released. When the system bus reset is removed, this bit remains cleared. The functional part of the I2C controller is held in reset state while this bit is 0, and all configuration registers can be accessed.

The I2C\_CON[15] I2C\_EN bit must be set to 1 to enable the functional part of the I2C controller.

The I2C\_SYSS[0] RDONE bit is asserted only after the module is enabled by setting the I2C\_CON[15] I2C\_EN bit to 1.

---

**12.2.2.3.4 I2C Power Management**

Table 12-45 describes power-management features available for the multicontroller I2C.

---

**Note**

For information about source clock gating, see *Power in the Device Configuration*.

---

**Note**

Some of the I2C features described in this section may not be supported on this family of devices. For more information, see *I2C Not Supported Features*.

---

**Table 12-45. I2C Local Power-Management Features**

| Feature               | Registers                   | Description                                                                         |
|-----------------------|-----------------------------|-------------------------------------------------------------------------------------|
| Clock auto gating     | I2C_SYSC[0] AUTOIDLE        | This bit allows a local power optimization inside the module.                       |
| Target idle modes     | I2C_SYSC[4-3] IDLEMODE      | Force-idle, no-idle, smart-idle, and smart-idle wakeup-capable modes are available. |
| Clock activity        | I2C_SYSC[9-8] CLOCKACTIVITY | For configuration details, see Table 12-46.                                         |
| Global wake-up enable | I2C_SYSC[2] ENAWAKEUP       | This bit enables the wake-up feature at module level.                               |

**Table 12-46. I2C Clock Activity Settings**

| I2C_SYSC[9-8]<br>CLOCKACTIVITY | Clock State When Module is in IDLE State |         | Features Available/Unavailable When Module is in IDLE State |
|--------------------------------|------------------------------------------|---------|-------------------------------------------------------------|
|                                | OCP_CLK                                  | SYS_CLK |                                                             |
| 00                             | OFF                                      | OFF     | Both clocks are disabled.                                   |
| 10                             | OFF                                      | ON      | Interface clock is disabled; Functional clock is enabled    |
| 01                             | ON                                       | OFF     | Functional clock is disabled; Interface clock is enabled    |
| 11                             | ON                                       | ON      | Both clocks are enabled.                                    |

**12.2.2.3.5 I2C Interrupt Requests**

The I2C controller must allocate a minimum of five registers for interrupts.

- Interrupt Raw Status (I2C\_IRQSTATUS\_RAW)
- Interrupt Enabled Status (I2C\_IRQSTATUS)
- Interrupt Enable Set (I2C\_IRQENABLE\_SET)
- Interrupt enable Clear (I2C\_IRQENABLE\_CLR)
- End of interrupt (I2C\_EOI)

End of Interrupt (I2C\_EOI) is used by software to trigger an interrupt service completion.

Table 12-47 lists the event flags, and their mask, that can cause module interrupts.

Table 12-47. I2C Events

| Event Flag             | Event Unmask                  | Event Mask                    | Description                                                                                                                                                                   |
|------------------------|-------------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I2C IRQSTATUS[0] AL    | I2C_IRQENABLE_SET[0] AL_IE    | I2C_IRQENABLE_CLR[0] AL_IE    | Arbitration lost. This bit is automatically set by the hardware when it loses the arbitration in controller transmit mode, an interrupt is signaled to the host.              |
| I2C IRQSTATUS[1] NACK  | I2C_IRQENABLE_SET[1] NACK_IE  | I2C_IRQENABLE_CLR[1] NACK_IE  | No acknowledgement. Bit is set when No Acknowledge is received, an interrupt is signaled to the host.                                                                         |
| I2C IRQSTATUS[2] ARDY  | I2C_IRQENABLE_SET[2] ARDY_IE  | I2C_IRQENABLE_CLR[2] ARDY_IE  | Register access ready. When set to 1 it indicates that previous access has been performed and registers are ready to be accessed again. An interrupt is signaled to the host. |
| I2C IRQSTATUS[3] RRDY  | I2C_IRQENABLE_SET[3] RRDY_IE  | I2C_IRQENABLE_CLR[3] RRDY_IE  | Receive data ready. Set to 1 by core when in receiver mode, a new data can be read. An interrupt is signaled to the host.                                                     |
| I2C IRQSTATUS[4] XRDY  | I2C_IRQENABLE_SET[4] XRDY_IE  | I2C_IRQENABLE_CLR[4] XRDY_IE  | Transmit data ready. Set to 1 by core when transmitter is ready for new data. An interrupt is signaled to the host.                                                           |
| I2C IRQSTATUS[5] GC    | I2C_IRQENABLE_SET[5] GC_IE    | I2C_IRQENABLE_CLR[5] GC_IE    | General call. Set to 1 by core when General Call address was detected. An interrupt is signaled to the host.                                                                  |
| I2C IRQSTATUS[6] STC   | I2C_IRQENABLE_SET[6] STC_IE   | I2C_IRQENABLE_CLR[6] STC_IE   | Start condition detected. An interrupt is signaled to the host.                                                                                                               |
| I2C IRQSTATUS[7] AERR  | I2C_IRQENABLE_SET[7] AERR_IE  | I2C_IRQENABLE_CLR[7] AERR_IE  | Bus Access Error. An interrupt is signaled to the host.                                                                                                                       |
| I2C IRQSTATUS[8] BF    | I2C_IRQENABLE_SET[8] BF_IE    | I2C_IRQENABLE_CLR[8] BF_IE    | Bus free. An interrupt is signaled to the host.                                                                                                                               |
| I2C IRQSTATUS[9] AAS   | I2C_IRQENABLE_SET[9] AAS_IE   | I2C_IRQENABLE_CLR[9] AAS_IE   | Address recognized as target. An interrupt is signaled to the host.                                                                                                           |
| I2C IRQSTATUS[10] XUDF | I2C_IRQENABLE_SET[10] XUDF_IE | I2C_IRQENABLE_CLR[10] XUDF_IE | Transmit underflow. An interrupt is signaled to the host.                                                                                                                     |
| I2C IRQSTATUS[11] ROVR | I2C_IRQENABLE_SET[11] ROVR_IE | I2C_IRQENABLE_CLR[11] ROVR_IE | Receive overrun. An interrupt is signaled to the host.                                                                                                                        |
| I2C IRQSTATUS[12] BB   | N/A                           | N/A                           | Bus busy indicator                                                                                                                                                            |
| I2C IRQSTATUS[13] RDR  | I2C_IRQENABLE_SET[13] RDR_IE  | I2C_IRQENABLE_CLR[13] RDR_IE  | Receive draining. An interrupt is signaled to the host.                                                                                                                       |
| I2C IRQSTATUS[14] XDR  | I2C_IRQENABLE_SET[14] XDR_IE  | I2C_IRQENABLE_CLR[14] XDR_IE  | Transmit draining. An interrupt is signaled to the host.                                                                                                                      |

#### 12.2.2.3.6 I2C Programmable Multitarget Channel Feature

This feature allows each multicontroller I2C to be addressed using four separate Own Addresses configured in the I2C\_OA and I2C\_OAx registers (where x = 1, 2, 3). An additional register (I2C\_ACTOA) is used to indicate to the LH which address is used by the external controller to communicate with the I2C controller.

Each Own Address can be independently configured in 7-bit or 10-bit mode by setting the corresponding bit (I2C\_CON[7] XOA0, I2C\_CON[6] XOA1, I2C\_CON[5] XOA2, or I2C\_CON[4] XOA3).

#### 12.2.2.3.7 I2C FIFO Management

The depth of the RX and TX FIFOs can be checked by reading the I2C\_BUFSTAT[15-14] FIFODEPTH bit field (0x0: 8 bytes, 0x1: 16 bytes, 0x2: 32 bytes, and 0x3: 64 bytes).

#### 12.2.2.3.7.1 I2C FIFO Interrupt Mode

In FIFO interrupt mode (relevant interrupts enabled by the I2C\_IRQENABLE\_SET register), an interrupt signal informs the processor of the receiver and transmitter status. These interrupts are raised when the RX/TX FIFO thresholds (defined by the I2C\_BUF[13-8] RXTRSH bit field value + 1 for the RX FIFO or the I2C\_BUF[5-0] TXTRSH bit field value + 1 for the TX FIFO) are reached; the interrupt signals instruct the LH to transfer data to the destination (from the I2C controller in receive mode and/or from any source to the I2C controller FIFO in transmit mode).

Figure 12-50 and Figure 12-51 show receive and transmit operations, respectively, from a FIFO management point of view.



i2c-013

**Figure 12-50. I2C Receive FIFO Interrupt Request Generation**

In Figure 12-50, the RRDY interrupt condition shows that the condition for generating an RRDY interrupt is achieved. The interrupt request is generated when this signal is active, and it can be cleared only by the LH by writing 1 in the corresponding bit. If the condition is still present after clearing the previous interrupt, another interrupt request is generated.

In receive mode, an RRDY interrupt is generated as soon as the FIFO reaches its receive threshold (I2C\_BUF[13-8] RXTRSH bit field value + 1). The interrupt can be deasserted only when the LH has handled enough bytes to make the number of bytes in the RX FIFO lower than the programmed threshold. For each interrupt, the LH can be configured to read a number of bytes equal to the value of the RX FIFO threshold.



**Figure 12-51. I2C Transmit FIFO Interrupt Request Generation**

In Figure 12-51, the XRDY interrupt condition shows that the condition for generating an XRDY interrupt is achieved. The interrupt request is generated when TX FIFO is empty or when the TX FIFO threshold is not reached, and the LH can clear the XRDY status bit by setting the I2C\_IRQENABLE\_CLR[4] XRDY\_IE bit to 1 after transmitting the configured number of bytes. If the condition is still present after clearing the previous interrupt, another interrupt request is generated.

In interrupt mode, the module offers two options for the LH application to handle the interrupts:

- When detecting an interrupt request (XRDY or RRDY type), the LH can write/read 1 data byte to/from the TX/RX FIFO and then clear the interrupt. The module reasserts the interrupt until the interrupt condition is not met.
- When detecting an interrupt request (XRDY or RRDY type), the LH can be programmed to write/read the amount of data bytes specified by the corresponding FIFO threshold (I2C\_BUF[5-0] TXTRSH + 1 or I2C\_BUF[5-0] RXTRSH + 1). In this case, the interrupt condition is cleared and the next interrupt is asserted again when the XRDY or RRDY condition is met again.

If the second-interrupt-serving approach is used, an additional mechanism (draining feature) is implemented for cases where the transfer length is not a multiple of the FIFO threshold value (see [Section 12.2.2.3.7.3, Draining Feature \[I2C Mode Only\]](#)).

#### Note

In target transmit mode (the I2C\_CON[10] MST bit is cleared and the I2C\_CON[9] TRX bit is set to 1), the draining feature must not be used, because the transfer length is not known at configuration time, and the external controller can end the transfer at any point by not acknowledging 1 data byte. If the draining feature is used in target transmit mode, data can remain in the TX FIFO without being transmitted over the I<sup>2</sup>C bus. In this case, the TX FIFO must be cleared by setting the I2C\_BUF[6] TXFIFO\_CLR bit.

#### 12.2.2.3.7.2 I2C FIFO Polling Mode

In FIFO polling mode (the I2C\_IRQENABLE\_SET[4] XRDY\_IE and I2C\_IRQENABLE\_SET[3] RRDY\_IE bits are disabled), the status of the module (receiver or transmitter) can be checked by polling the I2C\_IRQSTATUS\_RAW[4] XRDY and the I2C\_IRQSTATUS\_RAW[3] RRDY bits (the I2C\_IRQSTATUS\_RAW[13] RDR and I2C\_IRQSTATUS\_RAW[14] XDR bits can also be polled if the draining feature is enabled). The I2C\_IRQSTATUS\_RAW[4] XRDY and I2C\_IRQSTATUS\_RAW[3] RRDY bits accurately reflect the interrupt conditions described in the discussion of FIFO interrupt mode.

### 12.2.2.3.7.3 I2C Draining Feature

---

#### Note

DMA mode and SCCB Protocol are not supported on this family of devices.

---

The draining feature is implemented to handle the end of a transfer whose length is not a multiple of the FIFO threshold values (the I2C\_BUF[13-8] RXTRSH bit field value + 1 for the RX threshold and the I2C\_BUF[5-0] TXTRSH field value + 1 for the TX threshold). It can also transfer the remaining number of bytes (because the threshold is not reached).

This feature prevents the LH or the DMA controller from trying more FIFO accesses than necessary (for example, to generate at the end of a transfer a DMA RX request having fewer bytes in the FIFO than the configured DMA transfer length). Otherwise, an AERR interrupt is generated by the I2C\_IRQSTATUS\_RAW[7] AERR bit.

The draining mechanism generates an interrupt using the I2C\_IRQSTATUS\_RAW[13] RDR or I2C\_IRQSTATUS\_RAW[14] XDR bit at the end of the transfer, informing the LH that it must check the amount of data left to be transferred (the I2C\_BUFSTAT[13-8] RXSTAT or I2C\_BUFSTAT[5-0] TXSTAT bit fields) and enable the draining feature of the DMA controller by reconfiguring the DMA transfer length according to this value (when the DMA mode is enabled) or perform only the required number of data accesses (when the DMA mode is disabled).

In receive mode (controller or target), if the RX FIFO threshold (the I2C\_BUF[13-8] RXTRSH bit field value + 1) is not reached, but the transfer ends on the I<sup>2</sup>C bus and data remains in the RX FIFO (less than the threshold), the receive draining interrupt (the I2C\_IRQSTATUS\_RAW[13] RDR bit) is asserted to inform the LH that it can read the amount of data in the RX FIFO (the I2C\_BUFSTAT[13-8] RXSTAT bit field). The LH performs a number of data read accesses equal to the I2C\_BUFSTAT[13-8] RXSTAT bit field (interrupt or polling mode), or reconfigures the DMA controller with the required value to drain the FIFO.

In controller transmit mode, if the TX FIFO threshold (the I2C\_BUF[5-0] TXTRSH bit field value + 1) is not reached, but the amount of data remaining to be written in the TX FIFO is less than the threshold, the transmit draining interrupt (the I2C\_IRQSTATUS\_RAW[14] XDR bit) is asserted to inform the LH that it can read the amount of data remaining to be written in the TX FIFO (the I2C\_BUFSTAT[5-0] TXSTAT bit field). The LH must write the required number of data bytes specified by the I2C\_BUFSTAT[5-0] TXSTAT bit field value or reconfigure the DMA controller with the value required to transfer the last bytes to the FIFO.

In controller mode, the LH can alternately not check the values of the I2C\_BUFSTAT[5-0] TXSTAT and I2C\_BUFSTAT[13-8] RXSTAT bit fields, because it can obtain this information internally (by computing the I2C\_CNT[15-0] DATACOUNT bit field value modulo I2C\_BUF[13-8] RXTRSH or I2C\_BUF[5-0] TXTRSH).

By default, the draining feature is disabled; it can be enabled using the I2C\_IRQENABLE\_SET[14] XDR\_IE or I2C\_IRQENABLE\_SET[13] RDR\_IE bits (default disabled) only for transfers with lengths not equal to the threshold values (I2C\_BUF[5-0] TXTRSH bit field value + 1 for the TX threshold or the I2C\_BUF[13-8] RXTRSH bit field value + 1 for the RX threshold).

### 12.2.2.3.8 I2C Noise Filter

The noise filter is used to suppress any noise that is 50 ns or less in case of F/S operation modes, and any noise that is 10 ns or less in case of HS mode operation. The noise filter is always one period of the INTERNAL\_CLK clock. This way, for HS mode operation (prescaler bypassed), the filter suppresses spikes of less than 10.4 ns.

For standard mode (for example, the I2C\_PSC[7-0] PSC bit field = 4), the maximum width of suppressed spikes is 46.1 ns.

To ensure correct filtering, the prescaler must be programmed accordingly by the I2Ci.I2C\_PSC[7-0] PSC bit field.

### 12.2.2.3.9 I<sup>2</sup>C System Test Mode

A system test mode is available for multicontroller I<sup>2</sup>C module testing. This mode is enabled by setting the I<sup>2</sup>C\_SYSTEST[15] ST\_EN bit to 1. When this bit is cleared to 0, the I<sup>2</sup>C controller is configured in normal operation mode.

In system test mode, the I<sup>2</sup>C\_SYSTEST[13-12] TMODE bit field selects the type of test. [Table 12-48](#) lists the tests available for the multicontroller HS I<sup>2</sup>C.

**Table 12-48. I<sup>2</sup>C List of Tests**

| I <sup>2</sup> C_SYSTEST[13-12] TMODE | Test                          | Description                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00                                    | Functional mode               | Normal operation mode                                                                                                                                                                                                                                                                                                                                                  |
| 01                                    | Reserved (not used)           |                                                                                                                                                                                                                                                                                                                                                                        |
| 10                                    | Test of SCL serial clock line | The SCL line is driven with a permanent clock as if controlled with the parameters set in the I <sup>2</sup> C_PSC, I <sup>2</sup> C_SCLL, and I <sup>2</sup> C_SCLH registers.                                                                                                                                                                                        |
| 11                                    | Loop-back mode + SCL/SDA I/O  | In control transmit mode only, data transmitted out of the I <sup>2</sup> C_DATA register (write action) is received in the same I <sup>2</sup> C_DATA register through an internal path through the FIFO buffers. The interrupt request is normally generated if it is enabled. Moreover, the SCL and SDA are controlled with the I <sup>2</sup> C_SYSTEST[3-0] bits. |

#### Note

When the I<sup>2</sup>C\_SYSTEST[13-12] TMODE bit field is set to 11, the I<sup>2</sup>C controller must be configured in I<sup>2</sup>C F/S (I<sup>2</sup>C\_CON[13-12] OPMODE set to 00) or I<sup>2</sup>C HS mode (I<sup>2</sup>C\_CON[13-12] OPMODE set to 01).

#### Note

In normal operation mode (the I<sup>2</sup>C\_SYSTEST[15] ST\_EN bit cleared to 0), the I<sup>2</sup>C\_SYSTEST[3-0] bits that control the SCL, SDA lines in system test mode are read-only bits.

In system test mode (the I<sup>2</sup>C\_SYSTEST[15] ST\_EN bit set to 1), the I<sup>2</sup>C\_IRQSTATUS\_RAW[4] XRDY, I<sup>2</sup>C\_IRQSTATUS\_RAW[3] RRDY, I<sup>2</sup>C\_IRQSTATUS\_RAW[10] XUDF, I<sup>2</sup>C\_IRQSTATUS\_RAW[11] ROVR, I<sup>2</sup>C\_IRQSTATUS\_RAW[2] ARDY and I<sup>2</sup>C\_IRQSTATUS\_RAW[1] NACK status bits can be set to 1 when the I<sup>2</sup>C\_SYSTEST[11] SSB bit is set to 1. Clearing the I<sup>2</sup>C\_SYSTEST[11] SSB bit to 0 does not clear the I<sup>2</sup>C\_IRQSTATUS\_RAW bits to 0. The I<sup>2</sup>C\_IRQSTATUS\_RAW bit field can be cleared to 0 only by writing 1 in the corresponding bits.

#### 12.2.2.4 I<sup>2</sup>C Programming Guide

##### 12.2.2.4.1 I<sup>2</sup>C Low-Level Programming Models

###### 12.2.2.4.1.1 I<sup>2</sup>C Programming Model

This section describes the programming model of the multicontroller I<sup>2</sup>C configured in I<sup>2</sup>C mode.

###### 12.2.2.4.1.1.1 Main Program

###### 12.2.2.4.1.1.1.1 Configure the Module Before Enabling the I<sup>2</sup>C Controller

Before enabling the I<sup>2</sup>C controller, perform the following steps:

1. Enable the functional and interface clocks (see *MCU\_I2C[0-1] Clocks*, and *I2C[0-3] Clocks*).
2. Program the prescaler to obtain an approximately 12-MHz internal sampling clock by programming the corresponding value in the I2C\_PSC[7-0] PSC bit field. This value depends on the frequency of the functional clock (SYS\_CLK).
3. Program the I2C\_SCLL[7-0] SCLL and I2C\_SCLH[7-0] SCLH bit fields to obtain a bit rate of 100 kbps or 400 kbps. These values depend on the internal sampling clock frequency (see [Table 12-43](#)).
4. (Optional) Program the I2C\_SCLL[15-8] HSSCLL and I2C\_SCLH[15-8] HSSCLH bit fields to obtain a bit rate of 400 kbps or 3.4 Mbps (for the second phase of HS mode). These values depend on the internal sampling clock frequency (see [Table 12-43](#)).
5. Configure the Own Address of the I<sup>2</sup>C controller by storing it in the I2C\_OA register. Up to four Own Addresses can be programmed in the I2C\_OA and I2C\_OAx registers (where x = 1, 2, 3) for each I<sup>2</sup>C controller.

---

###### Note

For a 10-bit address, set the corresponding expand Own Address bit in the I2C\_CON register.

6. Set the TX threshold (in transmitter mode) and the RX threshold (in receiver mode) by setting the I2C\_BUF[5-0] TXTRSH bit field to (TX threshold – 1) and the I2C\_BUF[13-8] RXTRSH bit field to (RX threshold – 1), where the TX and RX thresholds are greater than or equal to 1.
7. Take the I<sup>2</sup>C controller out of reset by setting the I2C\_CON[15] I2C\_EN bit to 1.

###### 12.2.2.4.1.1.1.2 Initialize the I<sup>2</sup>C Controller

To initialize the I<sup>2</sup>C controller, perform the following steps:

1. Configure the I2C\_CON register:
  - For controller or target mode, set the I2C\_CON[10] MST bit (0: target; 1: controller).
  - For transmitter or receiver mode, set the I2C\_CON[9] TRX bit (0: receiver; 1: transmitter).
2. If using an interrupt to transmit and receive data, set the corresponding bit in the I2C\_IRQENABLE\_SET register to 1 (the I2C\_IRQENABLE\_SET[4] XRDY\_IE bit for the transmit interrupt, the I2C\_IRQENABLE\_SET[3] RRDY bit for the receive interrupt).

###### 12.2.2.4.1.1.1.3 Configure Target Address and the Data Control Register

In controller mode, configure the target address register by programming the I2C\_SA[9-0] SA bit field and the number of data bytes (I<sup>2</sup>C data payload) associated with the transfer by programming the I2C\_CNT[15-0] DCOUNT bit field.

---

###### Note

For a 10-bit address, set the I2C\_CON[8] XSA bit to 1.

###### 12.2.2.4.1.1.1.4 Initiate a Transfer

Poll the I2C\_IRQSTATUS\_RAW[12] BB bit. If it is cleared to 0 (bus not busy), configure the I2C\_CON[0] STT and I2C\_CON[1] STP bits. To initiate a transfer, the I2C\_CON[0] STT bit must be set to 1, and it is not mandatory to set the I2C\_CON[1] STP bit to 1.

#### 12.2.2.4.1.1.1.5 Receive Data

Poll the I2C\_IRQSTATUS\_RAW[3] RRDY bit, or use the RRDY interrupt (the I2C\_IRQENABLE\_SET[3] RRDY\_IE bit must be set to 1) to read the receive data in the I2C\_DATA register.

If the transfer length does not equal the RX FIFO threshold (the I2C\_BUF[13-8] RTRSH bit field + 1), use the draining feature (enable the RDR interrupt by setting the I2C\_IRQENABLE\_SET[13] RDR\_IE bit to 1).

---

#### Note

In receive mode only, the I2C\_IRQSTATUS\_RAW[11] ROVR (receive overrun) bit indicates whether the receiver has experienced overrun. An overrun condition occurs when the shift register and the RX FIFO are full. An overrun condition does not result in data loss; the I2C controller simply holds SCL to low to prevent other bytes from being received.

The I2C\_IRQSTATUS\_RAW[7] AERR bit is set to 1 when a read access is performed in the I2C\_DATA register while the RX FIFO is empty. The corresponding interrupt can be enabled by setting the I2C\_IRQENABLE\_SET[7] AERR\_IE bit to 1.

---

#### 12.2.2.4.1.1.1.6 Transmit Data

Poll the I2C\_IRQSTATUS\_RAW[4] XRDY bit, or use the XRDY interrupt (the I2C\_IRQENABLE\_SET[4] XRDY\_IE bit must be set to 1) to write data to the I2C\_DATA register.

If the transfer length does not equal the TX FIFO threshold (the I2C\_BUF[5-0] TXTRSH bit field + 1), use the draining feature (enable the XDR interrupt by setting the I2C\_IRQENABLE\_SET[14] XDR\_IE bit to 1).

---

#### Note

In transmit mode only, the I2C\_IRQSTATUS\_RAW[10] XUDF bit indicates whether the transmitter has experienced underflow.

In controller transmit mode, underflow occurs when the shift register and the TX FIFO are empty and there are still some bytes to transmit (the value of the I2C\_CNT[15-0] DCOUNT bit field is not 0).

In target transmit mode, underflow occurs when the shift register and the TX FIFO are empty and the external I<sup>2</sup>C controller device still requests data bytes to be read.

The I2C\_IRQSTATUS\_RAW[7] AERR bit is set to 1 when a write access is performed in the I2C\_DATA register while the TX FIFO is full. The corresponding interrupt can be enabled by setting the I2C\_IRQENABLE\_SET[7] AERR\_IE bit to 1.

---

#### 12.2.2.4.1.1.2 Interrupt Subroutine Sequence

1. Test for arbitration lost (the I2C\_IRQSTATUS\_RAW[0] AL bit) and resolve accordingly.
2. Test for no acknowledgment (the I2C\_IRQSTATUS\_RAW[1] NACK bit) and resolve accordingly.
3. Test for register access ready (the I2C\_IRQSTATUS\_RAW[2] ARDY bit) and resolve accordingly.
4. Test for receive data ready (the I2C\_IRQSTATUS\_RAW[3] RRDY bit) and resolve accordingly.
5. Test for transmit data ready (the I2C\_IRQSTATUS\_RAW[4] XRDY bit) and resolve accordingly.
6. Test for general call (the I2C\_IRQSTATUS\_RAW[5] GC bit) and resolve accordingly.
7. Test for start (S) condition (the I2C\_IRQSTATUS\_RAW[6] STC bit) and resolve accordingly. For this test, the functional clock must be inactive.
8. Test for access error (the I2C\_IRQSTATUS\_RAW[7] AERR bit) and resolve accordingly.
9. Test for bus free (the I2C\_IRQSTATUS\_RAW[8] BF bit) and resolve accordingly.

#### 12.2.2.4.1.1.3 Programming Flow-Diagrams

Figure 12-52 through Figure 12-58 are procedure flow charts for programming the F/S and HS I<sup>2</sup>C modes.



i2c-018

**Figure 12-52. I2C Setup Procedure**



- The NACK, AL, ARDY, XDR, and XRDY bits are cleared by writing 1 to each corresponding bit in the I2C\_IRQSTATUS register.
- Reprogram the registers means: I2C\_CON[11] STB and/or I2C\_CON[10] MST bit and/or I2C\_SA[9-0] SA register and/or I2C\_CNT[15-0] DCOUNT register and/or I2C\_CON[0] STT bit and/or I2C\_CON[1] STP bit.

**Figure 12-53. I2C Controller Transmitter Mode, Polling Method, in F/S and HS Modes**

#### Note

The FIFO clearing can be made when the module is configured as transmitter, the receiver send a NACK in the middle of the transfer, and there is still data in the FIFO.

**Note**

In HS mode, the Sr condition and clock frequency switching are automatically generated by the multicontroller I2C.



i2c-020

- The NACK, AL, ARDY, RDR, and RRDY bits are cleared by writing 1 to each corresponding bit in the I2C\_IRQSTATUS register.
- Reprogram registers means: I2C\_CON[11] STB and/or I2C\_CON[10] MST bit and/or I2C\_SA[9-0] SA register and/or I2C\_CNT[15-0] DCOUNT register and/or I2C\_CON[0] STT bit and/or I2C\_CON[1] STP bit.

**Figure 12-54. I2C Controller Receiver Mode, Polling Method, in F/S and HS Modes**



- The NACK, AL, ARDY, XDR, and XRDY bits are cleared by writing 1 to each corresponding bit in the I2C\_IRQSTATUS register.
- Reprogram registers means: I2C\_CON[11] STB and/or I2C\_CON[10] MST bit and/or I2C\_SA[9-0] SA register and/or I2C\_CNT[15-0] DCOUNT register and/or I2C\_CON[0] STT bit and/or I2C\_CON[1] STP bit.

**Figure 12-55. I2C Controller Transmitter Mode, Interrupt Method, in F/S and HS Modes**

---

**Note**

The FIFO clearing can be made when the module is configured as transmitter, the receiver send a NACK in the middle of the transfer, and there is still data in the FIFO.

---

**Note**

In HS mode, the Sr condition and clock frequency switching are automatically generated by the multicontroller I2C.

---



- The NACK, AL, ARDY, RDR, and RRDY bits are cleared by writing 1 to each corresponding bit in the I2C\_IRQSTATUS register.
- Reprogram registers means: I2C\_CON[11] STB and/or I2C\_CON[10] MST bit and/or I2C\_SA[9-0] SA register and/or I2C\_CNT[15-0] DCOUNT register and/or I2C\_CON[0] STT bit and/or I2C\_CON[1] STP bit.

**Figure 12-56. I2C Controller Receiver Mode, Interrupt Method, in F/S and HS Modes**



- A. The XRDY, RDR, RRDY, and ARDY bits are cleared by writing 1 to each corresponding bit in the I2C\_IRQSTATUS register.
- B. In target transmitter mode, the amount of data requested by the external controller I<sup>2</sup>C device is unknown; thus, the I2C\_BUFBUF[5-0] XTRSH bit field must be configured to 0x0 (TX threshold = 1).

**Figure 12-57. I2C Target Transmitter/Receiver Mode, Polling**



- A. The XRDY, RDR, RRDY, and ARDY bits are cleared by writing 1 to each corresponding bit in the I2C\_IRQSTATUS register.

- B. In target transmitter mode, the amount of data requested by the external controller I<sup>2</sup>C device is unknown; thus, the I<sup>2</sup>C\_BUF[5-0] XTRSH bit field must be configured to 0x0 (TX threshold = 1).

**Figure 12-58. I<sup>2</sup>C Target Transmitter/Receiver Mode, Interrupt**

### 12.2.3 Multichannel Serial Peripheral Interface (MCSPI)

This section describes the Multichannel Serial Peripheral Interface (MCSPI) modules for the device.

#### 12.2.3.1 MCSPI Overview

The MCSPI module is a multichannel transmit/receive, controller/peripheral synchronous serial bus.

Figure 12-59 shows the MCSPI overview.



**Figure 12-59. MCSPI Overview**

n represents a valid instance of MCSPI in a domain.

#### 12.2.3.1.1 MCSPI Features

The MCSPI modules include the following main features:

- Serial clock with programmable frequency, polarity, and phase for each channel
- Wide selection of MCSPI word lengths, ranging from 4 to 32 bits
- Up to four controller channels, or single channel in peripheral mode
- Controller multichannel mode:
  - Full duplex/half duplex
  - Transmit-only/receive-only/transmit-and-receive modes
  - Flexible input/output (I/O) port controls per channel
  - Programmable clock granularity
  - MCSPI configuration per channel. This means, clock definition, polarity enabling and word width
- Single interrupt line for multiple interrupt source events
- Enable the addition of a programmable start-bit for MCSPI transfer per channel (start-bit mode)
- Supports start-bit write command
- Supports start-bit pause and break sequence
- Programmable shift operations (1-32 bits)
- Programmable timing control between chip select and external clock generation
- Built-in FIFO available for a single channel.

#### 12.2.3.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

### 12.2.3.2 MCSPI Environment

This section describes the MCSPI external connections (environment).

#### 12.2.3.2.1 Basic MCSPI Pins for Controller Mode

Figure 12-60 shows all of the MCSPI interface signals in controller mode.



#### Note

$i$  represents a MCSPI instance. See the device datasheet for available domains and MCSPI instances.

**Figure 12-60. MCSPI Interface Signals in Controller Mode**

Table 12-49 describes the MCSPI I/O signals in controller mode.

Table 12-49. MCSPI I/O Signals (Controller Mode)

| Module Pin                     | Device Level Signal         | I/O <sup>(1)</sup> | Description                                    | Module Pin<br>Reset Value <sup>(2)</sup> |
|--------------------------------|-----------------------------|--------------------|------------------------------------------------|------------------------------------------|
| <b>MCU_MCSPI<sup>(5)</sup></b> |                             |                    |                                                |                                          |
| SPICLK                         | MCU_SPI <sup>(5)</sup> _CLK | O                  | MCSPI Serial clock output for controller mode. | HiZ                                      |
| SPIDAT[0]                      | MCU_SPI <sup>(5)</sup> _D0  | O <sup>(3)</sup>   | MCSPI Data I/O for controller mode.            | HiZ                                      |
| SPIDAT[1]                      | MCU_SPI <sup>(5)</sup> _D1  | I <sup>(4)</sup>   | MCSPI Data I/O for controller mode.            | HiZ                                      |
| SPIEN[i]                       | MCU_SPI <sup>(5)</sup> _CSI | O                  | MCSPI Chip-select i output for controller mode | HiZ                                      |
| <b>MCSPI<sup>(5)</sup></b>     |                             |                    |                                                |                                          |
| SPICLK                         | SPI <sup>(5)</sup> _CLK     | O                  | MCSPI Serial clock output for controller mode. | HiZ                                      |
| SPIDAT[0]                      | SPI <sup>(5)</sup> _D0      | O <sup>(3)</sup>   | MCSPI Data I/O for controller mode.            | HiZ                                      |
| SPIDAT[1]                      | SPI <sup>(5)</sup> _D1      | I <sup>(4)</sup>   | MCSPI Data I/O for controller mode.            | HiZ                                      |
| SPIEN[i]                       | SPI <sup>(5)</sup> _CSI     | O                  | MCSPI Chip-select i output for controller mode | HiZ                                      |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) Example configuration only. Can be configured either as input or as output depending on MCSPI\_CHCONF\_0/1/2/3[18] IS and MCSPI\_CHCONF\_0/1/2/3[16] DPE0.

(4) Example configuration only. Can be configured either as input or as output depending on MCSPI\_CHCONF\_0/1/2/3[18] IS and MCSPI\_CHCONF\_0/1/2/3[17] DPE1.

(5) i represents a MCSPI instance. See the device datasheet for available domains and MCSPI instances.

#### Note

For SPI<sup>(5)</sup>\_CLK and MCU\_SPI<sup>(5)</sup>\_CLK signals to work properly, the RXACTIVE bit of the appropriate CTRLMMR\_MCU\_PADCONFIGx/ CTRLMMR\_PADCONFIGy registers should be set to 0x1 because of retiming purposes.

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

#### 12.2.3.2.2 Basic MCSPI Pins for Peripheral Mode

Figure 12-61 shows all of the MCSPI interface signals in peripheral mode.



- A. Direction depends on MCSPI\_CHCONF\_0/1/2/3[16] DPE0, MCSPI\_CHCONF\_0/1/2/3[17] DPE1 and MCSPI\_CHCONF\_0/1/2/3[18] IS bits
- B.  $j = 0$  to 3

**Note**

*i* represents a MCSPI instance. See the device datasheet for available domains and MCSPI instances.

**Figure 12-61. MCSPI Interface Signals in Peripheral Mode**

Table 12-50 describes the MCSPI I/O signals in peripheral mode.

**Table 12-50. MCSPI I/O Signals (Peripheral Mode)**

| Module Pin            | Device Level Signal | I/O <sup>(1)</sup> | Description                                    | Module Pin<br>Reset Value <sup>(1)</sup> |
|-----------------------|---------------------|--------------------|------------------------------------------------|------------------------------------------|
| <b>MCU_MCSPI[1-0]</b> |                     |                    |                                                |                                          |
| SPICLK                | MCU_SPI[1-0]_CLK    | I                  | MCSPI serial clock input for peripheral mode.  | HiZ                                      |
| SPIDAT[0]             | MCU_SPI[1-0]_D0     | I <sup>(2)</sup>   | MCSPI Data I/O for peripheral mode.            | HiZ                                      |
| SPIDAT[1]             | MCU_SPI[1-0]_D1     | O <sup>(3)</sup>   | MCSPI Data I/O for peripheral mode.            | HiZ                                      |
| SPIEN[i]              | MCU_SPI[1-0]_CSI    | I <sup>(4)</sup>   | MCSPI chip-select i input for peripheral mode. | HiZ                                      |
| <b>MCSPI[4-0]</b>     |                     |                    |                                                |                                          |
| SPICLK                | SPI[4-0]_CLK        | I                  | MCSPI serial clock input for peripheral mode.  | HiZ                                      |
| SPIDAT[0]             | SPI[4-0]_D0         | I <sup>(2)</sup>   | MCSPI Data I/O for peripheral mode.            | HiZ                                      |

**Table 12-50. MCSPI I/O Signals (Peripheral Mode) (continued)**

| Module Pin | Device Level Signal | I/O <sup>(1)</sup> | Description                                    | Module Pin<br>Reset Value <sup>(1)</sup> |
|------------|---------------------|--------------------|------------------------------------------------|------------------------------------------|
| SPIDAT[1]  | SPI[4-0]_D1         | O <sup>(3)</sup>   | MCSPI Data I/O for peripheral mode.            | HiZ                                      |
| SPIEN[i]   | SPI[4-0]_CSI        | I <sup>(4)</sup>   | MCSPI chip-select i input for peripheral mode. | HiZ                                      |

(1) HiZ = High Impedance

(2) Example configuration only. Can be configured either as input or as output depending on MCSPI\_CHCONF\_0/1/2/3[18] IS and MCSPI\_CHCONF\_0/1/2/3[16] DPE0.

(3) Example configuration only. Can be configured either as input or as output depending on MCSPI\_CHCONF\_0/1/2/3[18] IS and MCSPI\_CHCONF\_0/1/2/3[17] DPE1.

(4) The chip-select input in peripheral mode can be selected through the MCSPI\_CHCONF\_0/1/2/3[22-21] SPIENSLV bit field.

#### Note

For SPI[4-0]\_CLK and MCU\_SPI[1-0]\_CLK signals to work properly, the RXACTIVE bit of the appropriate CTRLMMR\_MCU\_PADCONFIGx/ CTRLMMR\_PADCONFIGy registers should be set to 0x1 because of retiming purposes.

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

#### 12.2.3.2.3 MCSPI Protocol and Data Format

The synchronous MCSPI protocol allows a controller device to initiate serial data transfers to a peripheral device. A peripheral select line (SPIEN[i]) allows selection of an individual peripheral MCSPI device. Peripheral devices that are not selected do not interfere with MCSPI bus activities.

MCSPI offers the flexibility to modify the following parameters to adapt to the device features:

- Word length

MCSPI supports any MCSPI word ranging from 4 bits to 32 bits long (the MCSPI\_CHCONF\_0/1/2/3[11-7] WL bit field).

MCSPI word length can be changed between transmissions to allow the controller device to communicate with peripheral devices that have different requirements.

- MCSPI enable (SPIEN[i], for channel i)

The polarity of the MCSPI enable signals is programmable (the MCSPI\_CHCONF\_0/1/2/3[6] EPOL bit). SPIEN[i] signals can be active high or low.

Assertion of the SPIEN[i] signals is programmable and can be done manually or automatically. The manual assertion mode is available in single controller mode only. SPIEN[i] can be kept active between words with the MCSPI\_CHCONF\_0/1/2/3[20] FORCE bit.

Two consecutive words for two different peripheral devices can go along with active SPIEN[i] signals with different polarity.

- Programmable start-bit

In start-bit mode a start-bit is added before the MCSPI word length to indicate how the next MCSPI word must be handled. The start-bit is enabled by setting the MCSPI\_CHCONF\_0/1/2/3[23] SBE bit to 1. The MCSPI\_CHCONF\_0/1/2/3[24] SBPOL bit defines the polarity of the start-bit.

- Programmable MCSPI clock

- Bit rate

In controller mode, the baud rate of the MCSPI serial clock is programmable using the 50-MHz reference clock (from the device clock management module). [Table 12-51](#) lists the SPICLK bit rates obtained for data transfer when programming the clock divider (the MCSPI\_CHCONF\_0/1/2/3[5-2] CLKD bit field).

**Table 12-51. MCSPI Controller Clock Rates**

| Divider | Clock Rate            |
|---------|-----------------------|
| 1       | 50 MHz <sup>(1)</sup> |
| 2       | 25 MHz <sup>(1)</sup> |
| 4       | 12.5 MHz              |
| 8       | 6.25 MHz              |
| 16      | 3.125 MHz             |
| 32      | 1.5625 MHz            |
| 64      | 781.25 kHz            |
| 128     | 390.625 kHz           |
| 256     | ~195 kHz              |
| 512     | ~97.7 kHz             |
| 1024    | ~48.8 kHz             |
| 2048    | ~24.4 kHz             |

**Table 12-51. MCSPI Controller Clock Rates  
(continued)**

| Divider | Clock Rate |
|---------|------------|
| 4096    | ~12.2 kHz  |

(1) These frequencies are not necessarily supported by all MCSPI modules. For more information, see the *Timing Requirements and Switching Characteristics* chapter in the device-specific Datasheet.

- Polarity and phase

The polarity (the MCSPI\_CHCONF\_0/1/2/3[1] POL bit) and the phase (the MCSPI\_CHCONF\_0/1/2/3[0] PHA bit) of the MCSPI serial clock (SPICLK) are configurable to offer four combinations. Software selects the right combination, depending on the device. See [Table 12-52](#) and [Figure 12-62](#).

**Table 12-52. Phase and Polarity Combinations**

| Polarity (POL) | Phase (PHA) | MCSPI Mode | Description                                                      |
|----------------|-------------|------------|------------------------------------------------------------------|
| 0              | 0           | Mode 0     | SPICLK is inactive low and sampling occurs at the rising edge.   |
| 0              | 1           | Mode 1     | SPICLK is inactive low and sampling occurs at the falling edge.  |
| 1              | 0           | Mode 2     | SPICLK is inactive high and sampling occurs at the falling edge. |
| 1              | 1           | Mode 3     | SPICLK is inactive high and sampling occurs at the rising edge.  |


**Figure 12-62. Phase and Polarity Combinations**

#### 12.2.3.2.3.1 Transfer Format

In controller and peripheral modes, the MCSPI drives the data lines when SPIEN[i] is asserted.

Each word is transmitted starting with the most-significant bit (MSB).

This section explains the two cases of data transmission determined by the clock phase (PHA) and the type of data transmission using a start-bit (SBE) called the start-bit mode:

- Transmission in mode 0 and mode 2 (PHA = 0)

When PHA = 0, the first bit of the MCSPI word to transmit (on the controller or the peripheral data output pin) is valid one-half cycle of SPICLK after the assertion of SPIEN[i].

Therefore, the first edge of the SPICLK line is used by the controller to sample the first data bit sent by the peripheral. On the same edge, the first data bit sent by the controller is sampled by the peripheral.

On the next SPICLK edge, the received data bit is shifted into the receive shift register and a new data bit is transmitted on the serial data line.

This process continues for a number of pulses on the SPICLK line defined by the MCSPI word length programmed in the controller device, with data being latched on odd-numbered edges and shifted on even-numbered edges, see [Figure 12-63](#).



**Figure 12-63. Full-Duplex Transfer Format With  $\text{PHA} = 0$**

- Transmission in mode 1 and mode 3 ( $\text{PHA} = 1$ )

When  $\text{PHA} = 1$ , the first bit of the MCSPI word to transmit (on the controller or the peripheral data output pin) is valid on the following SPICLK edge (one-half cycle later). This is the sampling edge for the controller and peripheral. A synchronization delay is added between the activation of  $\text{SPIEN}[i]$  and the first SPICLK edge.

The received data bit is shifted into the shift register on the third SPICLK edge.

This process continues for a number of pulses on the SPICLK line defined by the MCSPI word length programmed in the controller device, with data being latched on even-numbered edges and shifted on odd-numbered edges.

#### Note

The minimum synchronization delay is one cycle of SPICLK, if the frequency of SPICLK equals the frequency of MCSPI\_FCLK (MCSPI functional clock) in controller mode. The minimum synchronization delay is one-half cycle of SPICLK, if the frequency of SPICLK is lower than the frequency of MCSPI\_FCLK in the controller and peripheral modes.

- Transmission with a start-bit ( $\text{SBE} = 1$ )

When the `MCSPI_CHCONF_0/1/2/3[23]`  $\text{SBE}$  bit is set to 1, a start-bit is added before the MSB to indicate whether the next MCSPI word must be handled as a command or as data.

[Figure 12-64](#) shows an example of a data transfer with an extra start-bit.



spi-006

**Figure 12-64. Extended MCSPI Transfer With a Start-Bit (SBE = 1)**

#### 12.2.3.2.4 MCSPI in Controller Mode

Figure 12-65 shows a case in controller mode (full-duplex) where the MCSPI module is connected with two peripheral devices.



spi-007

- A. Direction depends on MCSPI\_CHCONF\_0/1/2/3[16] DPE0, MCSPI\_CHCONF\_0/1/2/3[17] DPE1 and MCSPI\_CHCONF\_0/1/2/3[18] IS bits

**Figure 12-65. MCSPI Controller Mode (Full Duplex)**

Figure 12-66 shows the controller single mode, which can also be configured in receive-only mode.



spi-008

k = 0 or 1 depending on MCSPI\_CHCONF\_0/1/2/3[16] DPE0, MCSPI\_CHCONF\_0/1/2/3[17] DPE1 and MCSPI\_CHCONF\_0/1/2/3[18] IS bits

**Figure 12-66. MCSPI Controller Single Mode (Receive Only)**

#### 12.2.3.2.5 MCSPI in Peripheral Mode

Figure 12-67 shows a case in peripheral mode (full-duplex).

##### Note

Only channel 0 can be configured as peripheral, but the chip-enable signal can be connected to any SPIEN[i] pin and then rerouted internally to channel 0 (the MCSPI\_CHCONF\_0[22-21] SPIENSLV bit field). For more information, see [Section 12.2.3.4.4, MCSPI Peripheral Mode](#).



spi-009

- A. Direction depends on MCSPI\_CHCONF\_0/1/2/3[16] DPE0, MCSPI\_CHCONF\_0/1/2/3[17] DPE1 and MCSPI\_CHCONF\_0/1/2/3[18] IS bits

**Figure 12-67. MCSPI Peripheral Mode (Full Duplex)**

Figure 12-68 shows the peripheral single mode, which can also be configured in transmit-only mode.



**Figure 12-68. MCSPI Peripheral Single Mode (Transmit Only)**

#### 12.2.3.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.2.3.4 MCSPI Functional Description

##### 12.2.3.4.1 MCSPI Block Diagram

Figure 12-69 shows the MCSPI module.



**Figure 12-69. MCSPI Block Diagram**

##### 12.2.3.4.2 MCSPI Reset

The MCSPI module can be reset either by hardware or by software reset. All configuration registers and all state machines are reset by the hardware reset signal (MCSPI\_RST). MCSPI can be reset by software through the

MCSPI\_SYS CONFIG[1] SOFTRESET bit. This bit has the same impact on the module as the hardware reset signal. The only exception is that the MCSPI\_SYS CONFIG register is not affected by that software reset.

#### 12.2.3.4.3 MCSPI Controller Mode

##### 12.2.3.4.3.1 Controller Mode Features

The MCSPI controller mode supports multichannel communication with up to four independent MCSPI communication channel contexts. The MCSPI initiates a data transfer on the data lines (SPIDAT[0] and SPIDAT[1]) and generates clock (SPICLK) and control (SPIEN[i]) signals.

Connected to multiple external devices, the MCSPI exchanges data with one MCSPI device at a time through two main modes (available in peripheral mode):

- Two-data-pins interface mode (transmit-and-receive mode for full-duplex transmission)
- Single-data-pin interface mode (recommended for half-duplex transmission)

---

##### Note

There is a fixed chip select line allocation in multichannel controller mode. Channel i is mapped to SPIEN[i].

---

Two DMA request events (read and write) allow synchronized accesses of the DMA controller with the activity of MCSPI.

Three interrupt events can be used for data transmission and reception in controller mode (for more information about interrupts, see [Section 12.2.3.4.7.1, Interrupt Events in Controller Mode](#)).

##### 12.2.3.4.3.2 Controller Transmit-and-Receive Mode (Full Duplex)

In full-duplex transmission, data is transmitted (shifted out serially on SPIDAT[0]) and received (shifted in serially on SPIDAT[1]) simultaneously on separate data lines.

The controller transmit-and-receive mode is programmable per channel (the MCSPI\_CHCONF\_0/1/2/3[13-12] TRM bit field).

Channel access to the shift registers for transmission/reception is based on the MCSPI\_TX\_0/1/2/3 transmitter register state, the MCSPI\_RX\_0/1/2/3 receiver register state, and round-robin arbitration.

Channels that meet the following rules are included in the round-robin list of active channels scheduled for transmission and/or reception. The arbiter skips channels that do not meet the rules and searches in the rotation for the next enabled channel.

- Rule 1: Only enabled channels (the MCSPI\_CHCTRL\_0/1/2/3[0] EN bit) can be scheduled for transmission and/or reception.
- Rule 2: If its MCSPI\_TX\_0/1/2/3 transmitter register is not empty (the MCSPI\_CHSTAT\_0/1/2/3[1] TXS bit), an enabled channel can be scheduled when the shift register is assigned. If the MCSPI\_TX\_0/1/2/3 register is empty when the shift register is assigned, the TXx\_UNDERFLOW event is activated, and the next enabled channel with new data to transmit is scheduled (see also transmit-only mode).
- Rule 3: An enabled channel can be scheduled if its receive register is not full (the MCSPI\_CHSTAT\_0/1/2/3[0] RXS bit) when the shift register is assigned (see also receive-only mode). Therefore, the MCSPI\_RX\_0/1/2/3 register cannot be overwritten. The MCSPI\_IRQSTATUS[3] RX0\_OVERFLOW bit is never set to this mode.

When MCSPI word transfer completes (the MCSPI\_CHSTAT\_0/1/2/3[2] EOT bit is set), the updated MCSPI\_TX\_0/1/2/3 register of the next scheduled channel is loaded into the shift register. The serialization (transmit-and-receive) starts depending on the channel communication configuration. When serialization completes, the received data transfers to the channel receive register.

The serial clock (SPICLK) synchronizes shifting and sampling of the information on the two serial data lines (SPIDAT[0] and SPIDAT[1]). Each time a bit transfers out from the controller, 1 bit transfers in from the peripheral.

Figure 12-70 shows an example of a full-duplex system with a controller device on the left and a peripheral device on the right. After eight cycles of the serial clock SPICLK, WordA transfers from the controller to the peripheral. At the same time, WordB transfers from the peripheral to the controller.



spi-013

**Figure 12-70. MCSPI Full-Duplex Transmission (Example)**

#### 12.2.3.4.3.3 Controller Transmit-Only Mode (Half Duplex)

The controller transmit-only mode prevents the processor from reading the MCSPI\_RX\_0/1/2/3 register (minimizing data movement) when only transmission is meaningful.

The controller transmit-only mode is programmable per channel (the MCSPI\_CHCONF\_0/1/2/3[13-12] TRM bit field). Transmission starts only after data is loaded into the MCSPI\_TX\_0/1/2/3 register.

Rule 1 and Rule 2, defined in [Section 12.2.3.4.3.2](#), apply in this mode.

Rule 3, defined in [Section 12.2.3.4.3.2](#), does not apply.

In controller transmit-only mode, the MCSPI\_RX\_0/1/2/3 register state FULL does not prevent transmission and the MCSPI\_RX\_0/1/2/3 register is always overwritten with the new MCSPI word. This event is not significant when only transmission is meaningful. Thus, the RX0\_OVERFLOW bit in the MCSPI\_IRQSTATUS register is never set in this mode.

The hardware automatically disables the RX\_FULL interrupt and the DMA read requests.

The transfer status is given by the MCSPI\_CHSTAT\_0/1/2/3[2] EOT bit.

#### 12.2.3.4.3.4 Controller Receive-Only Mode (Half Duplex)

The controller receive mode prevents the processor from refilling the MCSPI\_TX\_0/1/2/3 register (minimizing data movement) when only reception is meaningful.

The controller receive mode is programmable per channel (the MCSPI\_CHCONF\_0/1/2/3[13-12] TRM bit field).

The controller receive-only mode enables channel scheduling only on the empty state of the MCSPI\_RX\_0/1/2/3 register.

Rule 1 and Rule 3, defined in [Section 12.2.3.4.3.2](#), apply in this mode.

Rule 2, defined in [Section 12.2.3.4.3.2](#), does not apply.

In the controller receive-only mode, software must write dummy data to the MCSPI\_TX\_0/1/2/3 register. Only one dummy write is enough to receive any number of words from the peripheral. Software must ensure that the MCSPI\_TX\_0/1/2/3 register is always full (the TXx\_EMPTY bits of MCSPI\_IRQSTATUS) when receiving. The content of the MCSPI\_TX\_0/1/2/3 register is always loaded into the shift register when the shift register is assigned. After writing the dummy data to the MCSPI\_TX\_0/1/2/3 register, the TXx\_EMPTY and TXx\_UNDERFLOW bits in the MCSPI\_IRQSTATUS register are never set in receive-only mode.

The MCSPI\_CHSTAT\_0/1/2/3[2] EOT bit gives the status of serialization. The RXx\_FULL bits of the MCSPI\_IRQSTATUS register are set when received data is loaded from the shift register to the corresponding MCSPI\_RX\_0/1/2/3 register. The MCSPI\_IRQSTATUS[3] RX0\_OVERFLOW bit is never set in this mode.

#### 12.2.3.4.3.5 Single-Channel Controller Mode

When the MCSPI is configured as a controller device with a single enabled channel (MCSPI\_MODULCTRL[2] MS = 0 and MCSPI\_MODULCTRL[0] SINGLE = 1), the assertion of the SPIEN[i] signal is optional depending on device connected to the controller. In 3-pin mode (MCSPI\_MODULCTRL[1] PIN34 = 1) the controller starts transmitting data when a write to the MCSPI\_TX\_0/1/2/3 register or the FIFO is performed. In 4-pin mode (MCSPI\_MODULCTRL[1] PIN34 = 0) the assertion and de-assertion of SPIEN[i] is controlled by software using the MCSPI\_CHCONF\_0/1/2/3[20] FORCE bit.

##### 12.2.3.4.3.5.1 Programming Tips When Switching to Another Channel

When a single channel is enabled and data transfer is ongoing:

- Wait for the MCSPI word transfer to complete (wait until the MCSPI\_CHSTAT\_0/1/2/3[2] EOT bit is set to 1) before disabling the current channel and enabling a different channel.
- Disable the current channel, and then enable the other channel.

##### 12.2.3.4.3.5.2 Force SPIEN[i] Mode

Continuous transfers are allowed manually by keeping the SPIEN[i] signal active for successive MCSPI words transfer. Several sequences (configuration/enable/disable of the channel) can be run without deactivating the SPIEN[i] line. This mode is supported by all channels and any controller sequence can be used (transmit-receive, transmit-only, receive-only).

Keeping the SPIEN[i] active mode is supported when:

- A single channel is used (with the MCSPI\_MODULCTRL[0] SINGLE bit set to 1).
- Transfer parameters are loaded in the configuration register of the appropriate channel (MCSPI\_CHCONF\_0/1/2/3).

The state of the SPIEN[i] signal is programmable:

- Writing 1 to the MCSPI\_CHCONF\_0/1/2/3[20] FORCE bit drives the SPIEN[i] line high when the MCSPI\_CHCONF\_0/1/2/3[6] EPOL bit is set to 0. SPIEN[i] is driven low when the MCSPI\_CHCONF\_0/1/2/3[6] EPOL bit is set to 1.
- Writing 0 to the MCSPI\_CHCONF\_0/1/2/3[20] FORCE bit drives the SPIEN[i] line low when the MCSPI\_CHCONF\_0/1/2/3[6] EPOL bit is set to 0. SPIEN[i] is driven high when the MCSPI\_CHCONF\_0/1/2/3[6] EPOL bit is set to 1.
- A single channel is enabled (the MCSPI\_CHCTRL\_0/1/2/3[0] EN bit is set to 1). The first enabled channel activates the SPIEN[i] line.

When the channel is enabled, the SPIEN[i] signal activates with the programmed polarity. As in the multichannel controller mode, the transfer start depends on the status of the MCSPI\_TX\_0/1/2/3 register (the MCSPI\_CHSTAT\_0/1/2/3[1] TXS bit), the status of the MCSPI\_RX\_0/1/2/3 register (the MCSPI\_CHSTAT\_0/1/2/3[1] RXS bit), and the defined mode (the MCSPI\_CHCONF\_0/1/2/3[13-12] TRM bit field) of the channel enabled.

The MCSPI\_CHSTAT\_0/1/2/3[2] EOT bit gives the transfer status of each MCSPI word. The RXx\_FULL bit in the MCSPI\_IRQSTATUS register is set when received data is loaded from the shift register to the MCSPI\_RX\_0/1/2/3 register.

A change in the configuration parameters is propagated directly on the MCSPI interface. If the SPIEN[i] signal is activated, ensure that the configuration is changed only between MCSPI words to avoid corrupting the current transfer.

---

**Note**

To avoid data corruption, SPIEN[i] polarity and SPICLK phase and SPICLK polarity must not be modified when the SPIEN[i] signal is activated.

---

A delay between MCSPI words that requires the connected MCSPI peripheral device to switch from one configuration to another (for instance, from transmit-only to receive-only) must be handled by software.

At the end of the last MCSPI word, the channel must be deactivated (the MCSPI\_CHCTRL\_0/1/2/3[0] EN bit set to 0) and SPIEN[i] can be forced to its INACTIVE state using the MCSPI\_CHCONF\_0/1/2/3[20] FORCE bit.

[Figure 12-71](#) and [Figure 12-72](#) show successive transfers with SPIEN[i] maintained active low with a different configuration for each MCSPI word in single-data-pin and dual-data-pin interface modes, respectively.



**Figure 12-71. Continuous Transfers With SPIEN[i] Maintained Active (Single-Data-Pin Interface Mode)**



**Figure 12-72. Continuous Transfers With SPIEN[i] Maintained Active (Dual-Data-Pin Interface Mode)**

---

**Note**

The SPIEN[i] signal can be maintained active via software using the MCSPI\_CHCONF\_0/1/2/3[20] FORCE bit only when the MCSPI\_MODULCTRL[0] SINGLE bit is set to 0x1.

---

#### 12.2.3.4.3.5.3 Turbo Mode

Turbo mode improves the throughput of the MCSPI interface when a single channel is enabled by allowing transfers until the shift register and the MCSPI\_RX\_0/1/2/3 register are full. Turbo mode is time saving when a transfer exceeds two words. This mode is programmable per channel (through the MCSPI\_CHCONF\_0/1/2/3[9] TURBO bit).

When several channels are enabled, the TURBO bit has no effect and the channel access to the shift registers remains as previously described.

In turbo mode, Rule 1 and Rule 2 apply, but Rule 3 does not (see [Section 12.2.3.4.3.2, Controller Transmit-and-Receive Mode \(Full Duplex\)](#)). An enabled channel can be scheduled if its receive register is full (the MCSPI\_CHSTAT\_0/1/2/3[0] RXS bit) when the shift-register is assigned until the shift register is full.

The MCSPI\_RX\_0/1/2/3 register cannot be overwritten in turbo mode. Consequently, the MCSPI\_IRQSTATUS[3] RX0\_OVERFLOW bit is never set in this mode.

#### 12.2.3.4.3.6 Start-Bit Mode

In start-bit mode, an extended bit is added before the MCSPI word to indicate whether the next MCSPI word must be handled as a command or as data. This feature is available only in controller mode. Start-bit mode cannot be used at the same time as turbo mode and/or force SPIEN[i] mode. In this case, only one channel can be used; round-robin arbitration is not possible.

This mode is programmable per channel by setting the MCSPI\_CHCONF\_0/1/2/3[23] SBE bit to 1. The polarity of the extended bit is programmable per channel. When the MCSPI\_CHCONF\_0/1/2/3[24] SBPOL bit is set to 0, the MCSPI word must be handled as a command. When the MCSPI\_CHCONF\_0/1/2/3[24] SBPOL bit is set to 1, the MCSPI word must be handled as data. Moreover, start-bit polarity can be changed dynamically during start-bit transfer without disabling the channel for reconfiguration; in this case, users must configure the MCSPI\_CHCONF\_0/1/2/3[24] SBPOL bit before writing the MCSPI word to be transmitted to the TX register.

#### 12.2.3.4.3.7 Chip-Select Timing Control

The chip-select (CS) timing control is available only in controller mode with automatic CS generation (the MCSPI\_MODULCTRL[0] SINGLE bit set to 0) to add a programmable delay between CS assertion and first clock edge, or CS removal and last clock edge. This option is available only in 4-pin mode when MCSPI\_MODULCTRL[1] PIN34 set to 0.

This mode is programmable per channel through the MCSPI\_CHCONF\_0/1/2/3[26-25] TCS0 bit field.

[Figure 12-73](#) shows the CS SPIEN timing controls.



**Figure 12-73. CS SPIEN Timing Controls**

#### Note

Because of the design implementation for transfers using a clock divider ratio set to 1 (clock bypassed), a half cycle must be added to the value between CS assertion and the first clock edge with PHA = 1 or between CS removal and the last clock edge with PHA = 0.

#### 12.2.3.4.3.8 Programmable MCSPI Clock (SPICLK)

In controller mode, the baud rate of the MCSPI serial clock is programmable.

An internal reference clock, SPICLKREF, is used as input of a programmable divider (the MCSPI\_CHCONF\_0/1/2/3[5-2] CLKD bit field) to generate the bit rate of the serial output clock SPICLK. [Table 12-53](#) summarizes the supported divisor values.

**Table 12-53. MCSPI Controller Clock Rates**

| Divider                                 | Clock Rate            |
|-----------------------------------------|-----------------------|
| 1                                       | 50 MHz <sup>(1)</sup> |
| 2                                       | 25 MHz <sup>(1)</sup> |
| 4                                       | 12.5 MHz              |
| 8                                       | 6.25 MHz              |
| 16                                      | 3.125 MHz             |
| 32                                      | 1.5625 MHz            |
| 64                                      | 781.25 kHz            |
| 128                                     | ~390 kHz              |
| 256                                     | ~195 kHz              |
| 512                                     | ~97.7 kHz             |
| 1024                                    | ~48.8 kHz             |
| 2048                                    | ~24.4 kHz             |
| 4096                                    | ~12.2 kHz             |
| 8192 and higher: Division not supported | —                     |

- (1) These frequencies are not necessarily supported by all MCSPI modules. For more information, see the *Timing Requirements and Switching Characteristics* chapter in the device-specific Datasheet.

#### 12.2.3.4.3.8.1 Clock Ratio Granularity

By default, the clock division ratio is defined by the MCSPI\_CHCONF\_0/1/2/3[5-2] CLKD bit field with power-of-2 granularity leading to a clock division in the range 1 to 4096; in this case, the duty cycle is always 50 percent. With the MCSPI\_CHCONF\_0/1/2/3[29] CLKG bit, clock division granularity can be changed to one clock cycle; in that case the MCSPI\_CHCTRL\_0/1/2/3[15-8] EXTCLK bit field is concatenated with the MCSPI\_CHCONF\_0/1/2/3[5-2] CLKD bit field to give a 12-bit-wide division ratio in the range 1 to 4096.

When granularity is one clock cycle (the CLKG bit set to 1), for the odd value of the clock ratio, the clock high level lasts one clock cycle more than the low level, depending on the MCSPI\_CHCONF\_0/1/2/3[1] POL and MCSPI\_CHCONF\_0/1/2/3[0] PHA bits (see [Table 12-54](#)).

**Table 12-54. CLKSPIO High/Low Time Computation**

| Clock Ratio $F_{RATIO}$   | CLKSPIO High Time           | CLKSPIO Low Time            |
|---------------------------|-----------------------------|-----------------------------|
| 1                         | $T_{HIGH\_REF}$             | $T_{LOW\_REF}$              |
| Even $\geq 2$             | $T_{ref} * (F_{RATIO}/2)$   | $T_{ref} * (F_{RATIO}/2)$   |
| Odd $\geq (POL = PHA)$    | $T_{ref} * (F_{RATIO}-1)/2$ | $T_{ref} * (F_{RATIO}+1)/2$ |
| Odd $\geq (POL \neq PHA)$ | $T_{ref} * (F_{RATIO}+1)/2$ | $T_{ref} * (F_{RATIO}-1)/2$ |

---

**Note**

$F_{RATIO}$  = SPICLK frequency ( $F_{OUT}$ ) division ratio

$T_{HIGH}$  = SPICLK high time period

$T_{LOW}$  = SPICLK low time period

$T_{ref}$  = MCSPI\_FCLK period

$T_{HIGH\_REF}$  = MCSPI\_FCLK high time period

$T_{LOW\_REF}$  = MCSPI\_FCLK low time period

---

If the CLKG bit is set to 1;  $F_{RATIO}$  = EXTCLK concatenated with CLKD + 1.

For odd ratio values, the duty cycle is calculated as follows:

$$\text{Duty\_cycle} = (1 - 1/F_{\text{RATIO}})/2$$

Table 12-55 shows examples of clock granularity with a clock source frequency of 50 MHz.

**Table 12-55. Clock Granularity Examples**

| EXTCLK | CLKD | CLKG | F <sub>RATIO</sub> | PHA | POL | T <sub>HIGH</sub> (ns) | T <sub>LOW</sub> (ns) | T <sub>PERIOD</sub> (ns) | Duty Cycle | F <sub>OUT</sub> (MHz) |
|--------|------|------|--------------------|-----|-----|------------------------|-----------------------|--------------------------|------------|------------------------|
| X      | 0    | 0    | 1                  | X   | X   | 10.0                   | 10.0                  | 20.0                     | 50–50      | 50                     |
| X      | 1    | 0    | 2                  | X   | X   | 20.0                   | 20.0                  | 40.0                     | 50–50      | 25                     |
| X      | 2    | 0    | 4                  | X   | X   | 40.0                   | 40.0                  | 80.0                     | 50–50      | 12.5                   |
| X      | 3    | 0    | 8                  | X   | X   | 80.0                   | 80.0                  | 160.0                    | 50–50      | 6.2                    |
| 0      | 0    | 1    | 1                  | X   | X   | 10.0                   | 10.0                  | 20.0                     | 50–50      | 50                     |
| 0      | 1    | 1    | 2                  | X   | X   | 20.0                   | 20.0                  | 40.0                     | 50–50      | 25                     |
| 0      | 2    | 1    | 3                  | 1   | 0   | 40.0                   | 20.0                  | 60.0                     | 66–33      | 16.6                   |
| 0      | 2    | 1    | 3                  | 1   | 1   | 20.0                   | 40.0                  | 60.0                     | 33–66      | 16.6                   |
| 0      | 3    | 1    | 4                  | X   | X   | 40.0                   | 40.0                  | 80.0                     | 50–50      | 12.5                   |
| 5      | 0    | 1    | 81                 | 1   | 0   | 820.0                  | 800.0                 | 1620.0                   | 50.6–49.4  | 0.617                  |
| 5      | 7    | 1    | 88                 | X   | X   | 880.0                  | 880.0                 | 1760.0                   | 50–50      | 0.568                  |

#### 12.2.3.4.4 MCSPI Peripheral Mode

To select the MCSPI peripheral mode, set the MCSPI\_MODULCTRL[2] MS bit.

A MCSPI peripheral device can be connected to up to four external MCSPI controller devices but handles transactions with one MCSPI controller device at a time.

In peripheral mode, the MCSPI initiates data transfer on the data lines (SPIDAT[0] and SPIDAT[1]) when it is selected by an active control signal (SPIEN[i]) and receives an MCSPI clock (SPICLK) from the external MCSPI controller device. Only channel 0 can be configured as a peripheral but through the MCSPI\_CHCONF\_0[22-21] SPIENSLV bit field any of the SPIEN[i] signals can be used to select the MCSPI module. In peripheral mode and when the MCSPI\_MODULCTRL[1] PIN34 is set to 0x0 (default behaviour), the MCSPI uses the edge of SPIEN[i] to detect word length. For this reason, SPIEN[i] must become inactive between each word.

When the MCSPI\_MODULCTRL[1] PIN34 is set to 0x0, the MCSPI does not support SPIEN[i] active between MCSPI words. In this case, the MCSPI uses the edge to detect word length.

When the MCSPI\_MODULCTRL[1] PIN34 is set to 0x1, a multiword transfer can be performed without needing the external MCSPI controller to deactivate SPIEN[i] between each word as in this case the MCSPI module works in 3-pin peripheral mode and SPIEN[i] is not needed.

#### 12.2.3.4.4.1 Dedicated Resources

Only channel 0 can be enabled in peripheral mode.

Figure 12-74 shows an example of four peripherals wired on a single controller device.



spi-017

- A. Direction depends on MCSPI\_CHCONF\_0/1/2/3[16] DPE0, MCSPI\_CHCONF\_0/1/2/3[17] DPE1 and MCSPI\_CHCONF\_0/1/2/3[18] IS bits

**Figure 12-74. Example of MCSPI Peripheral With One Controller and Multiple Peripheral Devices on Channel 0**

Channel 0 in peripheral mode has the following resources:

- Its own channel enable, programmable with the MCSPI\_CHCTRL\_0[0] EN bit. This channel must be enabled before transmission and reception.
- For this mode, the peripheral-select signal can be detected on any of the SPIEN[i] ports. This is programmable with the MCSPI\_CHCONF\_0[22-21] SPIENSLV bit field.
- Its own transmitter register, MCSPI\_TX\_0, on top of the common transmit shift register. If the MCSPI\_TX\_0 register is empty, the MCSPI\_CHSTAT\_0[1] TXS bit is set. If MCSPI is selected by an external controller (the active signal on the SPIEN[i] port assigned to channel 0), the MCSPI\_TX\_0 register content of channel 0 is always loaded into the shift register, whether its content is updated or not. The MCSPI\_TX\_0 register must be loaded before MCSPI is selected by a controller.
- Its own receiver register, MCSPI\_RX\_0, on top of the common receive shift register. If the MCSPI\_RX\_0 register is full, the MCSPI\_CHSTAT\_0[0] RXS bit is set.

### Note

The MCSPI\_TX\_1/2/3 and MCSPI\_RX\_1/2/3 registers are not used. Reading from or writing to a channel register other than channel 0 has no effect.

- Its own communication configuration with the following parameters through the MCSPI\_CHCONF\_0:
  - Transmit and receive modes, programmable with the TRM field
  - Interface mode (two data pins or single data pin) and data pins assignment, both programmable with the IS and DPE bits. (The MCSPI modules are in peripheral mode after reset and must be properly configured for the modules to act in controller mode.)
  - MCSPI word length, programmable with the WL bit
  - SPIEN[i] polarity, programmable with the EPOL bit
  - SPICLK polarity, programmable with the POL bit
  - SPICLK phase, programmable with the PHA bit

The SPICLK frequency of a transfer is controlled by the external MCSPI controller connected to the MCSPI peripheral device. The MCSPI\_CHCONF\_0[5-2] CLKD bit field is not used in peripheral mode.

### Note

The configuration of the channel can be loaded in the MCSPI\_CHCONF\_0 only when the channel is disabled.

- Two DMA request events, read and write, synchronize read/write accesses of the DMA controller with the activity of MCSPI. DMA requests are asserted using the MCSPI\_CHCONF\_0[15] DMAR bit for reading and the MCSPI\_CHCONF\_0[14] DMAW bit for writing.
- Four interrupt events (see [Section 12.2.3.4.7.2, Interrupt Events in Peripheral Mode](#)).

#### **12.2.3.4.4.2 Peripheral Transmit-and-Receive Mode**

The peripheral receive mode is programmable (set the MCSPI\_CHCONF\_0[13-12] TRM bit field to 0x0).

In peripheral transmit-and-receive mode, the MCSPI\_TX\_0 register must be loaded before MCSPI is selected by an external MCSPI controller device.

After a channel is enabled, transmission and reception proceed with interrupt and DMA request events.

The MCSPI\_TX\_0 register content is always loaded in the shift register whether it is updated or not. The event TX0\_UNDERFLOW is activated accordingly and does not prevent transmission.

When the MCSPI word transfer completes (the MCSPI\_CHSTAT\_0[2] EOT bit is set to 1), the received data is transferred to the channel receive register.

To use MCSPI as a peripheral transmit-only device, the RX0\_FULL and RX0\_OVERFLOW interrupts and DMA read requests must be disabled due to the state of the MCSPI\_RX\_0 register (see [Section 12.2.3.4.7.2, Interrupt Events in Peripheral Mode](#)).

#### **12.2.3.4.4.3 Peripheral Transmit-Only Mode**

The peripheral transmit-only mode is programmable (set the MCSPI\_CHCONF\_0[13-12] TRM bit field to 0x2) and avoids the requirement for the processor to read the MCSPI\_RX\_0 register (minimizing data movement) only when transmission is meaningful.

To use the MCSPI as a peripheral transmit-only device, the RX0\_FULL and RX0\_OVERFLOW interrupts and DMA read requests must be disabled due to the state of the MCSPI\_RX\_0 register.

When the MCSPI word transfer completes, the MCSPI\_CHSTAT\_0[2] EOT bit is set.

[Figure 12-75](#) shows a half-duplex system with a controller device on the left and a transmit-only peripheral device on the right. Each time a bit transfers out from the peripheral, 1 bit transfers in the controller. After eight cycles of the serial clock SPICLK, WordB transfers from the peripheral to the controller.



spi-018

$k = 0$  or  $1$  depending on `MCSPI_CHCONF_0/1/2/3[16]` DPE0, `MCSPI_CHCONF_0/1/2/3[17]` DPE1 and `MCSPI_CHCONF_0/1/2/3[18]` IS bits

**Figure 12-75. MCSPI Half-Duplex Transmission (Transmit-Only Peripheral)**

#### 12.2.3.4.4 Peripheral Receive-Only Mode

The peripheral receive mode is programmable (set the `MCSPI_CHCONF_0[13-12]` TRM bit field to `0x1`).

In receive-only mode, the `MCSPI_TX_0` register must be loaded before the MCSPI is selected by an external MCSPI controller device. The `MCSPI_TX_0` register content is always loaded into the shift register whether it is updated or not. The `TX0_UNDERFLOW` event is activated accordingly and does not prevent transmission.

When the MCSPI word transfer completes (the `MCSPI_CHSTAT_0[2]` EOT bit is set to `1`), the received data is transferred to the channel receive register.

To use the MCSPI as a peripheral receive-only device, the `TX0_EMPTY` and `TX0_UNDERFLOW` interrupts and the DMA write requests must be disabled due to the state of the `MCSPI_TX_0` register.

For a full-duplex transmission, the serial clock (SPICLK) synchronizes shifting and sampling of the information on the single serial data line. For full duplex, two data lines are required. If SPICLK synchronizes on a single serial data line, the data line should be half-duplex.

**Figure 12-76** shows a half-duplex system with a controller device on the left and a receive-only peripheral device on the right. Each time a bit transfers out from the controller, 1 bit transfers in from the peripheral. After eight cycles of the serial clock SPICLK, WordA transfers from the controller to the peripheral.



spi-019

k = 0 or 1 depending on MCSPI\_CHCONF\_0/1/2/3[16] DPE0, MCSPI\_CHCONF\_0/1/2/3[17] DPE1 and MCSPI\_CHCONF\_0/1/2/3[18] IS bits

**Figure 12-76. MCSPI Half-Duplex Transmission (Receive-Only Peripheral)**

#### 12.2.3.4.5 MCSPI 3-Pin or 4-Pin Mode

Depending on targeted application the MCSPI interface can be configured to use 3 or 4 pins through the MCSPI\_MODULCTRL[1] PIN34 bit. If this bit is set to 0, MCSPI is in 4-pin mode using the SPICLK, SPIDAT[0], SPIDAT[1] and SPIEN[i] signals. If PIN34 is set to 1 the controller is in 3-pin mode and SPIEN[i] is not used. In this mode all options related to chip select management are useless (EPOL, FORCE and TCS0 bits of MCSPI\_CHCONF\_0/1/2/3). 3-pin and 4-pin operation applies to both controller and peripheral modes.

#### 12.2.3.4.6 MCSPI FIFO Buffer Management

The MCSPI controller has a built-in 64-byte buffer to unload the DMA or interrupt handler and improve data throughput.

This buffer can be used by only one channel at a time and is selected by setting the MCSPI\_CHCONF\_0/1/2/3[28] FFER or MCSPI\_CHCONF\_0/1/2/3[27] FF EW bit to 1. If several channels are selected and several FIFO enable bit fields are set to 1, the controller forces the buffer not to be used; the driver must set only one FIFO enable bit field.

The buffer can be used in the following modes:

- Controller or peripheral mode
- Transmit-only, receive-only, or transmit-and-receive mode
- Single channel or turbo mode, or normal round-robin mode. In round-robin mode the buffer is used by only one channel.

Every word length (MCSPI\_CHCONF\_0/1/2/3[11-7] WL) is supported.

In transmit-and-receive mode, the buffer can be used in transmit (see [Figure 12-77](#)) or receive (see [Figure 12-78](#)) directions, or in both directions. If only one direction is chosen in transmit-and-receive mode, the full buffer is used for this direction. In both directions, the buffer is split into two halves, one for each direction (see [Figure 12-79](#)).



Figure 12-77. Buffer Used in Transmit Direction Only



Figure 12-78. Buffer Used in Receive Direction Only



Figure 12-79. Buffer Used for Transmit and Receive Directions

Two levels (MCSPI\_XFERLEVEL[5-0] AEL and MCSPI\_XFERLEVEL[13-8] AFL) rule the buffer management. The granularity of these levels is 1 byte; it is not aligned with the MCSPI word length. The driver must set these values as a multiple of the MCSPI word length defined in WL. Table 12-56 lists the number of bytes written in the FIFO, depending on the word length.

Table 12-56. FIFO Writes, Word Length Relationship

|                                     | MCSPI Word Length (WL) |             |              |
|-------------------------------------|------------------------|-------------|--------------|
|                                     | 3 ≤ WL ≤ 7             | 8 ≤ WL ≤ 15 | 16 ≤ WL ≤ 31 |
| Number of bytes written in the FIFO | 1 byte                 | 2 bytes     | 4 bytes      |

The FIFO buffer pointers are reset when the corresponding channel is enabled or the FIFO configuration changes.

#### 12.2.3.4.6.1 Buffer Almost Full

The MCSPI\_XFERLEVEL[15-8] AFL bit field is needed when the buffer is used to receive an MCSPI word from a peripheral (the MCSPI\_CHCONF\_0/1/2/3[28] FFER bit must be set to 1). It defines the almost-full buffer status. See [Figure 12-80](#).

When the FIFO pointer reaches this level, an interrupt or a DMA request is sent to the processor to enable the system to read AFL + 1 bytes from the receive register.

---

#### Note

AFL + 1 must correspond to a multiple value of the MCSPI\_CHCONF\_0/1/2/3[11-7] WL bit field.

---

When DMA is used, the request is de-asserted after the first receive register read.

No new request is asserted again as long as the system has not performed the correct number of read accesses.



**Figure 12-80. Buffer Almost Full Level (AFL)**

---

#### Note

The MCSPI\_IRQSTATUS register bits are not available in DMA mode. In DMA mode, the request is asserted on the same conditions as the MCSPI\_IRQSTATUS RXx\_FULL flag.

---

#### 12.2.3.4.6.2 Buffer Almost Empty

The MCSPI\_XFERLEVEL[7-0] AEL bit field is needed when the buffer is used to transmit an MCSPI word to a peripheral (the MCSPI\_CHCONF\_0/1/2/3[27] FF EW bit must be set to 1). It defines the almost-empty buffer status. See [Figure 12-81](#).

When the FIFO pointer does not reach this level, an interrupt or a DMA request is sent to the processor to enable the system to write AEL + 1 bytes to the transmit register.

---

#### Note

AEL + 1 must correspond to a multiple value of the MCSPI\_CHCONF\_0/1/2/3[11-7] WL bit field.

---

When DMA is used, the request is de-asserted after the first transmit register write.

No new request is asserted again as long as the system has not performed the correct number of write accesses.



spi-024

**Figure 12-81. Buffer Almost Empty Level (AEL)**

#### Note

The MCSPI\_IRQSTATUS register bits are not available in DMA mode. In DMA mode, the request is asserted on the same conditions as the MCSPI\_IRQSTATUS TXx\_EMPTY flag.

##### 12.2.3.4.6.3 End of Transfer Management

When the FIFO buffer is enabled for a channel, the user must previously configure in the MCSPI\_XFERLEVEL register the AEL and AFL levels and especially the MCSPI\_XFERLEVEL[31-16] WCNT bit field to define the number of MCSPI words to be transferred using the FIFO before enabling the channel.

This counter lets the controller stop the transfer correctly after a defined number of MCSPI word transfers. If WNCT is set to 0x0000, the counter is not used and the user must stop the transfer manually by disabling the channel; in this case, the user does not know how many MCSPI transfers have been done. For received words, software must poll the MCSPI\_CHSTAT\_i[5] RXFFE bit and read the MCSPI\_RX\_0/1/2/3 receive register to empty the FIFO buffer.

When the end-of-word count interrupt is generated (the MCSPI\_IRQSTATUS[17] EOW bit is set), the user can disable the channel and poll the MCSPI\_CHSTAT\_0/1/2/3[5] RXFFE bit to know the last MCSPI words in the FIFO buffer and read them.

No new request is asserted as long as the system has not performed the correct number of write accesses.

##### 12.2.3.4.6.4 Multiple MCSPI Word Access

The processor has the ability to perform multiple MCSPI word access to the receive or transmit registers within a single 32-bit interface access by setting the MCSPI\_MODULCTRL[7] MOA to 1 under specific conditions:

- The channel selected has the FIFO enable.
- Only FIFO sense enabled support the kind of access.
- MCSPI\_MODULCTRL[7] MOA is set to 1.
- Only 32-bit interface access and data width can be performed to receive or transmit registers, for other kind of access the processor must de-assert MCSPI\_MODULCTRL[7] MOA bit.
- The level MCSPI\_XFERLEVEL[7-0] AEL and MCSPI\_XFERLEVEL[15-8] AFL must be 32-bit aligned, it means that AEL[0] = AEL[1] = 1 or AFL[0] = AFL[1] = 1.
- If MCSPI\_XFERLEVEL[31-16] WCNT is used it must be configured according to MCSPI word length.
- The word length of MCSPI words allows to perform multiple MCSPI access, that means that MCSPI\_CHCONF\_0/1/2/3[11-7] WL is <16.

The number of MCSPI word access depends on MCSPI word length:

- $3 \leq WL \leq 7$ , MCSPI word length smaller or equal to byte length, 4 MCSPI words accessed per 32-bit interface read/write. If word count is used (MCSPI\_XFERLEVEL[31-16] WCNT), set the bit field to  $WCNT[0] = WCNT[1] = 0$ .
- $8 \leq WL \leq 15$ , MCSPI word length greater than byte or equal to 16-bit length, 2 MCSPI words accessed per 32-bit interface read/write. If word count is used (MCSPI\_XFERLEVEL[31-16] WCNT), set the bit field to  $WCNT[0] = 0$ .
- $16 \leq WL$  Multiple MCSPI word access is not applicable.

#### 12.2.3.4.6.5 First MCSPI Word Delay

Figure 12-82 shows the MCSPI controller ability to delay the first MCSPI word transfer to give time for system to complete some parallel processes or fill the FIFO in order to improve transfer bandwidth. This delay is applied only on first MCSPI word after MCSPI channel enabled and first write in transmit register. It is based on output clock frequency.

This option is meaningful in controller mode and single channel mode asserted through MCSPI\_MODULCTRL[0] SINGLE.



spi-016a

**Figure 12-82. Controller Single Channel Initial Delay**

Few delay values are available: No delay, 4/8/16/32 MCSPI cycles.

Its accuracy is half cycle in clock bypass mode and depends on clock polarity and phase.

#### 12.2.3.4.7 MCSPI Interrupts

Each channel can issue interrupt events.

Each interrupt event has status bits in the MCSPI\_IRQSTATUS register (RXx\_FULL, TXx\_UNDERFLOW, TXx\_EMPTY, etc.) (where  $x = 0, 3$ ) that indicate whether service is required. Each status bit has an interrupt enable bit (a mask) in the MCSPI\_IRQENABLE register (RXx\_FULL\_ENABLE, TXx\_UNDERFLOW\_ENABLE, TXx\_EMPTY\_ENABLE, etc.).

When an interrupt occurs and a mask is later applied on it, the interrupt line is not asserted again, even if the interrupt source is not serviced.

The MCSPI supports interrupt-driven and polling operations.

#### 12.2.3.4.7.1 Interrupt Events in Controller Mode

In controller mode, the interrupt events related to the state of the MCSPI\_TX\_0/1/2/3 register are TXx\_EMPTY and TXx\_UNDERFLOW. The interrupt event related to the state of the MCSPI\_RX\_0/1/2/3 register is RXx\_FULL.

#### 12.2.3.4.7.1.1 TXx\_EMPTY

The TXx\_EMPTY event is activated when a channel is enabled and its MCSPI\_TX\_0/1/2/3 register is empty (transient event). Enabling a channel automatically triggers this event, except in controller receive-only mode (see [Section 12.2.3.4.3.4, Controller Receive-Only Mode](#)). When the FIFO buffer is enabled (the MCSPI\_CHCONF\_0/1/2/3[27] FFEW bit is set to 1), the MCSPI\_IRQSTATUS TXx\_EMPTY bit is set as soon as there is enough space in the buffer to write a number of bytes defined by the MCSPI\_XFERLEVEL[5-0] AFL bit field.

The MCSPI\_TX\_0/1/2/3 register must be loaded with data to remove the source of the interrupt; the MCSPI\_IRQSTATUS TXx\_EMPTY interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new TXx\_EMPTY event is asserted as long as the processor has not performed the number of writes into the MCSPI\_TX\_0/1/2/3 register defined by the MCSPI\_XFERLEVEL[5-0] AFL bit field. The processor must perform the correct number of writes.

#### 12.2.3.4.7.1.2 TXx\_UNDERFLOW

The event TXx\_UNDERFLOW is activated when the channel is enabled and if the MCSPI\_TX\_0/1/2/3 register or the FIFO is empty (not updated with new data) when an external controller device starts a data transfer with the MCSPI (transmit and receive).

The TXx\_UNDERFLOW is a harmless warning in controller mode.

To avoid having a TXx\_UNDERFLOW event at the beginning of a transmission, the TXx\_UNDERFLOW event is not activated when no data has been loaded into the MCSPI\_TX\_0/1/2/3 register, because the channel is enabled. To avoid having a TXx\_UNDERFLOW event, the MCSPI\_TX\_0/1/2/3 register must seldom be loaded.

The MCSPI\_IRQSTATUS TXx\_UNDERFLOW interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

#### 12.2.3.4.7.1.3 RXx\_FULL

The RXx\_FULL event is activated when a channel is enabled and the MCSPI\_RX\_0/1/2/3 register becomes filled (transient event). When the FIFO buffer is enabled (the MCSPI\_CHCONF\_0/1/2/3[28] FFER bit is set to 1), RXx\_FULL is asserted as soon as the number of bytes held in the FIFO to be read reaches the MCSPI\_XFERLEVEL[13-8] AFL threshold.

The MCSPI\_RX\_0/1/2/3 register must be read to remove the source of the interrupt; the MCSPI\_IRQSTATUS RXx\_FULL interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new RXx\_FULL event is asserted as long as the processor has not performed AFL + 1 reads into MCSPI\_RX\_0/1/2/3. The processor must perform the correct number of reads.

#### 12.2.3.4.7.1.4 End Of Word Count

The MCSPI\_IRQSTATUS[17] EOW event (end of word count) is activated when the channel is enabled and configured to use the built-in FIFO. This interrupt is raised when the controller performs the number of transfers defined in the MCSPI\_XFERLEVEL[31-16] WCNT bit field. If WCNT is set to 0x0000, the counter is not enabled and this interrupt is not generated.

The end of word count interrupt also indicates that the MCSPI transfer is halted on the channel using the FIFO buffer as soon as MCSPI\_XFERLEVEL[31-16] WCNT is not reloaded and the channel is not re-enabled.

The MCSPI\_IRQSTATUS[17] EOW interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

#### 12.2.3.4.7.2 Interrupt Events in Peripheral Mode

In peripheral mode, the interrupt events related to the state of the MCSPI\_TX\_0/1/2/3 register are TX0\_EMPTY and TX0\_UNDERFLOW. The interrupt events related to the state of the MCSPI\_RX\_0/1/2/3 are RX0\_FULL

and RX0\_OVERFLOW (channels 1, 2, and 3 do not have a receiver overflow status bit). See the MCSPI\_IRQSTATUS register.

#### **12.2.3.4.7.2.1 TXx\_EMPTY**

The TXx\_EMPTY event is activated when a channel is enabled and its MCSPI\_TX\_0/1/2/3 register is empty. Enabling the channel automatically raises this event. If the FIFO buffer is enabled (the MCSPI\_CHCONF\_0/1/2/3[27] FFEW bit is set to 1), the TXx\_EMPTY event is asserted as soon as there is enough space in buffer to write a number of bytes defined by the MCSPI\_XFERLEVEL[5-0] AFL bit field.

The MCSPI\_TX\_0/1/2/3 register must be loaded with data to remove the source of the interrupt; the MCSPI\_IRQSTATUS TXx\_EMPTY interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new TXx\_EMPTY event is asserted as long as the processor has not performed the number of writes into the MCSPI\_TX\_0/1/2/3 register defined by MCSPI\_XFERLEVEL[5-0] AFL bit field. The processor must perform the correct number of writes.

#### **12.2.3.4.7.2.2 TXx\_UNDERFLOW**

The TXx\_UNDERFLOW event is activated when a channel is enabled and if the MCSPI\_TX\_0/1/2/3 register is empty (not updated with new data) when an external controller device starts a data transfer with the MCSPI (transmit and receive).

When FIFO is enabled, the data emitted while the underflow event is raised is not the last data written in the FIFO but the next data in the FIFO (an old transmitted value or a dummy data in the FIFO has been reset).

TXx\_UNDERFLOW indicates an error (data loss) in peripheral mode.

To avoid having a TXx\_UNDERFLOW event at the beginning of a transmission, the TXx\_UNDERFLOW event is not activated when no data has been loaded into the MCSPI\_TX\_0/1/2/3 register because the channel is enabled.

The MCSPI\_IRQSTATUS TXx\_UNDERFLOW interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

#### **12.2.3.4.7.2.3 RXx\_FULL**

The RXx\_FULL event is activated when a channel is enabled and the MCSPI\_RX\_0/1/2/3 register is being filled (transient event). When the FIFO buffer is enabled (the MCSPI\_CHCONF\_0/1/2/3[28] FFER bit is set to 1), RXx\_FULL is asserted as soon as the number of bytes held in the buffer to read defined by the MCSPI\_XFERLEVEL[13-8] AFL bit field.

The MCSPI\_RX\_0/1/2/3 register must be read to remove the source of the interrupt; the MCSPI\_IRQSTATUS RXx\_FULL interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

When FIFO is enabled, no new RXx\_FULL event is asserted as long as the processor has not performed AFL + 1 reads into MCSPI\_RX\_0/1/2/3. The processor must perform the correct number of reads.

#### **12.2.3.4.7.2.4 RX0\_OVERFLOW**

The RX0\_OVERFLOW event is activated in peripheral mode in transmit-and-receive mode or receive-only mode when a channel is enabled and the MCSPI\_RX\_0/1/2/3 register or FIFO is full when a h MCSPI word is received. The MCSPI\_RX\_0/1/2/3 register is always overwritten with the new MCSPI word. If the FIFO is enabled, data within the FIFO are overwritten; it must be considered as corrupted. The RX0\_OVERFLOW event should not appear in peripheral mode using the FIFO.

The RX0\_OVERFLOW event indicates an error (data loss) in peripheral mode.

The MCSPI\_IRQSTATUS[3] RX0\_OVERFLOW interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

#### 12.2.3.4.7.2.5 End Of Word Count

The MCSPI\_IRQSTATUS[17] EOW event (end of word count) is activated when the channel is enabled and configured to use the built-in FIFO. This interrupt is raised when the controller performs the number of transfers defined in the MCSPI\_XFERLEVEL[31-16] WCNT bit field. If WCNT is set to 0x0000, the counter is not enabled and this interrupt is not generated.

The end of word count interrupt also indicates that the MCSPI transfer is halted on the channel using the FIFO buffer as soon as WCNT is not reloaded and the channel is not re-enabled.

The MCSPI\_IRQSTATUS[17] EOW interrupt status bit must be cleared for interrupt line deassertion (if the event is enabled as the interrupt source).

#### 12.2.3.4.7.3 Interrupt-Driven Operation

An interrupt enable bit in the MCSPI\_IRQENABLE register can be set to enable each event to generate interrupt requests when the corresponding event occurs. Status bits are automatically set by hardware logic conditions.

When an event occurs (the single interrupt line is asserted), the processor must:

1. Read the MCSPI\_IRQSTATUS register to identify which event occurred.
2. Read the MCSPI\_RX\_0/1/2/3 register that corresponds to the event to remove the source of an RXx\_FULL event or write into the MCSPI\_TX\_0/1/2/3 register that corresponds to the event to remove the source of a TXx\_EMPTY event. No action is required to remove the source of the TXx\_UNDERFLOW and RX0\_OVERFLOW events.
3. Set the corresponding bit of the MCSPI\_IRQSTATUS register to 1 to clear an interrupt status and then release the interrupt line.

The interrupt status bit must always be reset after channel enabling and before events are enabled as interrupt sources.

#### 12.2.3.4.7.4 Polling

When the interrupt capability of an event is disabled in the MCSPI\_IRQENABLE register, the interrupt line is not asserted, but the status bits in the MCSPI\_IRQSTATUS register can be polled by software to detect when the corresponding event occurs.

Once the expected event occurs:

- RXx\_FULL: To remove the source of the event, the processor must read the corresponding MCSPI\_RX\_0/1/2/3 register.
- TXx\_EMPTY: To remove the source of the event, the processor must write into the corresponding MCSPI\_TX\_0/1/2/3 register.
- TXx\_UNDERFLOW and RX0\_OVERFLOW: No action is required to remove the source of the event.

To clear an interrupt, set the corresponding status bit of the MCSPI\_IRQSTATUS register to 1. This does not affect the interrupt line state.

#### 12.2.3.4.8 MCSPI DMA Requests

Each MCSPI channel, if enabled, can issue DMA requests. There are two DMA request lines per MCSPI channel (one for read and one for write).

The DMA read request line is asserted when the MCSPI channel is enabled and new data is available in the receive register of the MCSPI channel. A DMA read request can be individually masked with the MCSPI\_CHCONF\_0/1/2/3[15] DMAR bit. The DMA read request line is de-asserted when reading of the MCSPI\_RX\_0/1/2/3 register of the MCSPI channel completes.

The DMA write request line is asserted when the MCSPI channel is enabled and the MCSPI\_TX\_0/1/2/3 register of the MCSPI channel is empty. A DMA write request can be individually masked with the MCSPI\_CHCONF\_0/1/2/3[14] DMAW bit. The DMA write request line is de-asserted when loading of the MCSPI\_TX\_0/1/2/3 register of the channel completes.

#### 12.2.3.4.9 MCSPI Power Saving Management

Power consumption can be optimized by switching off internal clocks (interface and functional clock) when there is no activity.

##### 12.2.3.4.9.1 Normal Mode

In normal mode, internal MCSPI module clocks are automatically switched off (autogated) when there is no activity in peripheral or controller mode.

Autogating of the module interface clock and functional clock occurs when the following conditions are met:

- The MCSPI\_SYSCONFIG[0] AUTOIDLE bit is set.
- In controller mode, there is no data to transmit or receive in all channels.
- In peripheral mode, the MCSPI is not selected by the external controller and there are no register accesses.

Autogating of the module interface clock and functional clock stops when the following conditions are met:

- In controller mode, an internal access occurs.
- In peripheral mode, an internal access occurs or the MCSPI is selected by the external controller.

##### 12.2.3.4.9.2 Idle Mode

---

###### Note

Some of the MCSPI features described in this section may not be supported on this family of devices. For more information, see *MCSPI Not Supported Features*.

---

At the power management level, when all conditions to shut off the MCSPI\_FCLK or MCSPI\_ICLK clocks are met, the corresponding LPSC asserts a clock stop request to the MCSPI. Although this procedure is completely hardware-oriented and out of software control, the method in which the MCSPI module acknowledges the clock stop request can be configured through the MCSPI\_SYSCONFIG[4-3] SIDLEMODE bit field.

The settings of the SIDLEMODE bit field and the related acknowledgement modes are:

- Force-idle mode (the MCSPI\_SYSCONFIG[4-3] SIDLEMODE bit field is set to 0x0): The MCSPI module acknowledges unconditionally the clock stop request, regardless of its internal operations. This mode must be used carefully in this case because it does not prevent the loss of data when the clock is switched off.
- No-idle mode (the SIDLEMODE bit field is set to 0x1): The MCSPI never acknowledges the clock stop request and is safe from a module point of view because it ensures that the clocks remain active. However, it is not efficient to save power because it does not allow shut off of MCSPI\_FCLK and MCSPI\_ICLK.
- Smart-idle mode (the SIDLEMODE bit field is set to 0x2): The MCSPI acknowledges the clock stop request, depending on its internal activity. MCSPI acknowledges the shut off of MCSPI\_FCLK and MCSPI\_ICLK only when all pending transactions, IRQs, or DMA requests are treated. This is the best approach for efficient system power management.

When configured in smart-idle mode, the MCSPI also offers an additional feature to control gating of MCSPI\_FCLK or MCSPI\_ICLK. The MCSPI\_SYSCONFIG[9-8] CLOCKACTIVITY bit field determines which clock shuts down (MCSPI\_FCLK, MCSPI\_ICLK, neither clock, or both clocks).

The setting of the CLOCKACTIVITY bit field is used internally to the MCSPI to determine on which part of the module the conditions to acknowledge the clock stop request are tested. For example, if MCSPI\_FCLK is not shut off on clock stop request, the MCSPI considers only MCSPI\_ICLK and the associated pending activities before acknowledging the request.

Some MCSPI features are associated with MCSPI\_ICLK and others with MCSPI\_FCLK. Using the CLOCKACTIVITY bit field with the smart-idle mode ensures that the features associated with the clock that remains active are always enabled, even if MCSPI acknowledges the clock stop request.

##### 12.2.3.4.9.2.1 Force-Idle Mode

Force-idle mode is enabled and exited as follows:

- Force-idle mode is enabled when the MCSPI\_SYSConfig[4-3] SIDLEMODE bit field is set to 0x0.
  - In force-idle mode, the MCSPI responds unconditionally to the clock stop request by de-asserting unconditionally the interrupt and DMA request lines, if asserted.
  - The transition from normal mode to idle mode does not affect the interrupt event bits of the MCSPI\_IRQSTATUS register.
  - In force-idle mode, because the module must be disabled, the interrupt and DMA request lines are likely de-asserted. The interface clock and MCSPI clock provided to the MCSPI can be switched off.
  - A clock stop request during an MCSPI data transfer can lead to an unexpected and unpredictable result. Software must avoid such a request.

### 12.2.3.5 MCSPI Programming Guide

This section describes the low-level hardware programming sequences for the configuration and use of the MCSPI module.

#### 12.2.3.5.1 MCSPI Global Initialization

##### 12.2.3.5.1.1 Surrounding Modules Global Initialization

This section identifies the requirements for initializing the surrounding modules when the MCSPI module is to be used for the first time after a device reset. This initialization of surrounding modules is based on the integration and environment of the MCSPI. For further information, see *MCSPI Integration* and *MCSPI Environment*.

**Table 12-57** lists the information on the global initialization of the surrounding modules.

**Table 12-57. Global Initialization of Surrounding Modules**

| Surrounding Modules       | Comments                                                                                                                                                        |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COMPUTE_CLUSTER0          | Device INTCs must be configured to enable the interrupt request generation. For information about enabling COMPUTE_CLUSTER0 interrupts, see <i>Interrupts</i> . |
| MCU_M4FSS0_CORE0          | Device INTCs must be configured to enable the interrupt request generation. For information about enabling MCU_M4FSS0_CORE0 interrupts, see <i>Interrupts</i> . |
| R5FSS0/1_CORE0/1          | Device INTCs must be configured to enable the interrupt request generation. For information about enabling R5FSS0/1_CORE0/1 interrupts, see <i>Interrupts</i> . |
| PRUSS                     | Device INTCs must be configured to enable the interrupt request generation. For information about enabling PRUSS interrupts, see <i>Interrupts</i> .            |
| PDMA0 and PDMA1           | Device INTCs must be configured to enable the interrupt request generation.                                                                                     |
| MCU_PLLCTRL0 and PLLCTRL0 | PLL controller's configuration must be done to enable the module clocks. For more information, see <i>Clocking</i> .                                            |

#### 12.2.3.5.1.2 MCSPI Global Initialization

##### 12.2.3.5.1.2.1 Main Sequence – MCSPI Global Initialization

The procedure in **Table 12-58** can be used to initialize MCSPI when performing software reset.

**Table 12-58. MCSPI Global Initialization**

| Step                                                                          | Register/Bit Field/Programming Model | Value |
|-------------------------------------------------------------------------------|--------------------------------------|-------|
| Perform a software reset.                                                     | MCSPI_SYSCONFIG[1] SOFTRESET         | 1     |
| Wait until reset is finished?                                                 | MCSPI_SYSSTATUS[0] RESETDONE         | =1    |
| Configure static settings (such as SPI controller or peripheral) as required. | MCSPI_MODULCTRL[8-0]                 | 0x-   |
| Write MCSPI_SYSCONFIG                                                         | MCSPI_SYSCONFIG                      | 0x-   |

#### 12.2.3.5.2 MCSPI Operational Mode Configuration

##### 12.2.3.5.2.1 MCSPI Operational Modes

The selection of the working mode is done with the MCSPI\_CHCONF\_0/1/2/3 register.

**Table 12-59. MCSPI Receive Mode Initialization**

| Step                                                                                        | Register/Bit Field/Programming Model | Value |
|---------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Set receive mode for the channel.                                                           | MCSPI_CHCONF_0/1/2/3[13-12] TRM      | 0x1   |
| Configure SPI clock polarity/phase, clock divider, word length, and others for the channel. | MCSPI_CHCONF_0/1/2/3                 | 0x-   |
| Reset the status bits.                                                                      | MCSPI_IRQSTATUS                      | 0x0   |

**Table 12-60. MCSPI Transmit Mode Initialization**

| Step                               | Register/Bit Field/Programming Model | Value |
|------------------------------------|--------------------------------------|-------|
| Set transmit mode for the channel. | MCSPI_CHCONF_0/1/2/3[13-12] TRM      | 0x2   |

**Table 12-60. MCSPI Transmit Mode Initialization (continued)**

| Step                                                                                        | Register/Bit Field/Programming Model | Value |
|---------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Configure SPI clock polarity/phase, clock divider, word length, and others for the channel. | MCSPI_CHCONF_0/1/2/3                 | 0x-   |
| Reset the status bits.                                                                      | MCSPI_IRQSTATUS                      | 0x0   |

**Table 12-61. MCSPI Transmit-and-Receive Mode Initialization**

| Step                                                                                        | Register/Bit Field/Programming Model | Value |
|---------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Set transmit and receive mode for the channel.                                              | MCSPI_CHCONF_0/1/2/3[13-12] TRM      | 0x0   |
| Configure SPI clock polarity/phase, clock divider, word length, and others for the channel. | MCSPI_CHCONF_0/1/2/3                 | 0x-   |
| Reset the status bits.                                                                      | MCSPI_IRQSTATUS                      | 0x0   |

### 12.2.3.5.2.1.1 Common Transfer Sequence

MCSPI module allows the transfer of one or several words, according to different modes:

- CONTROLLER Normal, CONTROLLER Turbo, PERIPHERAL
- TRANSMIT–RECEIVE, TRANSMIT-ONLY, RECEIVE-ONLY
- Write and Read requests: Interrupts, DMA
- SPIEN[i] lines assertion/deassertion: automatic, manual

For all these sequences, the host process contains the main process and the interrupt routines.

The interrupt routines are called on the interrupt signals or by an internal call if the module is used in polling mode.

Table 12-62 represents the main sequence which is common to all transfers.

In multi-channel controller mode, the sequences of different channels can be run simultaneously.

**Table 12-62. Common Transfer Sequence (Main Process)**

| Step                                                     | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------------|--------------------------------------|--------|
| Write MCSPI_IRQSTATUS to reset channel status bits       | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| Write MCSPI_IRQENABLE to enable interrupts               | MCSPI_IRQENABLE                      | 0x-    |
| Write MCSPI_CHCONF_0/1/2/3 to configure the channel      | MCSPI_CHCONF_0/1/2/3                 | 0x-    |
| Start the channel                                        | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1      |
| Wait for the first write request (TX empty or DMA write) |                                      |        |
| Write the transmitter register with data                 | MCSPI_TX_0/1/2/3                     | 0x-    |
| Wait for the host event for end of transfer              |                                      |        |
| Stop the channel                                         | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0      |

### 12.2.3.5.2.1.2 End of Transfer Sequences

The end of transfer depends on the transfer mode. Table 12-63 summarizes the type of end of transfer per transfer mode and gives a reference to the appropriate section for details.

**Table 12-63. End of Transfer Sequences**

|                          |                          | TRANSMIT-AND-RECEIVE       |     | TRANSMIT-ONLY                |                              | RECEIVE-ONLY                 |                              |
|--------------------------|--------------------------|----------------------------|-----|------------------------------|------------------------------|------------------------------|------------------------------|
|                          |                          | INTERRUPT                  | DMA | INTERRUPT                    | DMA                          | INTERRUPT                    | DMA                          |
| CONTROL<br>LER<br>Normal | End of transfer sequence | See Section 12.2.3.5.2.1.3 |     | See Section 12.2.3.5.2.1.4.1 | See Section 12.2.3.5.2.1.4.2 | See Section 12.2.3.5.2.1.5.1 | See Section 12.2.3.5.2.1.5.2 |
|                          | Minimum number of word   | 1                          | 1   | 1                            | 1                            | 1                            | 2                            |
|                          | DMA transfer size        |                            | N   |                              | N                            |                              | N-1                          |

**Table 12-63. End of Transfer Sequences (continued)**

|                      |                          | TRANSMIT-AND-RECEIVE       |     | TRANSMIT-ONLY                |                              | RECEIVE-ONLY                 |                              |
|----------------------|--------------------------|----------------------------|-----|------------------------------|------------------------------|------------------------------|------------------------------|
|                      |                          | INTERRUPT                  | DMA | INTERRUPT                    | DMA                          | INTERRUPT                    | DMA                          |
| CONTROL<br>LER Turbo | End of transfer sequence | See Section 12.2.3.5.2.1.3 |     | See Section 12.2.3.5.2.1.4.1 | See Section 12.2.3.5.2.1.4.2 | See Section 12.2.3.5.2.1.6.1 | See Section 12.2.3.5.2.1.6.2 |
|                      | Minimum number of word   | 1                          | 1   | 1                            | 1                            | 2                            | 3                            |
|                      | DMA transfer size        |                            | N   |                              | N                            |                              | N-2                          |
| PERIPHERAL           | End of transfer sequence | See Section 12.2.3.5.2.1.3 |     | See Section 12.2.3.5.2.1.4.1 | See Section 12.2.3.5.2.1.4.2 | See Section 12.2.3.5.2.1.7   |                              |
|                      | Minimum number of word   | 1                          | 1   | 1                            | 1                            | 1                            | 1                            |
|                      | DMA transfer size        |                            | N   |                              | N                            | N                            | N                            |

The transfer to execute has a size of N words.

The different sequences can be merged in one process to manage transfers of several types. The end of transfer sequences are described from the start of the channel.

In these sequences, some soft variables are used:

- write\_count = 0
- read\_count = 0
- channel\_enable = FALSE
- last\_transfer = FALSE
- last\_request = FALSE

They are initialized before starting the channel.

#### 12.2.3.5.2.1.3 Transmit-and-Receive (Controller and Peripheral)

If the requests are configured in DMA, write\_count and read\_count are assigned with 'N' when the DMA handlers have completed their 'N' CBASS0 accesses.

**Table 12-64. Transmit-and-Receive (Controller and Peripheral) (Main Process)**

| Step                                        | Register/Bit Field/Programming Model | Value |
|---------------------------------------------|--------------------------------------|-------|
| Start the channel                           | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait for write_count = N AND read_count = N |                                      |       |
| Stop the channel                            | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**Table 12-65. Transmit-and-Receive (Controller and Peripheral) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: TXx_EMPTY</b>                               |                                      |        |
| Write the transmitter register with data           | MCSPI_TX_0/1/2/3                     | 0x-    |
| Increment write_count +1                           |                                      |        |
| <b>IF: RXx_FULL</b>                                |                                      |        |
| Read the receiver register                         | MCSPI_RX_0/1/2/3                     |        |
| Increment read_count +1                            |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

#### 12.2.3.5.2.1.4 Transmit-Only (Controller and Peripheral)

##### 12.2.3.5.2.1.4.1 Based on Interrupt Requests

**Table 12-66. Transmit-Only With Interrupts (Controller and Peripheral) (Main Process)**

| Step                            | Register/Bit Field/Programming Model | Value |
|---------------------------------|--------------------------------------|-------|
| Start the channel               | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait until last transfer = TRUE |                                      |       |
| Wait for end of transfer        | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel                | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**Table 12-67. Transmit-Only With Interrupts (Controller and Peripheral) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: TXx_EMPTY AND write_count &lt; N</b>        |                                      |        |
| Write the transmitter register with data           | MCSPI_TX_0/1/2/3                     | 0x-    |
| Increment write_count +1                           |                                      |        |
| <b>ELSEIF: write_count ≥ N</b>                     |                                      |        |
| last_transfer = TRUE                               |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

#### 12.2.3.5.2.1.4.2 Based on DMA Write Requests

When the DMA handler has completed its 'N' CBASS0 accesses, write\_count is assigned with 'N'.

**Table 12-68. Transmit-Only With DMA (Controller and Peripheral) (Main Process)**

| Step                            | Register/Bit Field/Programming Model | Value |
|---------------------------------|--------------------------------------|-------|
| Start the channel               | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait until write_count = N      |                                      |       |
| Disable DMA write request       | MCSPI_CHCONF_0/1/2/3[14] DMAW        | 0     |
| Wait until last_transfer = TRUE |                                      |       |
| Wait for end of transfer        | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel                | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**Table 12-69. Transmit-Only With DMA (Controller and Peripheral) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: TXx_EMPTY AND write_count = N</b>           |                                      |        |
| last_transfer = TRUE                               |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

#### 12.2.3.5.2.1.5 Controller Normal Receive-Only

##### 12.2.3.5.2.1.5.1 Based on Interrupt Requests

**Table 12-70. Receive-Only With Interrupt (Controller Normal) (Main Process)**

| Step                           | Register/Bit Field/Programming Model | Value |
|--------------------------------|--------------------------------------|-------|
| Start the channel              | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait until last_request = TRUE |                                      |       |
| Stop the channel               | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Read the receiver register     | MCSPI_RX_0/1/2/3                     | 0x-   |

**Table 12-70. Receive-Only With Interrupt (Controller Normal) (Main Process) (continued)**

| Step                    | Register/Bit Field/Programming Model | Value |
|-------------------------|--------------------------------------|-------|
| Increment read_count +1 |                                      |       |

**Table 12-71. Receive-Only With Interrupt (Controller Normal) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: RXx_FULL AND read_count = N - 1</b>         |                                      |        |
| last_request = TRUE                                |                                      |        |
| <b>ELSEIF: read_count ≠ N - 1</b>                  |                                      |        |
| Read the receiver register                         | MCSPI_RX_0/1/2/3                     | 0x-    |
| Increment read_count +1                            |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

#### 12.2.3.5.2.1.5.2 Based on DMA Read Requests

When the DMA handler has completed its 'N-1' CBASS0 accesses, read\_count is assigned with 'N-1'.

**Table 12-72. Receive-Only With DMA (Controller Normal) (Main Process)**

| Step                            | Register/Bit Field/Programming Model | Value |
|---------------------------------|--------------------------------------|-------|
| Start the channel               | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait until read_count = N - 1   |                                      |       |
| Disable DMA read request        | MCSPI_CHCONF_0/1/2/3[15] DMAR        | 0     |
| Wait until last_transfer = TRUE |                                      |       |
| Stop the channel                | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Read the receiver register      | MCSPI_RX_0/1/2/3                     | 0x-   |
| Increment read_count +1         |                                      |       |

**Table 12-73. Receive-Only With DMA (Controller Normal) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: RXx_FULL AND read_count = N</b>             |                                      |        |
| last_transfer = TRUE                               |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

#### 12.2.3.5.2.1.6 Controller Turbo Receive-Only

##### 12.2.3.5.2.1.6.1 Based on Interrupt Requests

**Table 12-74. Receive-Only With Interrupt (Controller Turbo) (Main Process)**

| Step                              | Register/Bit Field/Programming Model | Value |
|-----------------------------------|--------------------------------------|-------|
| Start the channel                 | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait until channel_enable = TRUE  |                                      |       |
| Wait until last_transfer = TRUE   |                                      |       |
| Wait for end of transfer          | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel                  | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Wait until channel_enable = FALSE |                                      |       |

**Table 12-75. Receive-Only With Interrupt (Controller Turbo) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: RXx_FULL</b>                                |                                      |        |
| <b>IF: read_count = N - 2</b>                      |                                      |        |
| last_transfer = TRUE                               |                                      |        |
| Wait until channel_enable = FALSE                  |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |
| <b>IF: read_count &lt; N</b>                       |                                      |        |
| Read the receiver register                         | MCSPI_RX_0/1/2/3                     | 0x-    |
| Increment read_count +1                            |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

**12.2.3.5.2.1.6.2 Based on DMA Read Requests**

When the DMA handler has completed its 'N-2' CBASS0 accesses read\_count is assigned with 'N-2'.

**Table 12-76. Receive-Only With DMA (Controller Turbo) (Main Process)**

| Step                              | Register/Bit Field/Programming Model | Value |
|-----------------------------------|--------------------------------------|-------|
| Start the channel                 | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait until channel_enable = TRUE  |                                      |       |
| Wait until read_count = TRUE      |                                      |       |
| Disable DMA read request          | MCSPI_CHCONF_0/1/2/3[15] DMAR        | 0     |
| Wait until last_transfer = TRUE   |                                      |       |
| Wait for end of transfer          | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel                  | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Wait until channel_enable = FALSE |                                      |       |

**Table 12-77. Receive-Only With DMA (Controller Turbo) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: RXx_FULL</b>                                |                                      |        |
| <b>IF: read_count = N - 2</b>                      |                                      |        |
| last_transfer = TRUE                               |                                      |        |
| Wait until channel_enable = FALSE                  |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |
| <b>IF: read_count &lt; N</b>                       |                                      |        |
| Read the receiver register                         | MCSPI_RX_0/1/2/3                     | 0x-    |
| Increment read_count +1                            |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

**12.2.3.5.2.1.7 Peripheral Receive-Only**

If the requests are configured in DMA, read\_count is assigned with 'N' when the DMA handler has completed its 'N' CBASS0 accesses.

**Table 12-78. Receive-Only (Peripheral) (Main Process)**

| Step                      | Register/Bit Field/Programming Model | Value |
|---------------------------|--------------------------------------|-------|
| Start the channel         | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait until read_count = N |                                      |       |
| Stop the channel          | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**Table 12-79. Receive-Only (Peripheral) (Interrupt Routine)**

| Step                                               | Register/Bit Field/Programming Model | Value  |
|----------------------------------------------------|--------------------------------------|--------|
| Read MCSPI_IRQSTATUS                               | MCSPI_IRQSTATUS                      | 0x-    |
| Write MCSPI_IRQSTATUS to reset channel status bits | MCSPI_IRQSTATUS[channel i bits]      | 0b1111 |
| <b>IF: RXx_FULL</b>                                |                                      |        |
| Read the receiver register                         | MCSPI_RX_0/1/2/3                     | 0x-    |
| Increment read_count +1                            |                                      |        |
| <b>ENDIF</b>                                       |                                      |        |

#### 12.2.3.5.2.1.8 Transfer Procedures With FIFO

These flows describe the transfer with FIFO.

The MCSPI module allows the transfer of one or several words, according to different modes:

- CONTROLLER Normal, CONTROLLER Turbo, PERIPHERAL
- TRANSMIT-RECEIVE, TRANSMIT-ONLY, RECEIVE-ONLY
- Write and Read requests: IRQ, DMA

For all these flows, the host process contains the main process and the interrupt routine. This routine is called on the IRQ signals or by an internal call if the module is used in polling mode.

For more information, see [Section 12.2.3.4.6, MCSPI FIFO Buffer Management](#).

**Table 12-80. FIFO Mode Common Sequence (Controller) (Main Process)**

| Step                                                | Register/Bit Field/Programming Model | Value |
|-----------------------------------------------------|--------------------------------------|-------|
| Write MCSPI_IRQSTATUS to reset channel status bits  | MCSPI_IRQSTATUS                      | 1     |
| Write MCSPI_IRQENABLE to enable interrupts          | MCSPI_IRQENABLE                      | 1     |
| Write MCSPI_CHCONF_0/1/2/3 to configure the channel | MCSPI_CHCONF_0/1/2/3                 | 0x-   |
| Write MCSPI_XFERLEVEL                               | MCSPI_XFERLEVEL                      | 0x-   |
| Start the channel                                   | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| <b>IF: Receive only</b>                             |                                      |       |
| Wait for the write request (TX empty or DMA write)  |                                      |       |
| Write for the transmitter register with data        | MCSPI_TX_0/1/2/3                     | 0x-   |
| <b>ENDIF</b>                                        |                                      |       |
| Wait for the host event for end of transfer         |                                      |       |
| Stop the channel                                    | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

#### 12.2.3.5.2.1.8.1 Common Transfer Sequence in FIFO Mode

This flow describes the host sequence for a transfer of any type defined in [Section 12.2.3.5.2.1.8, Transfer Procedures With FIFO](#).

In multi-channel, only one channel can use the FIFO.

Before enabling the FIFO for a channel (MCSPI\_CHCONF\_0/1/2/3[28] FFER and MCSPI\_CHCONF\_0/1/2/3[27] FFEW bits), the host must check that the FIFO is not enabled for another channel, even if these channels are not used.

In transmit-and-receive mode, the FIFO can be enabled for write or read request only, without FIFO for the other request.

In Peripheral mode, the channel 0 only can be activated. The correct SPIEN line is chosen in MCSPI\_CHCONF\_0[22-21] SPIENSLV bits.

The MCSPI module can start the transfer only when the first write request has been released by writing the MCSPI\_TX\_0/1/2/3 register, even in receive-only mode (only one write request occurs in this case).

#### **12.2.3.5.2.1.8.2 End of Transfer Sequences in FIFO Mode**

**Table 12-81** summarizes the type of end of transfer per transfer mode and gives a reference to the appropriate section for details.

**Table 12-81. End of Transfer Sequences in FIFO Mode**

| Word count | TRANSMIT AND RECEIVE             | TRANSMIT-ONLY                    | RECEIVE-ONLY                     |
|------------|----------------------------------|----------------------------------|----------------------------------|
| Yes        | <a href="#">See Figure 12-83</a> | <a href="#">See Figure 12-85</a> | <a href="#">See Figure 12-86</a> |
| No         | <a href="#">See Figure 12-84</a> | <a href="#">See Figure 12-85</a> | <a href="#">See Figure 12-87</a> |

The end of transfer sequences are described from the start of the channel.

In these sequences, some soft variables are used:

- write\_count = N
- read\_count = N
- last\_request = FALSE

They are initialized before starting the channel.

#### **12.2.3.5.2.1.8.3 Transmit-and-Receive With Word Count**

[Figure 12-83](#) shows the flow of a transfer in transmit-and-receive mode, with word count.



mcsipi\_025

**Figure 12-83. FIFO Mode Transmit-and-Receive With Word Count (Controller)**

#### 12.2.3.5.2.1.8.4 Transmit-and-Receive Without Word Count

Figure 12-84 shows the flow of a transfer in transmit-and-receive mode, without word count.



mcspi\_026

**Figure 12-84. FIFO Mode Transmit-and-Receive Without Word Count (Controller)**

#### 12.2.3.5.2.1.8.5 Transmit-Only

Figure 12-85 shows the flow of a transfer in transmit-only mode, with or without word count. The difference between word count enabled or not is just on the condition after starting the channel:

- word count enable: wait for EOW interrupt
- word count disable: wait for write\_count = 0



mcsipi\_027

**Figure 12-85. FIFO Mode Transmit-Only (Controller)**

#### 12.2.3.5.2.1.8.6 Receive-Only With Word Count

Figure 12-86 shows the flow of a transfer in receive-only mode, with word count.



mcspi\_028

**Figure 12-86. FIFO Mode Receive-Only With Word Count (Controller)**

#### 12.2.3.5.2.1.8.7 Receive-Only Without Word Count

Figure 12-87 shows the flow of a transfer in receive-only mode, with word count.



mcspi\_029

**Figure 12-87. FIFO Mode Receive-Only Without Word Count (Controller)**

#### 12.2.3.5.2.1.9 Common Transfer Procedures Without FIFO – Polling Method

##### 12.2.3.5.2.1.9.1 Receive-Only Procedure – Polling Method

Table 12-82 lists the receive-only procedure using the polling method.

**Table 12-82. Receive-Only Procedure – Polling Method**

| Step                                         | Register/Bit Field/Programming Model | Value |
|----------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode. | See Table 12-59.                     |       |
| Start the channel.                           | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait for end-of-transfer.                    | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Read the receiver register.                  | MCSPI_RX_0/1/2/3                     | 0x-   |

**Table 12-82. Receive-Only Procedure – Polling Method (continued)**

| Step                                          | Register/Bit Field/Programming Model | Value |
|-----------------------------------------------|--------------------------------------|-------|
| Stop the channel if no more data is expected. | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**12.2.3.5.2.1.9.2 Receive-Only Procedure – Interrupt Method**

Table 12-83 lists the receive-only procedure using the interrupt method.

**Table 12-83. Receive-Only Procedure – Interrupt Method**

| Step                                               | Register/Bit Field/Programming Model | Value |
|----------------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode.       | See Table 12-59.                     |       |
| Start the channel.                                 | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Enable the interrupt for the receiver register.    | MCSPI_IRQENABLE[2] RX_FULL_ENABLE    | 1     |
| Wait for interrupt.                                |                                      |       |
| Read the status register.                          | MCSPI_IRQSTATUS[2] RX_FULL           | 1     |
| Disable the interrupt if no more data is expected. | MCSPI_IRQENABLE[2] RX_FULL_ENABLE    | 0     |
| Stop the channel if no more data is expected.      | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Read the receiver register.                        | MCSPI_RX_0/1/2/3                     | 0x-   |

**12.2.3.5.2.1.9.3 Transmit-Only Procedure – Polling Method**

Table 12-84 lists the transmit-only procedure using the polling method.

**Table 12-84. Transmit-Only Procedure – Polling Method**

| Step                                         | Register/Bit Field/Programming Model | Value |
|----------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode. | See Table 12-60.                     |       |
| Start the channel.                           | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Write the transmitter register with data.    | MCSPI_TX_0/1/2/3                     | 0x-   |
| Wait until end of transfer?                  | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel.                            | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**12.2.3.5.2.1.9.4 Transmit-and-Receive Procedure – Polling Method**

Table 12-85 lists the transmit-and-receive procedure using the polling method.

**Table 12-85. Transmit-and-Receive Procedure – Polling Method**

| Step                                         | Register/Bit Field/Programming Model | Value |
|----------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode. | See Table 12-61.                     |       |
| Start the channel.                           | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Write the transmitter register with data.    | MCSPI_TX_0/1/2/3                     | 0x-   |
| Wait until transmit/receive word?            | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel.                            | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Read the receiver register.                  | MCSPI_RX_0/1/2/3                     | 0x-   |

**12.2.3.5.3 Common Transfer Procedures Without FIFO – Polling Method****12.2.3.5.3.1 Receive-Only Procedure – Polling Method**

Table 12-86 lists the receive-only procedure using the polling method.

**Table 12-86. Receive-Only Procedure – Polling Method**

| Step                                         | Register/Bit Field/Programming Model | Value |
|----------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode. | See Table 12-59.                     |       |
| Start the channel.                           | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Wait for end-of-transfer.                    | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |

**Table 12-86. Receive-Only Procedure – Polling Method (continued)**

| Step                                          | Register/Bit Field/Programming Model | Value |
|-----------------------------------------------|--------------------------------------|-------|
| Read the receiver register.                   | MCSPI_RX_0/1/2/3                     | 0x-   |
| Stop the channel if no more data is expected. | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**12.2.3.5.3.2 Receive-Only Procedure – Interrupt Method**

Table 12-87 lists the receive-only procedure using the interrupt method.

**Table 12-87. Receive-Only Procedure – Interrupt Method**

| Step                                               | Register/Bit Field/Programming Model | Value |
|----------------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode.       | See Table 12-59.                     |       |
| Start the channel.                                 | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Enable the interrupt for the receiver register.    | MCSPI_IRQENABLE[2] RX_FULL_ENABLE    | 1     |
| Wait for interrupt.                                |                                      |       |
| Read the status register.                          | MCSPI_IRQSTATUS[2] RX_FULL           | 1     |
| Disable the interrupt if no more data is expected. | MCSPI_IRQENABLE[2] RX_FULL_ENABLE    | 0     |
| Stop the channel if no more data is expected.      | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Read the receiver register.                        | MCSPI_RX_0/1/2/3                     | 0x-   |

**12.2.3.5.3.3 Transmit-Only Procedure – Polling Method**

Table 12-88 lists the transmit-only procedure using the polling method.

**Table 12-88. Transmit-Only Procedure – Polling Method**

| Step                                         | Register/Bit Field/Programming Model | Value |
|----------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode. | See Table 12-60.                     |       |
| Start the channel.                           | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Write the transmitter register with data.    | MCSPI_TX_0/1/2/3                     | 0x-   |
| Wait until end of transfer?                  | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel.                            | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |

**12.2.3.5.3.4 Transmit-and-Receive Procedure – Polling Method**

Table 12-89 lists the transmit-and-receive procedure using the polling method.

**Table 12-89. Transmit-and-Receive Procedure – Polling Method**

| Step                                         | Register/Bit Field/Programming Model | Value |
|----------------------------------------------|--------------------------------------|-------|
| Configure the channel according to the mode. | See Table 12-61.                     |       |
| Start the channel.                           | MCSPI_CHCTRL_0/1/2/3[0] EN           | 1     |
| Write the transmitter register with data.    | MCSPI_TX_0/1/2/3                     | 0x-   |
| Wait until transmit/receive word?            | MCSPI_CHSTAT_0/1/2/3[2] EOT          | =1    |
| Stop the channel.                            | MCSPI_CHCTRL_0/1/2/3[0] EN           | 0     |
| Read the receiver register.                  | MCSPI_RX_0/1/2/3                     | 0x-   |

### 12.2.4 Universal Asynchronous Receiver/Transmitter (UART)

This chapter describes the function, operation, and configuration of the Universal Asynchronous Receiver/Transmitter (UART)/RS-485/Infrared Data Association (IrDA)/Consumer Infrared (CIR) module in the device.

#### Note

UART and USART acronyms are used interchangeably in this section.

#### 12.2.4.1 UART Overview

The UART is a peripheral that utilizes the DMA for data transfer or interrupt polling via host CPU. All UART modules support IrDA and CIR modes when 48 MHz function clock is used. Each UART can be used for configuration and data exchange with a number of external peripheral devices or interprocessor communication between devices.

Figure 12-88 shows the UART modules overview.



- A. x represents a valid instance of UART in a domain.
- B. n represents the maximum number of available UART signals -1.

**Figure 12-88. UART Modules Overview**

#### 12.2.4.1.1 UART Features

The UART includes the following features:

- 16C750-compatible
- RS-485 external transceiver auto flow control support
- 64-byte FIFO buffer for receiver and 64-byte FIFO buffer for transmitter
- Programmable interrupt trigger levels for FIFOs
- Programmable sleep mode
- The 48 MHz functional clock is default option and allows baud rates up to 3.6 Mbps
- Auto-baud between 1200 bits/s and 115.2 Kbits/s (only when 48 MHz function clock is used)
- Optional multi-drop transmission

- Configurable time-guard feature
- Configurable data format:
  - Parity bit: Even, odd, none
  - Stop-bit: 1, 1.5, 2 bit(s)
- Flow control: Hardware (RTS/CTS) or software (XON/XOFF)
- False start bit detection
- Line break generation and detection
- Fully prioritized interrupt system controls
- Internal test and loopback capabilities
- Modem control functions (CTS, RTS)
- UART0 module in MAIN domain has extended modem control signals (DCD, RI, DTR, DSR)

#### **12.2.4.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

---

##### **Note**

Some features may not be available. See *Module Integration* for more information.

---

#### **12.2.4.1.3 IrDA Features**

The IrDA includes the following features:

- Support of IrDA 1.4 slow infrared (SIR), medium infrared (MIR), and fast infrared (FIR) communications:
  - Slow infrared (SIR 115.2 KBAUD), medium infrared (MIR 0.576 MBAUD) and fast infrared (FIR 4.0 MBAUD) operations (very fast infrared (VFIR) is not supported)
  - Frame formatting: addition of variable beginning-of-frame (xBOF) characters and end-of-frame (EOF) characters
  - Uplink/downlink cyclic redundancy check (CRC) generation/detection
  - Asynchronous transparency (automatic insertion of break character)
  - Eight-entry status FIFO (with selectable trigger levels) to monitor frame length and frame errors
  - Framing error, CRC error, illegal symbol (FIR), and abort pattern (SIR, MIR) detection
- IrDA mode when 48 MHz function clock is used

#### **12.2.4.1.4 CIR Features**

The CIR mode uses a variable pulse-width modulation (PWM) technique (based on multiples of a programmable  $t$  period) to encompass the various formats of infrared encoding for remote-control applications. The CIR logic transmits data packets based on a user-definable frame structure and packet content.

The CIR includes the following features to provide CIR support for remote-control applications:

- Transmit and receive mode
- Free data format (supports any remote-control private standards)
- Selectable bit rate
- Configurable carrier frequency
- 1/2, 5/12, 1/3, or 1/4 carrier duty cycle
- CIR mode when 48 MHz function clock is used

#### 12.2.4.2 UART Environment

The , modules are hereinafter referred to as UART module.

This section describes the UART/RS-485/IrDA/CIR external connections (environment).

- The UART interface is described in [Section 12.2.4.2.1, UART Functional Interfaces](#).
- The RS-485 interface is described in [Section 12.2.4.2.2, RS-485 Functional Interfaces](#).
- The IrDA interface is described in [Section 12.2.4.2.3, IrDA Functional Interfaces](#).
- The CIR interface is described in [Section 12.2.4.2.4, CIR Functional Interfaces](#).

##### 12.2.4.2.1 UART Functional Interfaces

###### 12.2.4.2.1.1 System Using UART Communication With Hardware Handshake

Each UART instance can be easily connected to the UART port of an external IC (see [Figure 12-89](#) ).

**Figure 12-89. UART Mode Interface Signals**

#### 12.2.4.2.1.2 UART Interface Description

Table 12-90 lists the UART interface input/output (I/O) signals.

**Table 12-90. UART I/O Signals**

| Module Pin Name                           | Device Level Signal Name        | I/O <sup>(1)</sup> | Description                        | Module Pin Reset Value <sup>(2)</sup> |
|-------------------------------------------|---------------------------------|--------------------|------------------------------------|---------------------------------------|
| <b>WKUP_UARTi<sup>(10)</sup></b>          |                                 |                    |                                    |                                       |
| RX                                        | WKUP_UARTi <sup>(10)</sup> _RXD | I                  | Serial data input                  | HiZ                                   |
| TX                                        | WKUP_UARTi <sup>(10)</sup> _TXD | O                  | Serial data output <sup>(3)</sup>  | 1                                     |
| CTS                                       | WKUP_UARTi <sup>(10)</sup> _CTS | I                  | Clear to send <sup>(4)</sup>       | HiZ                                   |
| RTS                                       | WKUP_UARTi <sup>(10)</sup> _RTS | O                  | Request to send <sup>(5)</sup>     | 1                                     |
| <b>MCU_UARTi<sup>(10)</sup></b>           |                                 |                    |                                    |                                       |
| RX                                        | MCU_UARTi <sup>(10)</sup> _RXD  | I                  | Serial data input                  | HiZ                                   |
| TX                                        | MCU_UARTi <sup>(10)</sup> _TXD  | O                  | Serial data output <sup>(3)</sup>  | 1                                     |
| CTS                                       | MCU_UARTi <sup>(10)</sup> _CTS  | I                  | Clear to send <sup>(4)</sup>       | HiZ                                   |
| RTS                                       | MCU_UARTi <sup>(10)</sup> _RTS  | O                  | Request to send <sup>(5)</sup>     | 1                                     |
| <b>UARTi<sup>(10)</sup> Modem Signals</b> |                                 |                    |                                    |                                       |
| DCD                                       | UARTi <sup>(10)</sup> _DCDn     | I                  | Data Carrier Detect <sup>(6)</sup> | HiZ                                   |
| DSR                                       | UARTi <sup>(10)</sup> _DSRn     | I                  | Data Set Ready <sup>(7)</sup>      | HiZ                                   |
| DTR                                       | UARTi <sup>(10)</sup> _DTRn     | O                  | Data Terminal Ready <sup>(8)</sup> | 1                                     |
| RIN                                       | UARTi <sup>(10)</sup> _RIN      | I                  | Ring Indicator <sup>(9)</sup>      | HiZ                                   |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) Because this pin is active high in IrDA mode and the output is muxed, this pin is set to low on reset (when the UART\_MDR1[2:0] bit field is set to 0x7) and takes the defined inactive level of that signal corresponding to when and how the UART\_MDR1 register is programmed; that is, the output is 1 (inactive for UART modem modes) and 0 (inactive for IrDA modes).

(4) Active-low modem status signal. Reading the UART\_MSR[4] NCTS\_STS bit checks the condition of CTS. Reading the UART\_MSR[0] CTS\_STS bit checks a change of state of CTS since the last read of the modem status register. The auto-CTS mode uses CTS to control the transmitter.

(5) When active (low), the module is ready to receive data. Setting the UART\_MCR[1] RTS bit activates RTS signal, which becomes inactive as the result of a module reset, loopback mode, or clearing the UART\_MCR[1] RTS bit. In auto-RTS mode, RTS signal becomes inactive as a result of the receiver threshold logic.

(6) Active-low modem status signal. The condition of DCD can be checked by reading the UART\_MSR[7] NCD\_STS bit. Any change in its state can be detected by reading the UART\_MSR[3] DCD\_STS bit.

(7) Active-low modem status signal. Reading the UART\_MSR[5] NDSR\_STS bit checks the condition of DSR. Reading the UART\_MSR[1] DSR\_STS bit checks a change of state of DSR since the last read of the UART\_MSR register.

(8) When active (low), this signal informs the modem that the module is ready to communicate. It is activated by setting the UART\_MCR[0] DTR bit.

(9) Active-low modem status signal. The condition of RIN can be checked by reading the UART\_MSR[6] NRI\_STS bit. Any change in its state can be detected by reading the UART\_MSR[2] RI\_STS bit.

(10) i represents a UART instance. See the device datasheet for available domains and UART instances.

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

#### 12.2.4.2.1.3 UART Protocol and Data Format

The UART device operates in three modes:

- UART 16× (<= 230.4 kbps)
- UART 16× with autobauding (>= 1200 bps and <= 115.2 kbps)
- UART 13× (>= 460.8 kbps)

**CAUTION**

To be used as a UART, the operating mode must be programmed appropriately in the `UART_MDR1[2-0] MODE_SELECT` bit field to select UART, IrDA, or CIR mode, and the `UART_MDR3[4] DIR_EN` bit field to select RS-485 mode.

The UART uses a wired interface for serial communication with a remote device.

The UART is functionally compatible with the TL16C750 UART and earlier designs such as the TL16C550.

[Figure 12-90](#) shows the UART frame data format.

**Figure 12-90. UART Frame Data Format**

**12.2.4.2.2 RS-485 Functional Interfaces**

**12.2.4.2.2.1 System Using RS-485 Communication**

The RS-485 network physical layer consists of two-wire differential bus, usually twisted pair. External RS-485 transceiver IC is needed to access a RS-485 bus by the RS-485 mode. [Figure 12-91](#) shows an example connection of `MCU_UART0` in RS-485 mode.

**Figure 12-91. RS-485 Mode Interface Signals**

**12.2.4.2.2.2 RS-485 Interface Description**

[Table 12-91](#) lists the RS-485 interface input/output (I/O) signals.

**Table 12-91. UART I/O Signals (RS-485 Mode)**

| Module Pin                                 | Device Level Signal                         | I/O <sup>(1)</sup> | Description        | Module Pin Reset Value <sup>(2)</sup> |
|--------------------------------------------|---------------------------------------------|--------------------|--------------------|---------------------------------------|
| <b>WKUP_UART<sup>i</sup><sup>(3)</sup></b> |                                             |                    |                    |                                       |
| RX                                         | WKUP_UART <sup>i</sup> <sup>(3)</sup> _RXD  | I                  | Serial data input  | HiZ                                   |
| TX                                         | WKUP_UART <sup>i</sup> <sup>(3)</sup> _TXD  | O                  | Serial data output | 1                                     |
| DIR                                        | WKUP_UART <sup>i</sup> <sup>(3)</sup> _RTSn | O                  | RS-485 Direction   | 1                                     |
| <b>MCU_UART<sup>i</sup><sup>(3)</sup></b>  |                                             |                    |                    |                                       |
| RX                                         | MCU_UART <sup>i</sup> <sup>(3)</sup> _RXD   | I                  | Serial data input  | HiZ                                   |
| TX                                         | MCU_UART <sup>i</sup> <sup>(3)</sup> _TXD   | O                  | Serial data output | 1                                     |
| DIR                                        | MCU_UART <sup>i</sup> <sup>(3)</sup> _RTSn  | O                  | RS-485 Direction   | 1                                     |
| <b>UART<sup>i</sup><sup>(3)</sup></b>      |                                             |                    |                    |                                       |
| RX                                         | UART <sup>i</sup> <sup>(3)</sup> _RXD       | I                  | Serial data input  | HiZ                                   |
| TX                                         | UART <sup>i</sup> <sup>(3)</sup> _TXD       | O                  | Serial data output | 1                                     |
| DIR                                        | UART <sup>i</sup> <sup>(3)</sup> _RTSn      | O                  | RS-485 Direction   | 1                                     |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) i represents a valid UART instance. See the device datasheet for available domains and UART instances.

**Note**

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

**12.2.4.2.3 IrDA Functional Interfaces**

**12.2.4.2.3.1 System Using IrDA Communication Protocol**

[Figure 12-92](#) shows an example connection of `MCU_UART0` to an external infrared transceiver in the IrDA modes (FIR, SIR, and MIR).

**Figure 12-92. IrDA Mode Interface Signals**

#### 12.2.4.2.3.2 IrDA Interface Description

Table 12-92 lists the IrDA interface I/O signals.

**Table 12-92. UART I/O Signals (IrDA Mode)**

| Module Pin | Device Level Signal | I/O <sup>(1)</sup> | Description                                                          | Module Pin Reset Value <sup>(2)</sup> |
|------------|---------------------|--------------------|----------------------------------------------------------------------|---------------------------------------|
| RX         |                     | I                  | Serial data input                                                    | HiZ                                   |
| TX         |                     | O                  | Serial data output in IrDA modes (SIR, MIR, and FIR). <sup>(3)</sup> | 0                                     |
| SD         |                     | O                  | SD mode is used to configure the transceivers. <sup>(4)</sup>        | 1                                     |
| RX         |                     | I                  | Serial data input                                                    | HiZ                                   |
| TX         |                     | O                  | Serial data output in IrDA modes (SIR, MIR, and FIR). <sup>(3)</sup> | 0                                     |
| SD         |                     | O                  | SD mode is used to configure the transceivers. <sup>(4)</sup>        | 1                                     |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) In other modes, this pin is set to the reset value (inactive state).

(4) The SD pinout (see [UART\\_ACREG\[6\] SD\\_MOD bit](#)).

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

#### 12.2.4.2.3.3 IrDA Protocol and Data Format

##### 12.2.4.2.3.3.1 SIR Mode

In SIR mode, data is transferred between the Host CPU and peripheral devices at speeds of up to 115.2 baud. A SIR transmit frame begins with start flags (a single 0xC0, a multiple 0xC0, or a single 0xC0 preceded by a number of 0xFF flags), followed by frame data and a CRC-16, and ends with a stop flag (0xC1).

The bit format for a single word uses 1 start-bit, 8 data bits, and 1 stop-bit, and is unaffected by the use and settings of the [UART\\_LCR](#) register.

The [UART\\_BLR\[6\] XBOF\\_TYPE](#) bit selects whether the 0xC0 or 0xFF start patterns are used when multiple start flags are required.

The SIR transmit state-machine attaches start flags, CRC-16, and stop flags, and checks the outgoing data to establish whether data transparency is required.

The SIR transparency is carried out if the outgoing data between the start and stop flags contains 0xC0, 0xC1, or 0x7D. If one of these start flags is about to be transmitted, the SIR state-machine sends an escape character (0x7D), inverts the fifth bit of the real data to be sent, and then sends this data immediately after the 0x7D character.

The SIR receive state-machine recovers the receive clock, removes the start flags and any transparency from the incoming data, and determines the frame boundary with reception of the stop flag. The SIR state-machine also checks for errors such as a frame abort (0x7D character followed immediately by a 0xC1 stop flag without transparency), a CRC error, or a frame-length error. At the end of a frame reception, the Host CPU reads the line status register ([UART\\_LSR\\_IRDA](#)) to find possible errors of the received frame.

#### Note

The module can transmit and receive data, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware. See the description of the [UART\\_ACREG\[5\] DIS\\_IR\\_RX](#) bit. This applies to all three modes: SIR, MIR, and FIR.

Infrared output in SIR mode can be 1.6- $\mu$ s or 3/16 encoding, selected by the UART\_ACREG[7] PULSE\_TYPE bit. In 1.6- $\mu$ s encoding, the infrared pulse width is 1.6  $\mu$ s; and in 3/16th encoding, the infrared pulse width is 3/16th of a bit duration (1/baud rate).

For back-to-back frames, the transmitting device must send at least two start flags at the start of each frame.

---

**Note**

Reception supports variable-length stop-bits.

---

#### 12.2.4.2.3.3.1.1 Frame Format

Figure 12-93 shows the IrDA SIR frame format.



**Figure 12-93. IrDA SIR Frame Format**

uart-006

The CRC is applied on the address (A), control (C), and information (I) bytes.

---

**Note**

The two words of CRC are written to the FIFO in reception.

---

#### 12.2.4.2.3.3.1.2 Asynchronous Transparency

Before transmitting a byte, the UART IrDA controller examines each byte of the payload and the CRC field (between BOF and EOF). For each byte equal to 0xC0 (BOF), 0xC1 (EOF), or 0x7D (control escape), the controller performs certain tasks:

- In transmission:
    - Inserts a control escape (CE) byte preceding the byte
    - Complements bit 5 of the byte (that is, exclusive ORs the byte with 0x20)
- The byte sent for the CRC computation is the initial byte written in the TX FIFO (before the XOR with 0x20).
- In reception:

For the A, C, I, and CRC fields:

- Compares the byte with the CE byte; if they are not equal, sends the byte to the CRC detector and stores it in the RX FIFO.
- If the byte is equal to the CE byte, discards the CE byte
- Complements bit 5 of the byte following the CE
- Sends the complemented byte to the CRC detector and stores it in the RX FIFO

#### 12.2.4.2.3.3.1.3 Abort Sequence

The transmitter can prematurely close a frame (abort) by sending the sequence 0x7DC1. The abort pattern closes the frame without a CRC field or an ending flag.

When a 0x7D character that is followed immediately by a 0xC1 character is received without transparency, the receiver treats the frame as an aborted frame.

#### 12.2.4.2.3.3.1.4 Pulse Shaping

The SIR mode supports the 3/16 and the 1.6- $\mu$ s pulse duration methods. The UART\_ACREG[7] PULSE\_TYPE bit selects the pulse-width method in transmit mode.

#### 12.2.4.2.3.3.1.5 Encoder

Serial data from the transmit state-machine are encoded to transmit data to the optoelectronics. While the TX FIFO output is high, the TX line is always low, and the counter used to form a pulse on TX is cleared continuously.

After the TX FIFO output resets to 0, TX rises on the falling edge of the seventh 16XCLK. On the falling edge of the tenth 16XCLK pulse, TX falls, creating a 3-clock-wide pulse. While the TX FIFO output stays low, a pulse is transmitted during the seventh clock to the tenth clock of each 16-clock bit cycle.

Figure 12-94 shows the IrDA SIR encoding mechanism.



**Figure 12-94. IrDA SIR Encoding Mechanism**

#### 12.2.4.2.3.3.1.6 Decoder

After reset, the RX FIFO input is high and the 4-bit counter is cleared. When a rising edge is detected on RX, the RX FIFO input falls on the next rising edge of 16XCLK with sufficient setup time. The RX FIFO input stays low for 16 cycles (16XCLK) and then returns to high as required by the IrDA specification. As long as no pulses (rising edges) are detected on the RX, the RX FIFO input remains high.

Figure 12-95 shows the IrDA SIR decoding mechanism.



uart-008

**Figure 12-95. IrDA SIR Decoding Mechanism**

The module can transmit and receive data, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware. The operation of the RX input can be disabled using the UART\_ACREG[5] DIS\_IR\_RX bit. The UART\_MDR2[6] IRRXINVERT bit can invert the signal from the transceiver (RX) pin to the IR RX logic in the UART. This inversion is performed by default.

#### 12.2.4.2.3.3.1.7 IR Address Checking

In all IR modes, when address checking is enabled by setting the UART\_EFR[1-0] bit field (see [Table 12-93](#)), only frames intended for the device are written to the RX FIFO. This is to avoid receiving frames not meant for this device in a multipoint infrared environment. To program two frame addresses that the UARTi receives in IrDA mode, use the UART\_XON1\_ADDR1[7-0] and UART\_XON2\_ADDR2[7-0] bit fields.

**Table 12-93. UART\_EFR[1-0] IR Address Checking Options**

| UART_EFR[1] | UART_EFR[0] | IR Address Checking                      |
|-------------|-------------|------------------------------------------|
| 0           | 0           | All address-checking operations disabled |
| 0           | 1           | Only address 1 checking enabled          |
| 1           | 0           | Only address 2 checking enabled          |
| 1           | 1           | All address-checking operations enabled  |

#### 12.2.4.2.3.3.2 SIR Free-Format Mode

To allow complete software flexibility when transmitting and receiving infrared data packets, the SIR free-format (FF) mode is a subfunction of the existing SIR mode. In FF mode, all frames going to and from the FIFO buffers are untouched with respect to appending and removing control characters and CRC values.

The FF mode corresponds to a UART mode with a pulse modulation of 3/16 of baud rate pulse width.

For example, a normal SIR packet has BOF control and CRC error-checking data appended (transmitting) or removed (receiving) from the data going to and from the FIFOs.

[Figure 12-96](#) shows SIR FF mode.



**Figure 12-96. SIR FF Mode**

In SIR FF mode, the Host CPU software must construct (that is, encode and decode) the entire FIFO data packet.

#### 12.2.4.2.3.3.3 MIR Mode

In MIR mode, data is transferred between the Host CPU and the peripheral devices at 0.576 Mbps or 1.152 Mbps. A MIR transmit frame starts with at least two start flags, followed by a frame data and a CRC-16, and ends with a stop flag (see Figure 12-97).



**Figure 12-97. MIR Transmit Frame Format**

On transmit, the MIR state-machine attaches start flags, a CRC-16, and stop flags, as in SIR mode. All fields are transmitted least-significant bit (LSB) of each byte first.

In MIR mode:

- The state-machine looks for consecutive 1s in the frame data and automatically inserts 0 after five consecutive 1s (this is called bit-stuffing).
- 0x7E is used for start and stop flags (unambiguously, not data, because of bit-stuffing).
- An abort sequence requires a minimum of seven consecutive 1s (unambiguously, not data, because of bit-stuffing).
- Back-to-back frames are allowed with three or more stop flags between them. If two consecutive frames are not back to back, the gap between the last stop flag of the first frame and the start flag of the second frame must be separated by at least seven bit durations.

On receive, the MIR receive state-machine recovers the receive clock, removes the start flags, destuffs the incoming data, and determines the frame boundary with reception of the stop flag. The state-machine also checks for errors such as frame abort, CRC error, and frame-length error. At the end of a frame reception, the Host CPU reads the line status register (UART\_LSR\_IRDA) to detect errors of the received frame.

The module can transmit and receive data, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware.

#### 12.2.4.2.3.3.3.1 MIR Encoder/Decoder

To meet the MIR baud rate tolerance of 0.1 percent with a 48-MHz clock input, a 42-41-42 encoding/decoding adjustment is performed. The reference start point is the first start flag, and the 42-41-42 cyclic pattern is repeated until the stop flag is sent or detected.

The jitter created this way is within MIR tolerances. The pulse width is not exactly 1/4, but it is within the tolerances defined by IrDA specifications.

Figure 12-98 shows the MIR baud rate adjustment mechanism.



Figure 12-98. MIR Baud Rate Adjustment Mechanism

#### 12.2.4.2.3.3.3.2 SIP Generation

In the MIR and FIR operation modes, the transmitter must send a serial infrared interaction pulse (SIP) at least once every 500 ms. The SIP informs slow devices (operating in SIR mode) that the medium is occupied.

Figure 12-99 shows the SIP.



Figure 12-99. SIP

#### 12.2.4.2.3.3.4 FIR Mode

In FIR mode, data is transferred between the Host CPU and the peripheral devices at 4 Mbps. A FIR transmit frame starts with a preamble that is followed by a start flag, frame data, CRC-32, and ends with a stop flag.

Figure 12-100 shows the FIR transmit frame format.

Figure 12-100. FIR Transmit Frame Format

|                |            |            |        |           |
|----------------|------------|------------|--------|-----------|
| Preamble (16x) | Start flag | Frame data | CRC-32 | Stop flag |
|----------------|------------|------------|--------|-----------|

On transmit, the FIR transmit state-machine attaches the preamble, start flag, CRC-32, and stop flag. An abort sequence requires at least two transmissions of 0000. Back-to-back frames are allowed, but each frame must be complete.

The state-machine also encodes the transmit data into 4-PPM format (see [Table 12-94](#)) and generates the SIP (see [Section 12.2.4.2.3.3.3.2, SIP Generation](#)).

**Table 12-94. 4-PPM Format**

| Data Bit Pair (Bin) | 4-PPM Data Symbol (Bin) |
|---------------------|-------------------------|
| 00                  | 1000                    |
| 01                  | 0100                    |
| 10                  | 0010                    |
| 11                  | 0001                    |

The four symbols described in [Table 12-94](#) are the legal, encoded data symbols. All other combinations are illegal for encoding data. Some of these illegal symbols are used in the definition of the preamble, start flag, and stop flag because they are unambiguously not data (see [Table 12-95](#)).

**Table 12-95. FIR Preamble, Start Flag, and Stop Flag**

| Frame Part | Transmitted Frame (Bin)                         |
|------------|-------------------------------------------------|
| Preamble   | 1000 0000 1010 1000 (16 repeated transmissions) |
| Start flag | 0000 1100 0000 1100 0110 0000 0110 0000         |
| Stop flag  | 0000 1100 0000 1100 0000 0110 0000 0110         |

All fields are transmitted LSBs of each byte first (see [Table 12-96](#)).

**Table 12-96. FIR Data Byte Transmission Order Example**

| Data Byte (Hex) | Data Byte Pair (Bin) | 4-PPM Data Symbol (Bin) | Transmission Order |
|-----------------|----------------------|-------------------------|--------------------|
| 0x0B            | 00                   | 1000                    | 4                  |
|                 | 00                   | 1000                    | 3                  |
|                 | 10                   | 0010                    | 2                  |
|                 | 11                   | 0001                    | 1                  |

On receive, the FIR receive state-machine recovers the receive clock, removes the preamble and the start flag, decodes the 4-PPM incoming data, and determines the frame boundary with reception of the stop flag. The state-machine also checks for errors such as illegal symbol, CRC error, and frame-length error. At the end of a frame reception, the Host CPU reads the line status register (UART\_LSR\_IRDA) to detect errors of the received frame.

The module can transmit and receive data, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware.

#### 12.2.4.2.4 CIR Functional Interfaces

##### 12.2.4.2.4.1 System Using CIR Communication Protocol With Remote Control

All UART modules can be connected to an external infrared transceiver in CIR mode. [Figure 12-101](#) shows an example connection of MCU\_UART0 in CIR mode.

**Figure 12-101. CIR Mode Interface Signals**

##### 12.2.4.2.4.2 CIR Interface Description

[Table 12-97](#) lists the CIR interface I/O signals.

**Table 12-97. UART I/O Signals (CIR Mode)**

| Module Pin       | Device Level Signal | I/O <sup>(1)</sup> | Description                                                   | Module Pin Reset Value <sup>(2)</sup> |
|------------------|---------------------|--------------------|---------------------------------------------------------------|---------------------------------------|
| RX               |                     | I                  | Serial data input                                             | HiZ                                   |
| TX               |                     | O                  | Serial data output in CIR mode. <sup>(3)</sup>                | 0                                     |
| SD               |                     | O                  | SD mode is used to configure the transceivers. <sup>(4)</sup> | 1                                     |
| <b>UART[0-9]</b> |                     |                    |                                                               |                                       |
| RX               |                     | I                  | Serial data input                                             | HiZ                                   |
| TX               |                     | O                  | Serial data output in CIR mode. <sup>(3)</sup>                | 0                                     |
| SD               |                     | O                  | SD mode is used to configure the transceivers. <sup>(4)</sup> | 1                                     |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) In other modes, this pin is set to the reset value (inactive state).

(4) The SD pinout is an inverted value of the UART\_ACREG[6] SD\_MOD bit.

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

#### 12.2.4.2.4.3 CIR Protocol and Data Format

In CIR mode, the infrared operation functions as a programmable (universal) remote control.

The CIR mode uses a variable PWM technique (based on multiples of a programmable  $t$  period) to encompass the various formats of infrared encoding for remote-control applications. The CIR logic transmits data packets based on user-defined frame structure and packet content.

##### 12.2.4.2.4.3.1 Carrier Modulation

Each modulated pulse that constitutes a digit is a train of on/off pulses (see [Figure 12-102](#)).



**Figure 12-102. CIR Pulse Modulation**

#### 12.2.4.2.4.3.2 Pulse Duty Cycle

The programmer can choose one of four duty cycles for modulation pulses by setting the appropriate value in the `UART_MDR2[5-4]` `CIR_PULSE_MODE` bit field (1/4, 1/3, 5/12, or 1/2).

Figure 12-103 shows the CIR modulation duty cycles.



**Figure 12-103. CIR Modulation Duty Cycle**

The transmission logic ensures that all pulses are transmitted completely (no cutoff during transmission). While transmitting continuous bytes back-to-back, no delay is inserted between 2 transmitted bytes. Thus, software must handle the delay between consecutively transmitted bytes if the receiving end requires it.

#### 12.2.4.2.4.3.3 Consumer IR Encoding/Decoding

There are two methods of encoding for remote-control applications:

- Pulse duration encoding (time-extended bit forms): A variable pulse distance, or duration, in which the difference between logic 1 and logic 0 is the length of the pulse width
- Biphase encoding: The encoding of logic 0 and logic 1 is in the change of signal level from 1 to 0 or 0 to 1, respectively.

Japanese manufacturers favor pulse duration encoding; European manufacturers favor biphase encoding.

CIR mode uses a completely flexible free-format encoding in which 1 is transmitted from the TX FIFO as a modulated pulse with duration  $t$ .

Similarly, 0 is transmitted as a blank duration  $T$ . The Host CPU constructs and deciphers the protocol of the data. For example, the RC-5 protocol using Manchester encoding can be emulated as using a 01 pair for 1 and a 10 pair for 0 (see [Figure 12-104](#)).



**Figure 12-104. UART RC-5 Bit Encoding**

Because CIR mode logic does not impose a fixed format for infrared packets of data, the Host CPU software can define the format using simple data structures that are then modulated into an industry standard, such as RC-5 or SIRC. To send a sequence of 0101 in RC-5, the Host CPU software must write an 8-bit binary character of 10011001 to the data FIFO of the UART.

For SIRC, the modulation length (multiples of  $t$ ) is used to distinguish between 1 and 0. The subsequent SIRC digits show the difference in encoding between this and, for example, RC-5. The pulse width is extended for one digit.

[Figure 12-105](#) shows SIRC bit encoding.



**Figure 12-105. UART SIRC Bit Encoding**

To construct comprehensive packets constituting remote-control commands, the Host CPU software must combine a number of 8-bit data characters in a sequence that follows one of the universally accepted formats.

Figure 12-106 shows a standard RC-5 frame as detected by UART in CIR mode (the SIRC format follows this). Each field in RC-5 can be considered as two  $t$  pulses (digital bits) from the TX FIFO.



uart-018

**Figure 12-106. UART RC-5 Standard Packet Format**

Where:

- S1, S2: Start-bits (always 1)
- T: Toggle bit
- A4..A0: Address (or system) bits
- C5..C0: Command bits

The toggle bit T changes when a new command is transmitted to detect when the same key is pressed twice (effectively receiving the same data from the host consecutively). A brief delay in the transmission of the same command is detected by the use of the toggle bit because a code is sent while the Host CPU transmits characters to the UART for transmission. The address bits define the machine or device for which the infrared transmission is intended, and the command defines the operation.

To accommodate an extended RC-5 format, the S2 bit is replaced by an additional command bit (C6) that lets the command range increase to 7 bits. This format is known as the extended RC-5 format.

The SIRC encoding uses the duration of modulation for mark and space; therefore, the duration of data bits in the standard frame length varies.

Figure 12-107 shows the packet format and bit encoding. As Figure 12-108 shows, 1 start-bit of 2.4 ms and control codes are followed by data that constitute the entire frame.



uart-019

**Figure 12-107. UART SIRC Packet Format**

**Note**

The encoding must take a standard duration, but the contents of the data can vary. This implies that the control software for sending and receiving data packets must exercise a scheme of interpacket delay, where successive packets can be sent only after a real-time delay expires.



**Figure 12-108. UART SIRC Bit Transmission Example**

**Note**

This document does not describe all encoding methods and techniques; the previous information discusses the considerations required to employ different encoding methods for different industry-standard protocols. See industry-standard documentation for specific methods of encoding and protocol use.

#### 12.2.4.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.2.4.4 UART Functional Description

##### 12.2.4.4.1 UART Block Diagram

The UART module can be divided into three main blocks:

- FIFO management
- Mode selection
- Protocol formatting

FIFO management is common to all functions and enables the transmission and reception of data from the host processor point of view.

There are two modes:

- Function mode: Routes the data to the chosen function (UART, RS-485, IrDA, or CIR) and enables the mechanism corresponding to the chosen function.
- Register mode: Enables conditional access to registers.

For more information about mode configuration, see [Section 12.2.4.4.7, Mode Selection](#).

Protocol formatting has three subcategories:

- Clock generation: The 48-MHz input clock generates all necessary clocks.
- Data formatting: Each function uses its own state-machine that is responsible for the transition between FIFO data and frame data associated with it.
- Interrupt management: Different interrupt types are generated depending on the chosen function. In each mode, when an interrupt is generated, the `UART_IIR_UART` register indicates the interrupt type.
  - UART mode interrupts: Seven interrupts prioritized in six different levels
  - IrDA mode interrupts: Eight interrupts. The interrupt line is activated when any interrupt is generated (there is no priority).
  - CIR mode interrupts: A subset of existing IrDA mode interrupts is used.

In parallel with these functional blocks, a power-saving strategy exists for each function.

Figure 12-109 is the UART block diagram.



**Figure 12-109. UART Functional Block Diagram**

#### 12.2.4.4.2 UART Clock Configuration

Each UART uses a 48-MHz functional clock for its logic and to generate external interface signals. Each UART uses an interface clock for register accesses.

#### 12.2.4.4.3 UART Software Reset

The UART\_SYSC[1] SOFTRESET bit controls the software reset; setting this bit to 1 triggers a software reset functionally equivalent to hardware reset.

#### 12.2.4.4.3.1 Independent TX/RX

The receiver and transmitter are enabled by default after reset. Software can choose to disable, re-enable or to reset either the RX or the TX side independently of the other through the UART\_ECR register.

#### 12.2.4.4.4 UART Power Management

##### 12.2.4.4.4.1 UART Mode Power Management

###### 12.2.4.4.4.1.1 Module Power Saving

In UART modes, sleep mode is enabled by setting the UART\_IER\_UART[4] SLEEP\_MODE bit to 1 (when the UART\_EFR[4] ENHANCED\_EN bit is set to 1).

Sleep mode is entered when all of the following conditions exist:

- The serial data input line, RX, is idle.
- The TX FIFO and TX shift register are empty.
- The RX FIFO is empty.
- The only pending interrupts are THR interrupts.

Sleep mode is a good way to lower UART power consumption, but this state can be achieved only when the UART is set to modem mode. Therefore, even if the UART has no key role functionally, it must be initialized in a functional mode to take advantage of sleep mode.

In sleep mode, the module clock and baud rate clock are stopped internally. Because most registers are clocked by these clocks, this greatly reduces power consumption. The module wakes up when a change is detected on the RX line, when data is written to the TX FIFO, and when there is a change in the state of the modem input pins.

An interrupt can be generated on a wake-up event by setting the UART\_SCR[4] RX\_CTS\_WU\_EN bit to 1. To understand how to manage the interrupt, see [Section 12.2.4.4.5.1.2, Wake-Up Interrupt](#).

---

#### Note

There must be no writing to the divisor latches, UART\_DLL and UART\_DLH, to set the baud clock (BCLK) while in sleep mode. It is advisable to disable sleep mode using the UART\_IER\_UART[4] SLEEP\_MODE bit before writing to the UART\_DLL or UART\_DLH register.

#### 12.2.4.4.4.1.2 System Power Saving

Sleep and auto-idle modes are embedded power-saving features. Power-reduction techniques can be applied at the system level by shutting down certain internal clock and power domains of the device.

The UART supports an idle req/idle ack handshaking protocol used at the system level to shut down the UART clocks in a clean and controlled manner and to switch the UART from interrupt-generation mode to wake-up generation mode for unmasked events (see the UART\_SYSC[2] ENAWAKEUP bit and the UART\_WER register).

For more information, see *Power in the Device Configuration*.

#### 12.2.4.4.4.2 IrDA Mode Power Management

##### 12.2.4.4.4.2.1 Module Power Saving

In IrDA modes, sleep mode is enabled by setting the UART\_MDR1[3] IR\_SLEEP bit to 1.

Sleep mode is entered when all of the following conditions exist:

- The serial data input line, RXD, is idle.
- The TX FIFO and TX shift register are empty.
- The RX FIFO is empty.
- No interrupts are pending except THR interrupts.

The module wakes up when a change is detected on the RXD line or when data is written to the TX FIFO.

#### 12.2.4.4.2.2 System Power Saving

System power saving for the IrDA mode has the same function as for the UART mode (see [Section 12.2.4.4.1.2, System Power Saving](#)).

#### 12.2.4.4.3 CIR Mode Power Management

##### 12.2.4.4.3.1 Module Power Saving

Module power saving for the CIR mode has the same function as for the IrDA mode (see [Section 12.2.4.4.2.1, Module Power Saving](#)).

##### 12.2.4.4.3.2 System Power Saving

System power saving for the CIR mode has the same function as for the UART mode (see [Section 12.2.4.4.1.2, System Power Saving](#)).

#### 12.2.4.4.4 Local Power Management

[Table 12-98](#) describes power-management features available for the UART.

##### Note

For information about source clock gating and the sleep/wake-up transitions description, see *Power in the Device Configuration*.

**Table 12-98. UART Local Power-Management Features**

| Feature                  | Registers               | Description                                                                                                                                           |
|--------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock autogating         | UART_SYSC[0] AUTOIDLE   | This bit allows local power optimization in the module by gating the clock on interface activity or gating the UARTi_FCLK clock on internal activity. |
| Peripheral idle modes    | UART_SYSC[4-3] IDLEMODE | Force-idle, no-idle, smart-idle, and smart-idle wakeup-capable modes are available.                                                                   |
| Clock activity           | N/A                     | Feature not available                                                                                                                                 |
| Controller standby modes | N/A                     | Feature not available                                                                                                                                 |
| Global wake-up enable    | UART_SYSC[2] ENAWAKEUP  | This bit enables the wake-up feature at module level.                                                                                                 |
| Wake-Up sources enable   | N/A                     | Feature not available                                                                                                                                 |

#### 12.2.4.4.5 UART Interrupt Requests

##### 12.2.4.4.5.1 UART Mode Interrupt Management

###### 12.2.4.4.5.1.1 UART Interrupts

The UART mode includes seven possible interrupts prioritized to six levels.

When an interrupt is generated, the interrupt identification register (UART\_IIR\_UART) sets the UART\_IIR\_UART[0] IT\_PENDING bit to 0 to indicate that an interrupt is pending, and indicates the type of interrupt through the UART\_IIR\_UART[5-1] bit field. [Table 12-99](#) summarizes the interrupt control functions.

**Table 12-99. UART Mode Interrupts**

| IIR[5:0] | Priority Level | Interrupt Type | Interrupt Source | Interrupt Reset Method |
|----------|----------------|----------------|------------------|------------------------|
| 000001   | N/A            | No Interrupt   | N/A              | N/A                    |

Table 12-99. UART Mode Interrupts (continued)

| IIR[5:0] | Priority Level | Interrupt Type                                 | Interrupt Source                                                                | Interrupt Reset Method                                                                                         |
|----------|----------------|------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| 000110   | 1              | Receiver line status                           | OE, FE, PE, or BI errors occur in characters in the RX FIFO.                    | FE, PE, BI: Read the UART_RHR register. OE: Read the UART_LSR_UART register.                                   |
| 001100   | 2              | RX time-out                                    | Stale data in RX FIFO                                                           | Read the UART_RHR register.                                                                                    |
| 000100   | 2              | RHR interrupt                                  | DRDY (data ready) (FIFO disabled)<br>RX FIFO above trigger level (FIFO enabled) | Read the UART_RHR register until the interrupt condition disappears                                            |
| 000010   | 3              | THR interrupt                                  | TFE (THR empty) (FIFO disabled)<br>TX FIFO below trigger level (FIFO enabled)   | Write to the UART_THR until the interrupt condition disappears                                                 |
| 000000   | 4              | Modem status                                   | See the UART_MSR register.                                                      | Read the MSR register                                                                                          |
| 010000   | 5              | XOFF interrupt/<br>special character interrupt | Receive XOFF characters/special character                                       | Receive XON character(s), if XOFF interrupt/read of the UART_IIR_UART register, if special character interrupt |
| 100000   | 6              | CTS, RTS                                       | RTS pin or CTS pin change state from active (low) to inactive (high)            | Read the UART_IIR_UART register                                                                                |

For the receiver-line status interrupt, the UART\_LSR\_UART[7] RX\_FIFO\_STS bit generates the interrupt.

For the XOFF interrupt, if an XOFF flow character detection caused the interrupt, the interrupt is cleared by an XON flow character detection. If special character detection caused the interrupt, the interrupt is cleared by a read of the UART\_IIR\_UART register.

#### 12.2.4.4.5.1.2 Wake-Up Interrupt

Wake-up interrupt is a special interrupt that works differently from other interrupts. This interrupt is enabled when the UART\_SCR[4] RX\_CTS\_WU\_EN bit is set to 1. The UART\_IIR\_UART register is not modified when this occurs; the UART\_SSR[1] RX\_CTS\_WU\_STS bit must be checked to detect a wake-up event.

When a wake-up interrupt occurs, it can be cleared only by resetting the UART\_SCR[4] RX\_CTS\_WU\_EN bit. This bit must be reenabled (set to 1) after the current wake-up interrupt event is processed to detect the next incoming wake-up event.

#### 12.2.4.4.5.2 IrDA Mode Interrupt Management

##### 12.2.4.4.5.2.1 IrDA Interrupts

The IrDA function generates interrupts. All interrupts can be enabled and disabled by writing to the appropriate bit in the interrupt enable register (UART\_IER\_IRDA). The interrupt status of the device can be checked by reading the interrupt identification register (UART\_IIR\_IRDA).

The UART, IrDA, and CIR modes have different interrupts in the UART module and, therefore, different UART\_IER\_IRDA and UART\_IIR\_IRDA mappings, depending on the selected mode.

The IrDA modes have eight possible interrupts (see Table 12-100). The interrupt line is activated when any interrupt is generated (there is no priority).

Table 12-100. IrDA Mode Interrupts

| IIR_IRDA Bit | Interrupt Type        | Interrupt Source                                                                   | Interrupt Reset Method                                               |
|--------------|-----------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| 0            | RHR interrupt         | DRDY (data ready) (FIFO disabled)<br>RX FIFO above trigger level (FIFO enabled)    | Read the UART_RHR register until the interrupt condition disappears. |
| 1            | THR interrupt         | TFE (UART_THR empty) (FIFO disabled)<br>TX FIFO below trigger level (FIFO enabled) | Write to the UART_THR until the interrupt condition disappears.      |
| 2            | Last byte in RX FIFO  | Last byte of frame in RX FIFO is available to be read at the UART_RHR port.        | Read the UART_RHR register.                                          |
| 3            | RX overrun            | Write to the UART_RHR register when the RX FIFO is full.                           | Read UART_RESUME register.                                           |
| 4            | Status FIFO interrupt | Status FIFO triggers level reached.                                                | Read STATUS FIFO.                                                    |

**Table 12-100. IrDA Mode Interrupts (continued)**

| IIR_IRDA Bit | Interrupt Type                 | Interrupt Source                                                                                                                                                                                | Interrupt Reset Method                                                     |
|--------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 5            | TX status                      | UART_THR empty before EOF sent. Last bit of transmission of the IrDA frame occurred, but with an underrun error<br>OR<br>Transmission of the last bit of the IrDA frame completed successfully. | Read the UART_RESUME register<br>OR<br>Read the UART_IIR_IRDA register.    |
| 6            | Receiver line status interrupt | CRC, ABORT, or frame-length error is written into the STATUS FIFO.                                                                                                                              | Read the STATUS FIFO (read until empty - maximum of eight reads required). |
| 7            | Received EOF                   | Received end-of-frame                                                                                                                                                                           | Read the UART_IIR_IRDA register.                                           |

#### 12.2.4.4.5.2.2 Wake-Up Interrupts

The wake-up interrupt for IrDA mode has the same function as that for UART mode (see [Section 12.2.4.4.5.1.2, Wake-Up Interrupt](#)).

#### 12.2.4.4.5.3 CIR Mode Interrupt Management

##### 12.2.4.4.5.3.1 CIR Interrupts

The CIR function generates interrupts that can be enabled and disabled by writing to the appropriate bit in the interrupt enable register (UART\_IER\_CIR). The interrupt status of the device can be checked by reading the interrupt identification register (UART\_IIR\_CIR).

The UART, IrDA, and CIR modes have different interrupts in the UART module and, therefore, different UART\_IER\_CIR and UART\_IIR\_CIR mappings, depending on the selected mode.

**Table 12-101** lists the interrupt modes to be maintained. In CIR mode, the sole purpose of the UART\_IIR\_CIR[5] TX\_STATUS\_IT bit is to indicate that the last bit of infrared data was passed to the TX pin.

**Table 12-101. CIR Mode Interrupts**

| IIR_CIR Bit Number | Interrupt Type   | Interrupt Source                                                              | Interrupt Reset Method                                                  |
|--------------------|------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| 0                  | N/A for CIR mode | N/A for CIR mode                                                              | N/A for CIR mode                                                        |
| 1                  | THR interrupt    | TFE (THR empty) (FIFO disabled)<br>TX FIFO below trigger level (FIFO enabled) | Write to the UART_THR register until the interrupt condition disappears |
| 2                  | N/A for CIR mode | N/A for CIR mode                                                              | N/A for CIR mode                                                        |
| 3                  | N/A for CIR mode | N/A for CIR mode                                                              | N/A for CIR mode                                                        |
| 4                  | N/A for CIR mode | N/A for CIR mode                                                              | N/A for CIR mode                                                        |
| 5                  | TX status        | Transmission of the last bit of the frame is complete successfully            | Read the UART_IIR_CIR register                                          |
| 6                  | N/A for CIR mode | N/A for CIR mode                                                              | N/A for CIR mode                                                        |
| 7                  | N/A for CIR mode | N/A for CIR mode                                                              | N/A for CIR mode                                                        |

##### 12.2.4.4.5.3.2 Wake-Up Interrupts

The wake-up interrupt for CIR mode has the same function as that for UART mode (see [Section 12.2.4.4.5.1.2, Wake-Up Interrupt](#)).

#### 12.2.4.4.6 UART FIFO Management

The FIFO is accessed by reading and writing the UART\_RHR and UART\_THR registers. Parameters are controlled using the FIFO control register (UART\_FCR) and supplementary control register (UART\_SCR). Reading the UART\_SSR[0] TX\_FIFO\_FULL bit at 1 means the FIFO is full.

The UART\_TLR register controls the FIFO trigger level, which enables DMA and interrupt generation. After reset, transmit (TX) and receive (RX) FIFOs are disabled; thus, the trigger level is the default value of 1 byte. [Figure 12-110](#) shows the FIFO management registers.

**Note**

Data in the UART\_RHR register is not overwritten when an overflow occurs.

**Note**

The UART\_SFSLR, UART\_SFREGL, and UART\_SFREGH status registers are used in IrDA mode only. For information about their use, see [Section 12.2.4.4.8.3.3, IrDA Data Formatting](#).

**Note**

Bits UART\_FCR[2] TX\_FIFO\_CLEAR and UART\_FCR[1] RX\_FIFO\_CLEAR are automatically cleared by hardware after  $4 \times + 5 \times$  UART<sub>i</sub>\_FCLK clock cycles. This delay is needed to finish the resetting of the corresponding FIFO and DMA control registers.



uart-023

**Figure 12-110. UART FIFO Management Registers**

#### 12.2.4.4.6.1 FIFO Trigger

##### 12.2.4.4.6.1.1 Transmit FIFO Trigger

Table 12-102 lists the TX FIFO trigger level settings.

**Table 12-102. UART TX FIFO Trigger Level Setting Summary**

| SCR[6] | TLR[3:0] | TX FIFO Trigger Level                                                                                                                                                                                                                                                                                                   |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | = 0x0    | Defined by the UART_FCR[5-4] TX_FIFO_TRIG bit field (8,16, 32, or 56 spaces)                                                                                                                                                                                                                                            |
| 0      | != 0x0   | Defined by the UART_TLR[3-0] TX_FIFO_TRIG_DMA bit field (from 4 to 60 spaces with a granularity of 4 spaces)                                                                                                                                                                                                            |
| 1      | Value    | Defined by the concatenated value of TX_FIFO_TRIG_DMA and TX_FIFO_TRIG (from 1 to 63 spaces with a granularity of 1 space)<br><br><b>Note:</b> The combination of TX_FIFO_TRIG_DMA = 0x0 and TX_FIFO_TRIG = 0x0 (all zeros) is not supported (minimum of 1 space required). All zeros result in unpredictable behavior. |

##### 12.2.4.4.6.1.2 Receive FIFO Trigger

Table 12-103 lists the RX FIFO trigger-level settings.

**Table 12-103. UART RX FIFO Trigger-Level Setting Summary**

| SCR[7] | TLR[7:4] | RX FIFO Trigger Level                                                                                                                                                                                                                                                                                                               |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | = 0x0    | Defined by the UART_FCR[7-6] RX_FIFO_TRIG bit field (8,16, 56, or 60 characters)                                                                                                                                                                                                                                                    |
| 0      | != 0x0   | Defined by the UART_TLR[7-4] RX_FIFO_TRIG_DMA bit field (from 4 to 60 characters with a granularity of 4 characters)                                                                                                                                                                                                                |
| 1      | Value    | Defined by the concatenated value of RX_FIFO_TRIG_DMA and RX_FIFO_TRIG (from 1 to 63 characters with a granularity of 1 character)<br><br><b>Note:</b> The combination of RX_FIFO_TRIG_DMA = 0x0 and RX_FIFO_TRIG = 0x0 (all zeros) is not supported (minimum of 1 character required). All zeros result in unpredictable behavior. |

The receive threshold is programmed using the UART\_TCR[7-4] RX\_FIFO\_TRIG\_START and UART\_TCR[3-0] RX\_FIFO\_TRIG\_HALT bit fields:

- Trigger levels from 0 to 60 bytes are available with a granularity of 4 (trigger level = 4 × [4-bit register value]).
- To ensure correct device operation, ensure that RX\_FIFO\_TRIG\_HALT > RX\_FIFO\_TRIG when auto-RTS is enabled.

$$\text{Delay} = [4 + 16 \times (1 + \text{CHAR\_LENGTH} + \text{Parity} + \text{Stop} - 0.5)] \times \text{Baud\_rate} + 4 \times \text{FCLK}$$

#### Note

The RTS signal is deasserted after the UART module receives the data over RX\_FIFO\_TRIG\_HALT.

Delay means how long the UART module takes to deassert the RTS signal after reaching RX\_FIFO\_TRIG\_HALT.

- In FIFO interrupt mode with flow control, ensure that the trigger level to HALT transmission is greater than or equal to the RX FIFO trigger level (the UART\_TCR[7-4] RX\_FIFO\_TRIG\_START bit field or the UART\_FCR[7-6] RX\_FIFO\_TRIG bit field); otherwise, FIFO operation stalls. In FIFO DMA mode with flow control, this concept does not exist, because a DMA request is sent when a byte is received.

#### 12.2.4.4.6.2 FIFO Interrupt Mode

In FIFO interrupt mode (the FIFO control register UART\_FCR[0] FIFO\_EN bit is set to 1 and relevant interrupts are enabled by the UART\_IER\_UART register), an interrupt signal informs the processor of the status of the receiver and transmitter. These interrupts are raised when the RX/TX FIFO threshold (the UART\_TLR[7-4] RX\_FIFO\_TRIG\_DMA and UART\_TLR[3-0] TX\_FIFO\_TRIG\_DMA bit fields or the UART\_FCR[7-6] RX\_FIFO\_TRIG and UART\_FCR[5-4] TX\_FIFO\_TRIG bit fields, respectively) is reached.

The interrupt signals instruct the Host CPU to transfer data to the destination (from the UART in receive mode and/or from any source to the UART FIFO in transmit mode).

When UART flow control is enabled with interrupt capabilities, the UART flow control FIFO threshold (the `UART_TCR[3-0] RX_FIFO_TRIG_HALT` bit field) must be greater than or equal to the RX FIFO threshold.

Figure 12-111 shows the generation of the RX FIFO interrupt request.



**Figure 12-111. UART RX FIFO Interrupt Request Generation**

In receive mode, no interrupt is generated until the RX FIFO reaches its threshold. Once low, the interrupt can be deasserted only when the Host CPU has handled enough bytes to put the FIFO level below threshold. The flow control threshold is set at a higher value than the FIFO threshold.

Figure 12-112 shows the generation of the TX FIFO interrupt request.



**Figure 12-112. UART TX FIFO Interrupt Request Generation**

In transmit mode, an interrupt request is automatically asserted when the TX FIFO is empty. This request is deasserted when the TX FIFO crosses the threshold level. The interrupt line is deasserted until a sufficient number of elements is transmitted to go below the TX FIFO threshold.

#### 12.2.4.4.6.3 FIFO Polled Mode Operation

In FIFO polled mode (the `UART_FCR[0]` `FIFO_EN` bit is set to 0 and the relevant interrupts are disabled by the `UART_IER_UART` register), the status of the receiver and transmitter can be checked by polling the line status register (`UART_LSR_UART`).

This mode is an alternative to the FIFO interrupt mode of operation in which the status of the receiver and transmitter is automatically determined by sending interrupts to the Host CPU.

#### 12.2.4.4.6.4 FIFO DMA Mode Operation

Although the DMA operation includes four modes (DMA modes 0 through 3), the information in *UART Hardware Requests*, assumes that mode 1 is used. (Mode 2 and mode 3 are legacy modes that use only one DMA request for each module.)

In mode 2, the remaining DMA request is used for RX. In mode 3, the remaining DMA request is used for TX.

DMA requests in mode 2 and mode 3 use the signals (where  $i = 0$  to  $3$ ).

signals are not used by the module in mode 2 and mode 3:

The DMA mode and signals usage can be selected as follows:

- When the `UART_SCR[0]` `DMA_MODE_CTL` bit is set to 0, setting the `UART_FCR[3]` `DMA_MODE` bit to 0 enables DMA mode 0. Setting the `UART_FCR[3]` `DMA_MODE` bit to 1 enables DMA mode 1.
- When the `UART_SCR[0]` `DMA_MODE_CTL` bit is set to 1, the `UART_SCR[2-1]` `DMA_MODE_2` bit field determines DMA mode 0 to mode 3 based on the supplementary control register (`UART_SCR`) description.

For example:

- If no DMA operation is desired, set the `UART_SCR[0]` `DMA_MODE_CTL` bit to 1 and the `UART_SCR[2-1]` `DMA_MODE_2` bit field to 0x0. (The `DMA_MODE` bit is discarded.)
- If DMA mode 1 is desired, set the `UART_SCR[0]` `DMA_MODE_CTL` bit to 0 and the `UART_FCR[3]` `DMA_MODE` bit to 1, or set the `UART_SCR[0]` `DMA_MODE_CTL` bit to 1 and the `UART_SCR[2-1]` `DMA_MODE_2` bit field to 01. (The `UART_FCR[3]` `DMA_MODE` bit is discarded.)

If the FIFOs are disabled (the `UART_FCR[0]` `FIFO_EN` bit is set to 0), the DMA occurs in single-character transfers.

When DMA mode 0 is programmed, the signals associated with DMA operation are not active.

Depending on `UART_MDR3[2]` `SET_DMA_TX_THRESHOLD`, the threshold can be programmed different ways:

- `SET_TX_DMA_THRESHOLD` = 1:

The threshold value will be the value of the `UART_TX_DMA_THRESHOLD` register. If `SET_TX_DMA_THRESHOLD` + TX trigger spaces 64, then the default method of threshold is used: threshold value = TX FIFO size.

- `SET_TX_DMA_THRESHOLD` = 0:

The threshold value = TX FIFO size TX trigger space. The TX DMA line is asserted if the TX FIFO level is lower than the threshold. It remains asserted until TX trigger spaces number of bytes are written into the FIFO. The DMA line is then deasserted and the FIFO level is compared with the threshold value.

#### 12.2.4.4.6.4.1 DMA sequence to disable TX DMA

In order to disable TX DMA if it is not needed anymore (e.g. all transfers are done and UART idle mode is desired), the following sequence must be used

1. DMA mode 1 is set (both TX/RX DMA) by registers `UART_SCR[0]` `DMA_MODE_CTL` = 0 and `UART_FCR[3]` `DMA_MODE` = 1:
  - a. Set the `UART_SCR[2-1]` `DMA_MODE_2` bit fields to 01 (DMA mode 1)
  - b. Set the `UART_SCR[0]` `DMA_MODE_CTL` bit to 1 (this setting of `UART_SCR[0]` `DMA_MODE_CTL` will ignores `UART_FCR[3]` `DMA_MODE_CTL` bit)

---

### Note

It is strongly suggested to do steps 'a' and 'b' in two separate write in order to avoid malfunction of the device.

- c. Set the UART\_FCR[3] DMA\_MODE bit to 0. It is not necessary but suggested to avoid restore of DMA mode 1 during accidental reset of UART\_SCR[0] DMA\_MODE\_CTL bit. Be sure that all data was read out from RX FIFO and if it possible disable the RX side. In UART mode the RTS/CTS or XOFF/XON protocol can be used. In IrDA modes RX can be forcibly disabled by setting UART\_ACREG[5] DIS\_IR\_RX bit
- 

### Note

There can be RX DATA loss during the next steps if all DATA was not read out or there was an ongoing reception!

- d. Set the UART\_FCR[2-1] DMA\_MODE bit field to 11 (clear TX and RX FIFO and resets its counter logic to 0. Returns to 0 after clearing FIFO).
  - e. Set the UART\_SCR[2-1] DMA\_MODE\_2 bit field to 10 (DMA mode 2, RX only).
  - f. Set the UART\_FCR[2-1] DMA\_MODE bit field to 11 (clear TX and RX FIFO and the DMA request again).
  - g. Set the UART\_SCR[2-1] DMA\_MODE\_2 bit field to 00 (no DMA) or keep 10 if RX DMA is needed.
2. DMA mode 1 is set (both TX/RX DMA) by registers UART\_FCR[3] DMA\_MODE = 0 and UART\_SCR[0] DMA\_MODE\_CTL = 1, UART\_SCR[2-1] DMA\_MODE\_2 = 01. It is almost the same as above, but steps 'a', and 'b' can be skipped:
- a. Set the UART\_FCR[3] DMA\_MODE bit to 0. It is not necessary but suggested to avoid restore of DMA mode 1 during accidental reset of UART\_SCR[0] DMA\_MODE\_CTL bit. Be sure that all data was read out from RX FIFO and if it possible disable the RX side. In UART mode the RTS/CTS or XOFF/XON protocol can be used. In IrDA modes RX can be forcibly disabled by setting UART\_ACREG[5] DIS\_IR\_RX bit
- 

### Note

There can be RX DATA loss during the next steps if all DATA was not read out or there was an ongoing reception!

- b. Set the UART\_FCR[2-1] DMA\_MODE bit field to 11 (clear TX and RX FIFO and resets its counter logic to 0. Returns to 0 after clearing FIFO).
  - c. Set the UART\_SCR[2-1] DMA\_MODE\_2 bit field to 10 (DMA mode 2, RX only).
  - d. Set the UART\_FCR[2-1] DMA\_MODE bit field to 11 (clear TX and RX FIFO and the DMA request again).
  - e. Set the UART\_SCR[2-1] DMA\_MODE\_2 bit field to 00 (no DMA) or keep 10 if RX DMA is needed.
3. DMA mode 3 is set (TX DMA only) by registers UART\_FCR[3] DMA\_MODE = 0 and UART\_SCR[0] DMA\_MODE\_CTL = 1, UART\_SCR[2-1] DMA\_MODE\_2 = 11. It is the same as above:
- a. Set the UART\_FCR[3] DMA\_MODE bit to 0. It is not necessary but suggested to avoid restore of DMA mode 1 during accidental reset of UART\_SCR[0] DMA\_MODE\_CTL bit. Be sure that all data was read out from RX FIFO and if it possible disable the RX side. In UART mode the RTS/CTS or XOFF/XON protocol can be used. In IrDA modes RX can be forcibly disabled by setting UART\_ACREG[5] DIS\_IR\_RX bit
- 

### Note

There can be RX DATA loss during the next steps if all DATA was not read out or there was an ongoing reception!

- b. Set the UART\_FCR[2-1] DMA\_MODE bit field to 11 (clear TX and RX FIFO and resets its counter logic to 0. Returns to 0 after clearing FIFO).
- c. Set the UART\_SCR[2-1] DMA\_MODE\_2 bit field to 10 (DMA mode 2, RX only).
- d. Set the UART\_FCR[2-1] DMA\_MODE bit field to 11 (clear TX and RX FIFO and the DMA request again).
- e. Set the UART\_SCR[2-1] DMA\_MODE\_2 bit field to 00 (no DMA) or keep 10 if RX DMA is needed.

#### 12.2.4.4.6.4.2 DMA Transfers (DMA Mode 1, 2, or 3)

Figure 12-113 through Figure 12-116 show the supported DMA operations.



uart-026

**Figure 12-113. UART Receive FIFO DMA Request Generation (32 Characters)**

In receive mode, a DMA request is generated when the RX FIFO reaches its threshold level defined in the trigger level register (UART\_TLR). This request is deasserted when the number of bytes defined by the threshold level is read by the device DMA controllers.

In transmit mode, a DMA request is automatically asserted when the TX FIFO is empty. This request is deasserted when the number of bytes defined by the number of spaces in the UART\_TLR register is written by the device DMA controllers. If an insufficient number of characters is written, the DMA request stays active.



uart-027

**Figure 12-114. UART Transmit FIFO DMA Request Generation (56 Spaces)**

The DMA request is again asserted if the FIFO can receive the number of bytes defined by the UART\_TLR register.

The threshold can be programmed in a number of ways. [Figure 12-114](#) shows a DMA transfer operating with a space setting of 56 that can arise from using the auto settings in the `UART_FCR[5-4] TX_FIFO_TRIG` bit field or the `UART_TLR[3-0] TX_FIFO_TRIG_DMA` bit field concatenated with the `TX_FIFO_TRIG` bit field.

The setting of 56 spaces in the UART module must correlate with the settings of the device DMA controllers, so that the buffer does not overflow (program the DMA request size of the LH controller to equal the number of spaces in the UART module).

[Figure 12-115](#) shows an example with eight spaces to show the buffer level crossing the space threshold. The LH DMA controller settings must correspond to those of the UART module.



uart-028

**Figure 12-115. UART Transmit FIFO DMA Request Generation (8 Spaces)**

The next example shows the setting of one space that uses the DMA for each transfer of one character to the transmit buffer (see [Figure 12-116](#)). The buffer is filled faster than the baud rate at which data is transmitted to the TX pin. Eventually, the buffer is completely full and the DMA operations stop transferring data to the transmit buffer.

On two occasions, the buffer holds the maximum amount of data words; shortly after this, the DMA is disabled to show the slower transmission of the data words to the TX pin. Eventually, the buffer is emptied at the rate specified by the baud rate settings of the `UART_DLL` and `UART_DLH` registers.

The DMA settings must correspond to the system LH DMA controller settings to ensure correct operation of this logic.



uart-029

**Figure 12-116. UART Transmit FIFO DMA Request Generation (1 Space)**

The final example illustrates the setting of eight spaces but setting the TX DMA threshold directly by setting `UART_MDR3[1] NONDEFAULT_FREQ` bit and `UART_TX_DMA_THRESHOLD` register (see [Figure 12-117](#)). In the example, the `UART_TX_DMA_THRESHOLD[5-0]` `TX_DMA_THRESHOLD` = 3 and the trigger level is 8. The buffer is filled at a faster rate than the BAUD rate transmits data to the TX pin. The buffer is filled with 8 bytes and the DMA operations stop transferring data to the transmit buffer. When the buffer is emptied to the threshold level by transmission, the DMA operation activates again to fill the buffer with 8 bytes.

Eventually, the buffer will be emptied at the rate specified by the BAUD Rate settings of the `UART_DLL` and `UART_DLH` registers.

If the selected threshold level + trigger level exceeds max buffer size, then the original TX DMA threshold method is used to prevent TX overrun, regardless of the `UART_MDR3[1] NONDEFAULT_FREQ` value.

The DMA settings should correspond to the system Local Host DMA controller settings in order to ensure the correct operation of this logic.



uart-036

**Figure 12-117. UART Transmit FIFO DMA Request Generation Using Direct TX DMA Threshold Programming. (Threshold = 3; Spaces = 8)**

#### 12.2.4.4.6.4.3 DMA Transmission

Figure 12-118 shows DMA transmission.



uart-030

**Figure 12-118. DMA Transmission**

1. Data to be transmitted are put in the device memory reserved for UART transmission by the DMA:
  - a. Until the TX FIFO trigger level is not reached, a DMA request is generated
  - b. An element (1 byte) is transferred from the SDRAM to the TX FIFO at each DMA request (DMA element synchronization).
2. Data in the TX FIFO are automatically transmitted.
3. The end of the transmission is signaled by the `UART_THR` empty (TX FIFO empty).

#### Note

In IrDA mode, the transmission does not end immediately after the TX FIFO empties, at which point the last data byte, the CRC field, and the stop flag still must be transmitted; thus, the end of transmission occurs a few milliseconds after the `UART_THR` register empties.

#### 12.2.4.4.6.4.4 DMA Reception

Figure 12-119 shows DMA reception.



**Figure 12-119. DMA Reception**

1. Enable the reception.
2. Received data are put in the RX FIFO.
3. Data are transferred from the RX FIFO to the device memory by the DMA:
  - a. At each received byte, the RX FIFO trigger level (one character) is reached and a DMA request is generated.
  - b. An element (1 byte) is transferred from the RX FIFO to the SDRAM at each DMA request (DMA element synchronization).
4. The end of the reception is signaled by the EOF interrupt.

#### 12.2.4.4.7 UART Mode Selection

##### 12.2.4.4.7.1 Register Access Modes

###### 12.2.4.4.7.1.1 Operational Mode and Configuration Modes

Register access depends on the register access mode, although register access modes are not correlated to functional mode selection. Three different modes are available:

- Operational mode
- Configuration mode A
- Configuration mode B

Operational mode is the selected mode when the function is active; serial data transfer can be performed in this mode.

Configuration mode A and configuration mode B are used during module initialization steps. These modes enable access to configuration registers, which are hidden in the operational mode. The modes are used when the module is inactive (no serial data transfer processed) and only for initialization or reconfiguration of the module.

The value of the `UART_LCR` register determines the register access mode (see [Table 12-104](#)).

**Table 12-104. UART Register Access Mode Programming (Using `UART_LCR`)**

| Mode                 | Condition                                                             |
|----------------------|-----------------------------------------------------------------------|
| Configuration mode A | <code>UART_LCR[7] = 0x1</code> and <code>UART_LCR[7-0] != 0xBF</code> |
| Configuration mode B | <code>UART_LCR[7] = 0x1</code> and <code>UART_LCR[7-0] = 0xBF</code>  |
| Operational mode     | <code>UART_LCR[7] = 0x0</code>                                        |

#### 12.2.4.4.7.1.2 Register Access Submode

In each access register mode (operational mode or configuration mode A/B), some register accesses are conditional on the programming of a submode (MSR\_SPR, TCR\_TLR, and XOFF). These registers are identified in [Table 12-127, UART Load FIFO Triggers Defined by the Concatenated Value](#).

[Table 12-105](#) through [Table 12-107](#) summarize the register access submodes.

**Table 12-105. UART Subconfiguration Mode A Summary**

| Mode    | Condition                                |
|---------|------------------------------------------|
| MSR_SPR | (UART_EFR[4] = 0x0 or UART_MCR[6] = 0x0) |
| TCR_TLR | UART_EFR[4] = 0x1 and UART_MCR[6] = 0x1  |

**Table 12-106. UART Subconfiguration Mode B Summary**

| Mode    | Condition                                |
|---------|------------------------------------------|
| TCR_TLR | UART_EFR[4] = 0x1 and UART_MCR[6] = 0x1  |
| XOFF    | (UART_EFR[4] = 0x0 or UART_MCR[6] = 0x0) |

**Table 12-107. UART Suboperational Mode Summary**

| Mode    | Condition                               |
|---------|-----------------------------------------|
| MSR_SPR | UART_EFR[4] = 0x0 or UART_MCR[6] = 0x0  |
| TCR_TLR | UART_EFR[4] = 0x1 and UART_MCR[6] = 0x1 |

#### 12.2.4.4.7.1.3 Registers Available for the Register Access Modes

[Table 12-108](#) lists the names of the register bits in each access register mode. Gray shading indicates that the register does not depend on the register access mode (available in all modes).

**Table 12-108. UART Register Access Mode Overview**

| Address Offset | Registers              |                        |                          |                          |                        |                        |
|----------------|------------------------|------------------------|--------------------------|--------------------------|------------------------|------------------------|
|                | Configuration Mode A   |                        | Configuration Mode B     |                          | Operational Mode       |                        |
|                | Read                   | Write                  | Read                     | Write                    | Read                   | Write                  |
| 0x000          | UART_DLL               | UART_DLL               | UART_DLL                 | UART_DLL                 | UART_RHR               | UART_THR               |
| 0x004          | UART_DLH               | UART_DLH               | UART_DLH                 | UART_DLH                 | UART_IER_UART          | UART_IER_UART          |
| 0x008          | UART_IIR_UART          | UART_FCR               | UART_EFR                 | UART_EFR                 | UART_IIR_UART          | UART_FCR               |
| 0x00C          | UART_LCR               | UART_LCR               | UART_LCR                 | UART_LCR                 | UART_LCR               | UART_LCR               |
| 0x010          | UART_MCR               | UART_MCR               | UART_XON1_AD<br>DR1      | UART_XON1_AD<br>DR1      | UART_MCR               | UART_MCR               |
| 0x014          | UART_LSR_UART          | –                      | UART_XON2_AD<br>DR2      | UART_XON2_AD<br>DR2      | UART_LSR_UART          | –                      |
| 0x018          | UART_MSR /<br>UART_TCR | UART_TCR               | UART_TCR /<br>UART_XOFF1 | UART_TCR /<br>UART_XOFF1 | UART_MSR /<br>UART_TCR | UART_TCR               |
| 0x01C          | UART_SPR /<br>UART_TLR | UART_SPR /<br>UART_TLR | UART_TLR /<br>UART_XOFF2 | UART_TLR /<br>UART_XOFF2 | UART_SPR /<br>UART_TLR | UART_SPR /<br>UART_TLR |
| 0x020          | UART_MDR1              | UART_MDR1              | UART_MDR1                | UART_MDR1                | UART_MDR1              | UART_MDR1              |
| 0x024          | UART_MDR2              | UART_MDR2              | UART_MDR2                | UART_MDR2                | UART_MDR2              | UART_MDR2              |
| 0x028          | UART_SFSLR             | UART_TXFLL             | UART_SFSLR               | UART_TXFLL               | UART_SFSLR             | UART_TXFLL             |
| 0x02C          | UART_RESUME            | UART_TXFLH             | UART_RESUME              | UART_TXFLH               | UART_RESUME            | UART_TXFLH             |
| 0x030          | UART_SFREGL            | UART_RXFLL             | UART_SFREGL              | UART_RXFLL               | UART_SFREGL            | UART_RXFLL             |
| 0x034          | UART_SFREGH            | UART_RXFLH             | UART_SFREGH              | UART_RXFLH               | UART_SFREGH            | UART_RXFLH             |
| 0x038          | UART_UASR              | –                      | UART_UASR                | –                        | UART_BLR               | UART_BLR               |
| 0x03C          | –                      | –                      | –                        | –                        | UART_ACREG             | UART_ACREG             |
| 0x040          | UART_SCR               | UART_SCR               | UART_SCR                 | UART_SCR                 | UART_SCR               | UART_SCR               |

**Table 12-108. UART Register Access Mode Overview (continued)**

| Address<br>Offset | Registers                 |                           |                           |                           |                           |                           |
|-------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|
|                   | Configuration Mode A      |                           | Configuration Mode B      |                           | Operational Mode          |                           |
|                   | Read                      | Write                     | Read                      | Write                     | Read                      | Write                     |
| 0x044             | UART_SSR                  | –                         | UART_SSR                  | –                         | UART_SSR                  | –                         |
| 0x048             | –                         | –                         | –                         | –                         | UART_EBLR                 | UART_EBLR                 |
| 0x050             | UART_MVR                  | –                         | UART_MVR                  | –                         | UART_MVR                  | –                         |
| 0x054             | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 |
| 0x058             | UART_SYSS                 | –                         | UART_SYSS                 | –                         | UART_SYSS                 | –                         |
| 0x05C             | UART_WER                  | UART_WER                  | UART_WER                  | UART_WER                  | UART_WER                  | UART_WER                  |
| 0x060             | UART_CFPS                 | UART_CFPS                 | UART_CFPS                 | UART_CFPS                 | UART_CFPS                 | UART_CFPS                 |
| 0x064             | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       |
| 0x068             | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       |
| 0x06C             | UART_IER2                 | UART_IER2                 | UART_IER2                 | UART_IER2                 | UART_IER2                 | UART_IER2                 |
| 0x070             | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 |
| 0x074             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             |
| 0x080             | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 |
| 0x084             | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD |

#### 12.2.4.4.7.2 UART/RS-485/IrDA (SIR, MIR, FIR)/CIR Mode Selection

To select a mode, set the UART\_MDR1[2:0] MODE\_SELECT bit field (see [Table 12-109](#)).

**Table 12-109. UART Mode Selection**

| Value | Mode               |
|-------|--------------------|
| 0x0:  | UART 16x mode      |
| 0x1:  | SIR mode           |
| 0x2:  | UART 16x auto-baud |
| 0x3:  | UART 13x mode      |
| 0x4:  | MIR mode           |
| 0x5:  | FIR mode           |
| 0x6:  | CIR mode           |

MODE\_SELECT is effective when the module is in operational mode (see [Section 12.2.4.4.7.1, Register Access Modes](#)).

To select a RS-485 mode, set the UART\_MDR3[4] DIR\_EN bit field to 0x1.

#### 12.2.4.4.7.2.1 Registers Available for the UART Function

Only the registers listed in [Table 12-110](#) are used for the UART function.

**Table 12-110. UART Mode Register Overview**

| Address<br>Offset | Registers <sup>(1) (2)</sup> |          |                      |              |                         |                         |
|-------------------|------------------------------|----------|----------------------|--------------|-------------------------|-------------------------|
|                   | Configuration Mode A         |          | Configuration Mode B |              | Operational Mode        |                         |
|                   | Read                         | Write    | Read                 | Write        | Read                    | Write                   |
| 0x000             | UART_DLL                     | UART_DLL | UART_DLL             | UART_DLL     | UART_RHR                | UART_THR                |
| 0x004             | UART_DLH                     | UART_DLH | UART_DLH             | UART_DLH     | UART_IER_UART<br>(UART) | UART_IER_UART<br>(UART) |
| 0x008             | UART_IIR_UART                | UART_FCR | UART_EFR [4]         | UART_EFR [4] | UART_IIR_UART<br>(UART) | UART_FCR<br>(UART)      |

Table 12-110. UART Mode Register Overview (continued)

| Address<br>Offset | Registers <sup>(1) (2)</sup> |                        |                         |                         |                        |                        |
|-------------------|------------------------------|------------------------|-------------------------|-------------------------|------------------------|------------------------|
|                   | Configuration Mode A         |                        | Configuration Mode B    |                         | Operational Mode       |                        |
|                   | Read                         | Write                  | Read                    | Write                   | Read                   | Write                  |
| 0x00C             | UART_LCR                     | UART_LCR               | UART_LCR                | UART_LCR                | UART_LCR               | UART_LCR               |
| 0x010             | UART_MCR                     | UART_MCR               | UART_XON1_DR1           | UART_XON1_DR1           | UART_MCR               | UART_MCR               |
| 0x014             | UART_LSR_UART                | –                      | UART_XON2_DR2           | UART_XON2_DR2           | UART_LSR_UART          | –                      |
| 0x018             | UART_MSR/<br>UART_TCR        | UART_TCR               | UART_XOFF1/<br>UART_TCR | UART_XOFF1/<br>UART_TCR | UART_MSR/<br>UART_TCR  | UART_TCR               |
| 0x01C             | UART_TLR/<br>UART_SPR        | UART_TLR/<br>UART_SPR  | UART_TLR/<br>UART_XOFF2 | UART_TLR/<br>UART_XOFF2 | UART_TLR/<br>UART_SPR  | UART_TLR/<br>UART_SPR  |
| 0x020             | UART_MDR1                    | UART_MDR1 [2-0]        | UART_MDR1 [2-0]         | UART_MDR1 [2-0]         | UART_MDR1 [2-0]        | UART_MDR1 [2-0]        |
| 0x024             | UART_MDR2                    | UART_MDR2              | UART_MDR2               | UART_MDR2               | UART_MDR2              | UART_MDR2              |
| 0x028             | –                            | –                      | –                       | –                       | –                      | –                      |
| 0x02C             | –                            | –                      | –                       | –                       | –                      | –                      |
| 0x030             | –                            | –                      | –                       | –                       | –                      | –                      |
| 0x034             | –                            | –                      | –                       | –                       | –                      | –                      |
| 0x038             | UART_UASR                    | –                      | UART_UASR               | –                       | –                      | –                      |
| 0x03C             | –                            | –                      | –                       | –                       | –                      | –                      |
| 0x040             | UART_SCR                     | UART_SCR               | UART_SCR                | UART_SCR                | UART_SCR               | UART_SCR               |
| 0x044             | UART_SSR                     | –                      | UART_SSR                | –                       | UART_SSR               | –                      |
| 0x048             | –                            | –                      | –                       | –                       | –                      | –                      |
| 0x050             | UART_MVR                     | –                      | UART_MVR                | –                       | UART_MVR               | –                      |
| 0x054             | UART_SYSC                    | UART_SYSC              | UART_SYSC               | UART_SYSC               | UART_SYSC              | UART_SYSC              |
| 0x058             | UART_SYSS                    | –                      | UART_SYSS               | –                       | UART_SYSS              | –                      |
| 0x05C             | UART_WER                     | UART_WER               | UART_WER                | UART_WER                | UART_WER               | UART_WER               |
| 0x060             | –                            | –                      | –                       | –                       | –                      | –                      |
| 0x064             | UART_RXFIFO_L_VL             | UART_RXFIFO_L_VL       | UART_RXFIFO_L_VL        | UART_RXFIFO_L_VL        | UART_RXFIFO_L_VL       | UART_RXFIFO_L_VL       |
| 0x068             | UART_TXFIFO_L_VL             | UART_TXFIFO_L_VL       | UART_TXFIFO_L_VL        | UART_TXFIFO_L_VL        | UART_TXFIFO_L_VL       | UART_TXFIFO_L_VL       |
| 0x06C             | UART_IER2                    | UART_IER2              | UART_IER2               | UART_IER2               | UART_IER2              | UART_IER2              |
| 0x070             | UART_ISR2                    | UART_ISR2              | UART_ISR2               | UART_ISR2               | UART_ISR2              | UART_ISR2              |
| 0x074             | UART_FREQ_SEL                | UART_FREQ_SEL          | UART_FREQ_SEL           | UART_FREQ_SEL           | UART_FREQ_SEL          | UART_FREQ_SEL          |
| 0x080             | UART_MDR3                    | UART_MDR3              | UART_MDR3               | UART_MDR3               | UART_MDR3              | UART_MDR3              |
| 0x084             | UART_TX_DMA_T_HRESHOLD       | UART_TX_DMA_T_HRESHOLD | UART_TX_DMA_T_HRESHOLD  | UART_TX_DMA_T_HRESHOLD  | UART_TX_DMA_T_HRESHOLD | UART_TX_DMA_T_HRESHOLD |

(1) REGISTER\_NAME(UART) notation indicates that the register exists for other functions (IrDA or CIR), but fields have different meanings for other functions (described separately in *UART Registers*).

(2) REGISTER\_NAME[m:n] notation indicates that only register bits numbered m to n apply to the UART function.

#### 12.2.4.4.7.2.2 Registers Available for the IrDA Function

Only the registers listed in Table 12-111 are used for the IrDA function.

Table 12-111. IrDA Mode Register Overview

| Address<br>Offset | Registers <sup>(1) (2)</sup> |          |                      |          |                  |          |
|-------------------|------------------------------|----------|----------------------|----------|------------------|----------|
|                   | Configuration Mode A         |          | Configuration Mode B |          | Operational Mode |          |
|                   | Read                         | Write    | Read                 | Write    | Read             | Write    |
| 0x000             | UART_DLL                     | UART_DLL | UART_DLL             | UART_DLL | UART_RHR         | UART_THR |

**Table 12-111. IrDA Mode Register Overview (continued)**

| Address<br>Offset | Registers <sup>(1) (2)</sup> |                           |                           |                           |                           |                           |
|-------------------|------------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|
|                   | Configuration Mode A         |                           | Configuration Mode B      |                           | Operational Mode          |                           |
|                   | Read                         | Write                     | Read                      | Write                     | Read                      | Write                     |
| 0x004             | UART_DLH                     | UART_DLH                  | UART_DLH                  | UART_DLH                  | UART_IER_UART<br>(IrDA)   | UART_IER_UART<br>(IrDA)   |
| 0x008             | UART_IIR_UART                | UART_FCR                  | UART_EFR [4]              | UART_EFR [4]              | UART_IIR_UART<br>(IrDA)   | UART_FCR (IrDA)           |
| 0x00C             | UART_LCR [7]                 | UART_LCR [7]              | UART_LCR [7]              | UART_LCR [7]              | UART_LCR [7]              | UART_LCR [7]              |
| 0x010             | –                            | –                         | UART_XON1_AD<br>DR1       | UART_XON1_AD<br>DR1       | –                         | –                         |
| 0x014             | UART_LSR_UART<br>(IrDA)      | –                         | UART_XON2_AD<br>DR2       | UART_XON2_AD<br>DR2       | UART_LSR_UART<br>(IrDA)   | –                         |
| 0x018             | UART_MSR/<br>UART_TCR        | UART_TCR                  | UART_TCR                  | UART_TCR                  | UART_MSR/<br>UART_TCR     | UART_TCR                  |
| 0x01C             | UART_TLR/<br>UART_SPR        | UART_TLR/<br>UART_SPR     | UART_TLR                  | UART_TLR                  | UART_TLR/<br>UART_SPR     | UART_TLR/<br>UART_SPR     |
| 0x020             | UART_MDR1                    | UART_MDR1                 | UART_MDR1                 | UART_MDR1                 | UART_MDR1                 | UART_MDR1                 |
| 0x024             | UART_MDR2                    | UART_MDR2                 | UART_MDR2                 | UART_MDR2                 | UART_MDR2                 | UART_MDR2                 |
| 0x028             | UART_SFLSR                   | UART_TXFLL                | UART_SFLSR                | UART_TXFLL                | UART_SFLSR                | UART_TXFLL                |
| 0x02C             | UART_RESUME                  | UART_TXFLH                | UART_RESUME               | UART_TXFLH                | UART_RESUME               | UART_TXFLH                |
| 0x030             | UART_SFREGL                  | UART_RXFLL                | UART_SFREGL               | UART_RXFLL                | UART_SFREGL               | UART_RXFLL                |
| 0x034             | UART_SFREGH                  | UART_RXFLH                | UART_SFREGH               | UART_RXFLH                | UART_SFREGH               | UART_RXFLH                |
| 0x038             | –                            | –                         | –                         | –                         | UART_BLR                  | UART_BLR                  |
| 0x03C             | –                            | –                         | –                         | –                         | UART_ACREG                | UART_ACREG                |
| 0x040             | UART_SCR                     | UART_SCR                  | UART_SCR                  | UART_SCR                  | UART_SCR                  | UART_SCR                  |
| 0x044             | UART_SSR                     | –                         | UART_SSR                  | –                         | UART_SSR                  | –                         |
| 0x048             | –                            | –                         | –                         | –                         | UART_EBLR                 | UART_EBLR                 |
| 0x050             | UART_MVR                     | –                         | UART_MVR                  | –                         | UART_MVR                  | –                         |
| 0x054             | UART_SYSC                    | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 |
| 0x058             | UART_SYSS                    | –                         | UART_SYSS                 | –                         | UART_SYSS                 | –                         |
| 0x05C             | UART_WER [6-4]               | UART_WER [6-4]            | UART_WER [6-4]            | UART_WER [6-4]            | UART_WER [6-4]            | UART_WER [6-4]            |
| 0x060             | –                            | –                         | –                         | –                         | –                         | –                         |
| 0x064             | UART_RXFIFO_L<br>VL          | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       |
| 0x068             | UART_TXFIFO_L<br>LV          | UART_TXFIFO_L<br>LV       | UART_TXFIFO_L<br>LV       | UART_TXFIFO_L<br>LV       | UART_TXFIFO_L<br>LV       | UART_TXFIFO_L<br>LV       |
| 0x06C             | UART_IER2                    | UART_IER2                 | UART_IER2                 | UART_IER2                 | UART_IER2                 | UART_IER2                 |
| 0x070             | UART_ISR2                    | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 |
| 0x074             | UART_FREQ_SEL                | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             |
| 0x080             | UART_MDR3                    | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 |
| 0x084             | UART_TX_DMA_T<br>HRESHOLD    | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD |

(1) REGISTER\_NAME(IrDA) notation indicates that the register exists for other functions (UART or CIR), but fields have different meanings for other functions (described separately in *UART Registers*).

(2) REGISTER\_NAME[m:n] notation indicates that only register bits numbered m to n apply to the IrDA function.

#### 12.2.4.7.2.3 Registers Available for the CIR Function

Only the registers listed in Table 12-112 are used for the CIR function.

Table 12-112. CIR Mode Register Overview

| Address<br>Offset | Registers <sup>(1) (2)</sup> |                           |                           |                           |                           |                           |
|-------------------|------------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|
|                   | Configuration Mode A         |                           | Configuration Mode B      |                           | Operational Mode          |                           |
|                   | Read                         | Write                     | Read                      | Write                     | Read                      | Write                     |
| 0x000             | UART_DLL                     | UART_DLL                  | UART_DLL                  | UART_DLL                  | –                         | UART_THR                  |
| 0x004             | UART_DLH                     | UART_DLH                  | UART_DLH                  | UART_DLH                  | UART_IER_UART<br>(CIR)    | UART_IER_UART<br>(CIR)    |
| 0x008             | UART_IIR_UART                | UART_FCR                  | UART_EFR                  | UART_EFR                  | UART_IIR_UART<br>(CIR)    | UART_FCR (CIR)            |
| 0x00C             | UART_LCR                     | UART_LCR [7]              |
| 0x010             | –                            | –                         | –                         | –                         | –                         | –                         |
| 0x014             | UART_LSR_UART<br>(CIR)       | –                         | –                         | –                         | UART_LSR_UART<br>(CIR)    | –                         |
| 0x018             | UART_MSR/<br>UART_TCR        | UART_TCR                  | UART_TCR                  | UART_TCR                  | UART_MSR/<br>UART_TCR     | UART_TCR                  |
| 0x01C             | UART_TLR/<br>UART_SPR        | UART_TLR/<br>UART_SPR     | UART_TLR                  | UART_TLR                  | UART_TLR/<br>UART_SPR     | UART_TLR/<br>UART_SPR     |
| 0x020             | UART_MDR1 [3-0]              | UART_MDR1 [3-0]           | UART_MDR1 [3-0]           | UART_MDR1 [3-0]           | UART_MDR1 [3-0]           | UART_MDR1 [3-0]           |
| 0x024             | UART_MDR2                    | UART_MDR2                 | UART_MDR2                 | UART_MDR2                 | UART_MDR2                 | UART_MDR2                 |
| 0x028             | –                            | –                         | –                         | –                         | –                         | –                         |
| 0x02C             | UART_RESUME                  | –                         | UART_RESUME               | –                         | UART_RESUME               | –                         |
| 0x030             | –                            | –                         | –                         | –                         | –                         | –                         |
| 0x034             | –                            | –                         | –                         | –                         | –                         | –                         |
| 0x038             | –                            | –                         | –                         | –                         | –                         | –                         |
| 0x03C             | –                            | –                         | –                         | –                         | UART_ACREG                | UART_ACREG                |
| 0x040             | UART_SCR                     | UART_SCR                  | UART_SCR                  | UART_SCR                  | UART_SCR                  | UART_SCR                  |
| 0x044             | UART_SSR                     | –                         | UART_SSR                  | –                         | UART_SSR                  | –                         |
| 0x048             | –                            | –                         | –                         | –                         | UART_EBLR                 | UART_EBLR                 |
| 0x050             | UART_MVR                     | –                         | UART_MVR                  | –                         | UART_MVR                  | –                         |
| 0x054             | UART_SYSC                    | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 | UART_SYSC                 |
| 0x058             | UART_SYSS                    | –                         | UART_SYSS                 | –                         | UART_SYSS                 | –                         |
| 0x05C             | UART_WER [6-4]               | UART_WER [6-4]            | UART_WER [6-4]            | UART_WER [6-4]            | UART_WER [6-4]            | UART_WER [6-4]            |
| 0x060             | UART_CFPS                    | UART_CFPS                 | UART_CFPS                 | UART_CFPS                 | UART_CFPS                 | UART_CFPS                 |
| 0x064             | UART_RXFIFO_L<br>VL          | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       | UART_RXFIFO_L<br>VL       |
| 0x068             | UART_TXFIFO_LV<br>L          | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       | UART_TXFIFO_LV<br>L       |
| 0x06C             | UART_IER2                    | UART_IER2                 | UART_IER2                 | UART_IER2                 | UART_IER2                 | UART_IER2                 |
| 0x070             | UART_ISR2                    | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 | UART_ISR2                 |
| 0x074             | UART_FREQ_SEL                | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             | UART_FREQ_SEL             |
| 0x080             | UART_MDR3                    | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 | UART_MDR3                 |
| 0x084             | UART_TX_DMA_T<br>HRESHOLD    | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD | UART_TX_DMA_T<br>HRESHOLD |

(1) REGISTER\_NAME(CIR) notation indicates that the register exists for other functions (IrDA or UART), but fields have different meanings for other functions (described separately in *UART Registers*).

(2) REGISTER\_NAME[m:n] notation indicates that only register bits numbered m to n apply to the CIR function.

#### 12.2.4.4.8 UART Protocol Formatting

##### 12.2.4.4.8.1 UART Mode

###### 12.2.4.4.8.1.1 UART Clock Generation: Baud Rate Generation

The UART function contains a programmable baud generator and a set of fixed dividers that divide the 48-MHz clock input down to the expected baud rate.

Figure 12-120 shows the baud rate generator and associated controls.



**Figure 12-120. UART Baud Rate Generation**

**CAUTION**

Before initializing or modifying clock parameter controls (UART\_DLH, UART\_DLL), UART\_MDR1[2-0] MODE\_SELECT = DISABLE must be set to 0x7. Failure to observe this rule can result in unpredictable module behavior.

###### 12.2.4.4.8.1.2 Choosing the Appropriate Divisor Value

Two divisor values are:

- UART 16x mode: Divisor value = Operating frequency / (16x baud rate)
- UART 13x mode: Divisor value = Operating frequency / (13x baud rate)

**Table 12-113. UART Baud Rate Settings (48-MHz Clock)**

| Baud Rate  | Baud Multiple | DLH, DLL (Decimal) | DLH, DLL (Hex) | Actual Baud Rate | Error (%) |
|------------|---------------|--------------------|----------------|------------------|-----------|
| 0.3 kbps   | 16x           | 10000              | 0x27, 0x10     | 0.3 kbps         | 0         |
| 0.6 kbps   | 16x           | 5000               | 0x13, 0x88     | 0.6 kbps         | 0         |
| 1.2 kbps   | 16x           | 2500               | 0x09, 0xC4     | 1.2 kbps         | 0         |
| 2.4 kbps   | 16x           | 1250               | 0x04, 0xE2     | 2.4 kbps         | 0         |
| 4.8 kbps   | 16x           | 625                | 0x02, 0x71     | 4.8 kbps         | 0         |
| 9.6 kbps   | 16x           | 312                | 0x01, 0x38     | 9.6153 kbps      | +0.16     |
| 14.4 kbps  | 16x           | 208                | 0x00, 0xD0     | 14.423 kbps      | +0.16     |
| 19.2 kbps  | 16x           | 156                | 0x00, 0x9C     | 19.231 kbps      | +0.16     |
| 28.8 kbps  | 16x           | 104                | 0x00, 0x68     | 28.846 kbps      | +0.16     |
| 38.4 kbps  | 16x           | 78                 | 0x00, 0x4E     | 38.462 kbps      | +0.16     |
| 57.6 kbps  | 16x           | 52                 | 0x00, 0x34     | 57.692 kbps      | +0.16     |
| 115.2 kbps | 16x           | 26                 | 0x00, 0x1A     | 115.38 kbps      | +0.16     |
| 230.4 kbps | 16x           | 13                 | 0x00, 0x0D     | 230.77 kbps      | +0.16     |
| 460.8 kbps | 13x           | 8                  | 0x00, 0x08     | 461.54 kbps      | +0.16     |
| 921.6 kbps | 13x           | 4                  | 0x00, 0x04     | 923.08 kbps      | +0.16     |
| 1.843 Mbps | 13x           | 2                  | 0x00, 0x02     | 1.846 Mbps       | +0.16     |

**Table 12-113. UART Baud Rate Settings (48-MHz Clock) (continued)**

| Baud Rate   | Baud Multiple | DLH, DLL (Decimal) | DLH, DLL (Hex) | Actual Baud Rate | Error (%) |
|-------------|---------------|--------------------|----------------|------------------|-----------|
| 3.0 Mbps    | 16x           | 1                  | 0x00, 0x01     | 3.0 Mbps         | 0         |
| 3.6884 Mbps | 13x           | 1                  | 0x00, 0x01     | 3.6923 Mbps      | +0.16     |

#### 12.2.4.4.8.1.3 UART Data Formatting

The UART can use hardware flow control to manage transmission and reception. Hardware flow control significantly reduces software overhead and increases system efficiency by automatically controlling serial data flow using the RTS output and CTS input signals.

The UART is enhanced with the autobauding function. In control mode, autobauding lets the speed, the number of bits per character, and the parity selected be set automatically.

#### 12.2.4.4.8.1.3.1 Frame Formatting

When autobauding is not used, frame format attributes must be defined in the UART\_LCR register.

Character length is specified using the UART\_LCR[1-0] CHAR\_LENGTH bit field.

The number of stop-bits is specified using the UART\_LCR[2] NB\_STOP bit.

The parity bit is programmed using the UART\_LCR[5-3] PARITY\_EN, UART\_LCR[5-3] PARITY\_TYPE\_1, and UART\_LCR[5-3] PARITY\_TYPE\_2 bit fields (see [Table 12-114](#)).

**Table 12-114. UART Parity Bit Encoding**

| PARITY_EN | PARITY_TYPE_1 | PARITY_TYPE_2 | Parity      |
|-----------|---------------|---------------|-------------|
| 0         | N/A           | N/A           | No parity   |
| 1         | 0             | 0             | Odd parity  |
| 1         | 1             | 0             | Even parity |
| 1         | 0             | 1             | Forced 1    |
| 1         | 1             | 1             | Forced 0    |

#### 12.2.4.4.8.1.3.2 Hardware Flow Control

Hardware flow control is composed of auto-CTS and auto-RTS. Auto-CTS and auto-RTS can be enabled and disabled independently by programming the UART\_EFR[7] AUTO\_CTS\_EN and UART\_EFR[6] AUTO\_RTS\_EN bit fields, respectively.

With auto-CTS, CTS signal must be active before the module can transmit data.

Auto-RTS activates the RTS output only when there is enough room in the RX FIFO to receive data. It deactivates the RTS output when the RX FIFO is sufficiently full. The HALT and RESTORE trigger levels in the UART\_TCR register determine the levels at which RTS is activated and deactivated.

If auto-CTS and auto-RTS are enabled, data transmission does not occur unless the RX FIFO has empty space. Thus, overrun errors are eliminated during hardware flow control. If auto-CTS and auto-RTS are not enabled, overrun errors occur if the transmit data rate exceeds the RX FIFO latency.

- Auto-RTS:

Auto-RTS data flow control originates in the receiver block. The RX FIFO trigger levels used in auto-RTS are stored in the UART\_TCR register. RTS is active if the RX FIFO level is below the HALT trigger level in the UART\_TCR[3-0] RX\_FIFO\_TRIG\_HALTI bit field. When the RX FIFO HALT trigger level is reached, RTS is deasserted. The sending device (for example, another UART) can send an additional byte after the trigger level is reached because it may not recognize the deassertion of RTS until it begins sending the additional byte.

RTS is automatically reasserted when the RX FIFO reaches the RESUME trigger level programmed by the UART\_TCR[7-4] RX\_FIFO\_TRIG\_START bit field. This reassertion requests the sending device to resume transmission.

In this case, RTS is an active-low signal.

- Auto-CTS:

The transmitter circuitry checks CTS before sending the next data byte. When CTS is active, the transmitter sends the next byte. To stop the transmitter from sending the next byte, CTS must be deasserted before the middle of the last stop-bit currently sent.

The auto-CTS function reduces interrupts to the host system. When auto-CTS flow control is enabled, the CTS state changes do not have to trigger host interrupts because the device automatically controls its own transmitter. Without auto-CTS, the transmitter sends any data present in the transmit FIFO, and a receiver overrun error can result.

In this case, CTS is an active-low signal.

#### 12.2.4.4.8.1.3.3 Software Flow Control

Software flow control is enabled through the enhanced feature register (UART\_EFR) and the modem control register (UART\_MCR). Different combinations of software flow control can be enabled by setting different combinations of the UART\_EFR[3-0] bit field (see [Table 12-115](#)).

Two other enhanced features relate to software flow control:

- XON-any function (UART\_MCR[5] XON\_EN): Operation resumes after receiving any character after the XOFF character is recognized. If special character detect is enabled and special character is received after XOFF1, it does not resume transmission. The special character is stored in the RX FIFO.

#### Note

The XON-any character is written into the RX FIFO even if it is a software flow character.

- Special character (UART\_EFR[5] SPECIAL\_CHAR\_DETEC T): Incoming data is compared to XOFF2. When the special character is detected, the XOFF interrupt (UART\_IIR\_UART) is set, but it does not halt transmission. The XOFF interrupt is cleared by a read of UART\_IIR\_UART. The special character is transferred to the RX FIFO. Special character does not work with XON2, XOFF2, or sequential XOFFs.

**Table 12-115. UART\_EFR[3:0] Software Flow Control Options**

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | TX, RX Software Flow Controls                             |
|-------|-------|-------|-------|-----------------------------------------------------------|
| 0     | 0     | X     | X     | No transmit flow control                                  |
| 1     | 0     | X     | X     | Transmit XON1, XOFF1                                      |
| 0     | 1     | X     | X     | Transmit XON2, XOFF2                                      |
| 1     | 1     | X     | X     | Transmit XON1, XON2: XOFF1, XOFF2 <sup>(1)</sup>          |
| X     | X     | 0     | 0     | No receive flow control                                   |
| X     | X     | 1     | 0     | Receiver compares XON1, XOFF1                             |
| X     | X     | 0     | 1     | Receiver compares XON2, XOFF2                             |
| X     | X     | 1     | 1     | Receiver compares XON1, XON2: XOFF1, XOFF2 <sup>(1)</sup> |

- (1) In these cases, the XON1 and XON2 characters or the XOFF1 and XOFF2 characters must be transmitted/received sequentially with XON1/XOFF1 followed by XON2/XOFF2.  
 XON1 is defined in the UART\_XON1\_ADDR1[7-0] XON\_WORD1 bit field. XON2 is defined in the UART\_XON2\_ADDR2[7-0] XON\_WORD2 bit field.  
 XOFF1 is defined in the UART\_XOFF1[7-0] XOFF\_WORD1 bit field. XOFF2 is defined in the UART\_XOFF2[7-0] XOFF\_WORD2 bit field.

#### 12.2.4.4.8.1.3.3.1 Receive (RX)

When software flow control operation is enabled, the UART compares incoming data with XOFF1/2 programmed characters (in certain cases, XOFF1 and XOFF2 must be received sequentially). When the correct XOFF

characters are received, transmission stops after transmission of the current character completes. Detection of XOFF also sets the UART\_IIR\_UART[4] bit (if enabled by UART\_IER\_UART[5]) and causes the interrupt line to go low.

To resume transmission, an XON1/2 character must be received (in certain cases, XON1 and XON2 must be received sequentially). When the correct XON characters are received, the UART\_IIR\_UART[4] bit is cleared and the XOFF interrupt disappears.

---

#### Note

When a parity, framing, or break error occurs while receiving a software flow control character, this character is treated as normal data and is written to the RX FIFO.

---

When XON-any and special character detect are disabled and software flow control is enabled, no valid XON or XOFF characters are written to the RX FIFO. For example, when UART\_EFR[1-0] = 0x2, if XON1 and XOFF1 characters are received, they are not written to the RX FIFO.

When pairs of software flow characters are programmed to be received sequentially (UART\_EFR[1-0] = 0x3), the software flow characters are not written to the RX FIFO if they are received sequentially. However, received XON1/XOFF1 characters must be written to the RX FIFO if the subsequent character is not XON2/XOFF2.

#### 12.2.4.8.1.3.3.2 Transmit (TX)

Two XOFF1 characters are transmitted when the RX FIFO passes the trigger level programmed by UART\_TCR[3-0] RX\_FIFO\_TRIG\_HALT. As soon as the RX FIFO reaches the trigger level programmed by UART\_TCR[7-4] RX\_FIFO\_TRIG\_START, two XON1 characters are sent, so the data transfer recovers.

---

#### Note

If software flow control is disabled after an XOFF character is sent, the module transmits XON characters automatically to enable normal transmission.

---

The transmission of XOFF(s)/XON(s) follows the same protocol as transmission of an ordinary byte from the TX FIFO. This means that even if the word length is 5, 6, or 7 characters, the 5, 6, or 7 LSBs of XOFF1/2 and XON1/2 are transmitted. The 5, 6, or 7 bits of a character are seldom transmitted, but this function is included to maintain compatibility with earlier designs.

It is assumed that software flow control and hardware flow control are never enabled simultaneously.

#### 12.2.4.8.1.3.4 Autobauding Modes

In autobauding mode, the UART can extract transfer characteristics (speed, length, and parity) from an "at" (AT) command (ASCII code). These characteristics are used to receive data after an AT and to send data.

The following AT commands are valid:

|    |      |      |
|----|------|------|
| AT | DATA | <CR> |
| at | DATA | <CR> |
| A/ |      |      |
| a/ |      |      |

A line break during the acquisition of the sequence AT is not recognized, and an echo function is not implemented in hardware.

A/ and a/ are not used to extract characteristics, but they must be recognized because of their special meaning. A/ or a/ is used to instruct the software to repeat the last received AT command; therefore, an a/ always follows an AT, and transfer characteristics are not expected to change between an AT and an a/.

When a valid AT is received, AT and all subsequent data, including the final <CR> (0x0D), are saved to the RX FIFO. The autobaud state-machine waits for the next valid AT command. If an a/ (A/) is received, the a/ (A/) is saved in the RX FIFO and the state-machine waits for the next valid AT command.

On the first successful detection of the baud rate, the UART activates an interrupt to signify that the AT (upper or lower case) sequence is detected. The UART\_UASR register reflects the correct settings for the baud rate detected. Interrupt activity can continue in this fashion when a subsequent character is received. Therefore, it is recommended that the software enable the RHR interrupt when using the autobaud mode.

The following settings are detected in autobaud mode with a module clock of 48 MHz:

- Speed:
  - 115.2K baud
  - 57.6K baud
  - 38.4K baud
  - 28.8K baud
  - 19.2K baud
  - 14.4K baud
  - 9.6K baud
  - 4.8K baud
  - 2.4K baud
  - 1.2K baud
- Length: 7 or 8 bits
- Parity: Odd, even, or space

---

**Note**

The combination of 7-bit character plus space parity is not supported.

---

Autobausing mode is selected when the UART\_MDR1[2:0] MODE\_SELECT bit field is set to 0x2. In UART autobausing mode, UART\_DLL, UART\_DLH, and UART\_LCR[5:0] bit field settings are not used; instead, the UART\_UASR register is updated with the configuration detected by the autobausing logic.

#### **UASR Autobausing Status Register Use**

This register is used to set up transmission according to the characteristics of the previous reception instead of the UART\_LCR, UART\_DLL, and UART\_DLH registers when the UART is in autobausing mode.

To reset the autobausing hardware (to start a new AT detection) or to set the UART in standard mode (no autobausing), the UART\_MDR1[2:0] MODE\_SELECT bit field must be set to reset state (0x7) and then to the UART in autobausing mode (0x2) or to the UART in standard mode (0x0).

Use limitation:

- Only 7- and 8-bit characters (5- and 6-bit not supported)
- 7-bit character with space parity not supported
- Baud rate between 1200 and 115.2 bps (10 possibilities)

#### **12.2.4.4.8.1.3.5 Error Detection**

When the UART\_LSR\_UART register is read, the UART\_LSR\_UART[4:2] bit field reflects the error bits (BI: break condition, FE: framing error, PE: parity error) of the character at the top of the RX FIFO (the next character to be read). Therefore, reading the UART\_LSR\_UART register and then reading the UART\_RHR register identifies errors in a character.

Reading the UART\_RHR register updates the BI, FE, and PE bits (see [Table 12-99](#) for the UART mode interrupts).

The UART\_LSR\_UART[7] RX\_FIFO\_STS bit is set when there is an error in the RX FIFO and is cleared only when no errors remain in the RX FIFO.

---

**Note**

Reading the UART\_LSR\_UART register does not cause an increment of the RX FIFO read pointer. The RX FIFO read pointer is incremented by reading the UART\_RHR register.

---

Reading the UART\_LSR\_UART register clears the OE bit if it is set (see [Table 12-99](#) for the UART mode interrupts).

#### **12.2.4.8.1.3.6 Overrun During Receive**

Overrun during receive occurs if the RX state-machine tries to write data into the RX FIFO when it is already full. When overrun occurs, the device interrupts the Host CPU with the UART\_IIR\_UART[5-1] IT\_TYPE bit field set to 0x3 (receiver line status error) and discards the remaining portion of the frame.

Overrun also causes an internal flag to be set, which disables further reception. Before the next frame can be received, the Host CPU must:

- Reset the RX FIFO.
- Read the UART\_RESUME register, which clears the internal flag.

#### **12.2.4.8.1.3.7 Time-Out and Break Conditions**

##### **12.2.4.8.1.3.7.1 Time-Out Counter**

An RX idle condition is detected when the receiver line (RX) is high for a time that equals 4x the programmed word length + 12 bits or manually configured amount of baud clocks, if a value other zero is set in the timeout register. RX is sampled midway through each bit.

For sleep mode, the counter is reset when there is activity on RX.

There are two modes of operation:

- In default operation on the UART\_EFR2[6] TIMEOUT\_BEHAVE is set to 0. For the time-out interrupt, the counter counts only when there is data in the RX FIFO, and the count is reset when there is activity on RX or when the UART\_RHR register is read.
- Optionally, for choose to enable the timeout counter even if no character has been received by setting UART\_EFR2[6] TIMEOUT\_BEHAVE bit. This will generate periodic interrupts if the RX line remains idle. In this mode the counter will auto-reset when a timeout has been reached. Reading the UART\_IIR\_UART will clear the interrupt, but not the counter.

##### **12.2.4.8.1.3.7.2 Break Condition**

When a break condition occurs, TX is pulled low. A break condition is activated by setting the UART\_LCR[6] BREAK\_EN bit. The break condition is not aligned on word stream (a break condition can occur in the middle of a character). The only way to send a break condition on a full character is:

1. Reset the TX FIFO (if enabled).
2. Wait for the transmit shift register to empty (the UART\_LSR\_UART[6] TX\_SR\_E bit is set to 1).
3. Take a guard time according to stop-bit definition.
4. Set the BREAK\_EN bit to 1.

The break condition is asserted while the BREAK\_EN bit is set to 1.

The time-out counter and break condition apply only to UART modem operation and not to IrDA/CIR mode operation.

#### **12.2.4.8.2 RS-485 Mode**

##### **12.2.4.8.2.1 RS-485 External Transceiver Direction Control**

The UART\_MDR3[4] DIR\_EN bit enables hardware control over an external transceiver to support RS-485. The direction signal comes across the DIR port. The direction polarity is controlled by the UART\_MDR3[3] DIR\_POL bit. The direction is determined by the hardware monitoring the TX FIFO and the TX shift register. When both are empty the transceiver is set to RX. There is a guard band delay counter of 3 bit clock cycles after the TX

shift register is going empty to allow time for the stop bit to transition through the transceiver before a direction change to receive might be applied.

Figure 12-121 shows the direction control.



**Figure 12-121. RS-485 External Transceiver Direction Control**

#### 12.2.4.4.8.3 IrDA Mode

##### 12.2.4.4.8.3.1 IrDA Clock Generation: Baud Generator

The IrDA function contains a programmable baud generator and a set of fixed dividers that divide the 48-MHz clock input down to the expected baud rate.

Figure 12-122 shows the baud rate generator and associated controls.



uart-033

**Figure 12-122. IrDA Baud Rate Generator**

**CAUTION**

Before initializing or modifying clock parameter controls (UART\_DLH, UART\_DLL), MODE\_SELECT=DISABLE (UART\_MDR1[2-0] MODE\_SELECT) must be set to 0x7). Failure to observe this rule can result in unpredictable module behavior.

**12.2.4.4.8.3.2 Choosing the Appropriate Divisor Value**

Three divisor values are:

- SIR mode: Divisor value = Operating frequency/(16× baud rate)
- MIR mode: Divisor value = Operating frequency/(41×/42× baud rate)
- FIR mode: Divisor value = None

Table 12-116 lists the IrDA baud rate settings.

**Table 12-116. IrDA Baud Rate Settings**

| Baud Rate  | IR Mode | Baud Multiple | Encoding | DLH, DLL (Decimal) | Actual Baud Rate | Error (%) | Source Jitter (%) | Pulse Duration |
|------------|---------|---------------|----------|--------------------|------------------|-----------|-------------------|----------------|
| 2.4 kbps   | SIR     | 16x           | 3/16     | 1250               | 2.4 kbps         | 0         | 0                 | 78.1 $\mu$ s   |
| 9.6 kbps   | SIR     | 16x           | 3/16     | 312                | 9.6153 kbps      | +0.16     | 0                 | 19.5 $\mu$ s   |
| 19.2 kbps  | SIR     | 16x           | 3/16     | 156                | 19.231 kbps      | +0.16     | 0                 | 9.75 $\mu$ s   |
| 38.4 kbps  | SIR     | 16x           | 3/16     | 78                 | 38.462 kbps      | +0.16     | 0                 | 4.87 $\mu$ s   |
| 57.6 kbps  | SIR     | 16x           | 3/16     | 52                 | 57.692 kbps      | +0.16     | 0                 | 3.25 $\mu$ s   |
| 115.2 kbps | SIR     | 16x           | 3/16     | 26                 | 115.38 kbps      | +0.16     | 0                 | 1.62 $\mu$ s   |

**Table 12-116. IrDA Baud Rate Settings (continued)**

| Baud Rate  | IR Mode | Baud Multiple | Encoding | DLH, DLL (Decimal) | Actual Baud Rate           | Error (%) | Source Jitter (%) | Pulse Duration |
|------------|---------|---------------|----------|--------------------|----------------------------|-----------|-------------------|----------------|
| 0.576 Mbps | MIR     | 41×/42×       | 1/4      | 2                  | 0.5756 Mbps <sup>(1)</sup> | 0         | +1.63/-0.80       | 416 ns         |
| 1.152 Mbps | MIR     | 41×/42×       | 1/4      | 1                  | 1.1511 Mbps <sup>(1)</sup> | 0         | +1.63/-0.80       | 208 ns         |
| 4 Mbps     | FIR     | 6×            | 4 PPM    | —                  | 4 Mbps                     | 0         | 0                 | 125 ns         |

(1) Average value

#### Note

Baud rate error and source jitter table values do not include 48-MHz reference clock error and jitter.

#### 12.2.4.4.8.3.3 IrDA Data Formatting

The methods described in this section apply to all IrDA modes (SIR, MIR, and FIR).

##### 12.2.4.4.8.3.3.1 IR RX Polarity Control

The UART\_MDR2[6] IRRXINVERT bit provides the flexibility to invert the RX pin in the UART to ensure that the protocol at the output of the transceiver has the same polarity at module level. By default, the RX pin is inverted because most transceivers invert the IR receive pin.

##### 12.2.4.4.8.3.3.2 IrDA Reception Control

The module can transmit and receive data, but when the device is transmitting, the IR RX circuitry is automatically disabled by hardware.

Operation of the RX input can be disabled by the UART\_ACREG[5] DIS\_IR\_RX bit.

##### 12.2.4.4.8.3.3.3 IR Address Checking

In all IR modes, when address checking is enabled, only frames intended for the device are written to the RX FIFO. This restriction avoids receiving frames not meant for this device in a multipoint infrared environment. It is possible to program two frame addresses that the UART IrDA receives, with the UART\_XON1\_ADDR1[7-0] XON\_WORD1 and UART\_XON2\_ADDR2[7-0] XON\_WORD2 bit fields.

Setting the UART\_EFR[0] bit to 1 selects address1 checking. Setting the UART\_EFR[1] bit to 1 selects address2 checking. Setting the UART\_EFR[1-0] bit field to 0 disables all address checking operations. If both bits are set, the incoming frame is checked for private and public addresses.

If address checking is disabled, all received frames write to the RX FIFO.

##### 12.2.4.4.8.3.3.4 Frame Closing

A transmission frame can be terminated in two ways:

- Frame-length method: Set the UART\_MDR1[7] FRAME\_END\_MODE bit to 0. The Host CPU writes the value of the frame length to the UART\_TXFLH and UART\_TXFLL registers. The device automatically attaches end flags to the frame when the number of bytes transmitted equals the value of the frame length.
- Set-EOT bit method: Set the UART\_MDR1[7] FRAME\_END\_MODE bit to 1. The Host CPU writes 1 to the UART\_ACREG[0] EOT bit just before it writes the last byte to the TX FIFO. When the Host CPU writes the last byte to the TX FIFO, the device internally sets the tag bit for that character in the TX FIFO. As the TX state-machine reads data from the TX FIFO, it uses this tag-bit information to attach end flags and correctly terminate the frame.

##### 12.2.4.4.8.3.3.5 Store and Controlled Transmission

In store and controlled transmission (SCT) mode, the Host CPU starts writing data to the TX FIFO. Then, after writing a part of a frame (for a bigger frame) or an entire frame (a small frame; that is, a supervisory frame), the Host CPU writes 1 to the UART\_ACREG[2] SCTX\_EN bit (deferred TX start) to start transmission.

SCT mode is enabled by setting the UART\_MDR1[5] SCT bit to 1. This transmission method differs from normal mode, in which data transmission starts immediately after data is written to the TX FIFO. SCT mode is useful for sending short frames without TX underrun.

#### 12.2.4.8.3.3.6 Error Detection

When the UART\_LSR\_UART register is read, the UART\_LSR\_UART[4-2] bit field reflects the error bits [FL, CRC, ABORT] of the frame at the top of the STATUS FIFO (the next frame status to be read).

The error is triggered by an interrupt (for IrDA mode interrupts, see [Table 12-100](#)). The STATUS FIFO must be read until empty (a maximum of eight reads is required).

#### 12.2.4.8.3.3.7 Underrun During Transmission

Underrun during transmission occurs when the TX FIFO is empty before the end of the frame is transmitted. When underrun occurs, the device closes the frame with end flags but attaches an incorrect CRC value. The receiving device detects a CRC error and discards the frame; it can then ask for a retransmission.

Underrun also causes an internal flag to be set, which disables additional transmissions. Before the next frame can be transmitted, the Host CPU must:

- Reset the TX FIFO.
- Read the UART\_RESUME register, which clears the internal flag.

This function can be disabled by the UART\_ACREG[4] DIS\_TX\_UNDERRUN bit, compensated by the extension of the stop-bit in transmission if the TX FIFO is empty.

#### 12.2.4.8.3.3.8 Overrun During Receive

Overrun during receive for the IrDA mode has the same function as that for the UART mode (see [Section 12.2.4.8.1.3.6, Overrun During Receive](#)).

#### 12.2.4.8.3.3.9 Status FIFO

In IrDA modes, a status FIFO records the received frame status. When a complete frame is received, the length of the frame and the error bits associated with the frame are written to the status FIFO.

Reading the UART\_SFREGH[3-0] MSB and UART\_SFREGL[3-0] (LSB) bit fields obtains the frame length. The frame error status is read in the UART\_SFLSR register. Reading the UART\_SFLSR register increments the status FIFO read pointer. Because the status FIFO is eight entries deep, it can hold the status of eight frames.

The Host CPU uses the frame-length information to locate the frame boundary in the received frame data. The Host CPU can screen bad frames using the error status information and can later request the sender to resend only the bad frames.

This status FIFO can be used effectively in DMA mode because the Host CPU must be interrupted only when the programmed status FIFO trigger level is reached, not each time a frame is received.

#### 12.2.4.8.3.3.10 Multi-drop Parity Mode with Address Match

Multi-drop mode is enabled in the UART\_EFR2 register.

Address matching mode is only available with 8 bit character length setting. UART\_LCR[1-0] CHAR\_LENGTH bit fields should always be set to 0x11 (8 bits) prior to enabling the feature.

This mode allows the transmitter to send data on a line where multiple receivers are connected, when supported. In this mode, a set parity bit is used to mark an address, and a parity of 0 denotes data.

This setting affects how the parity is generated. Writing a 0x1 into the UART\_ECR[0] A\_MULTIDROP bit will set the parity bit for the next byte to be sent, which will then be considered an address, for sending a data frame, the UART\_ECR[0] A\_MULTIDROP bit has to be cleared.

On reception if the feature is enabled by setting the UART\_EFR2[2] MULTIDROP bit to 0x1 incoming frames with parity set to 0x1 are treated as address frames and with parity set to 0x0 as data frames. The receiver will drop all data frames until a matching address frame was found.

The matching address is determined by the values set in UART\_MAR, UART\_MMR and UART\_MBR registers and the value set in UART\_EFR2[7] BROADCAST bit.

Table 12-117 summarizes the operation of address matching based on the mentioned values.

**Table 12-117. Details of address matching**

| Received frame      | Received parity | Frame type | UART_MAR            | UART_MMR            | UART_MBR            | UART_EFR2[7] BROADCAST | Operation of receiver                   | Address matching |
|---------------------|-----------------|------------|---------------------|---------------------|---------------------|------------------------|-----------------------------------------|------------------|
| 0xXX <sup>(2)</sup> | 0               | DATA       | X <sup>(1)</sup>    | X <sup>(1)</sup>    | 0xXX <sup>(2)</sup> | X <sup>(1)</sup>       | Drops data until matching address found | N/A              |
| 0xXX <sup>(2)</sup> | 1               | ADDRESS    | 0xXX <sup>(2)</sup> | 0x00                | 0xXX <sup>(2)</sup> | 0                      | Matches any address                     | Yes              |
| 0xEF                | 1               | ADDRESS    | 0xXX <sup>(2)</sup> | 0xXX <sup>(2)</sup> | 0xEF                | 1                      | Matches broadcast address               | Yes              |
| 0x1A                | 1               | ADDRESS    | 0x1A                | 0xFF                | 0xXX <sup>(2)</sup> | 0                      | Single address match                    | Yes              |
| 0xF5                | 1               | ADDRESS    | 0xF3                | 0xF9                | 0xXX <sup>(2)</sup> | 0                      | Group address match                     | Yes              |

(1) X indicates a do not care bit value

(2) 0xXX indicates a do not care 8 bit hexadecimal value

The possible values for matching address can be calculated in the following way:

- Single and Group addresses can be formed by masking the UART\_MAR registers value with the value set in the UART\_MMR register, bits set to 0x0 in the UART\_MMR register result in do not care values.
- Broadcast addresses can be set in the UART\_MBR register if broadcast address is enabled in the UART\_EFR2[7] BROADCAST bit, the module will match on received address frames containing the broadcast address.
- For more details, see example below:
  - UART\_MAR: 0xF3, UART\_MMR: 0xF9, UART\_MBR: 0xFF
  - Single and Group addresses: 0xF1, 0xF3, 0xF5, 0xF7
  - Broadcast addresses: 0xFF

If an address match occurred the matching address value can be obtained from the UART\_RHR register in the following way:

- If the FIFO is disabled or the threshold is set to 0x1, the matching address can be directly read from UART\_RHR as the FIFO will not be overwritten.
- If the FIFO is enabled or the threshold is greater than 0x1, the matching address will be the latest frame in the FIFO with a parity error bit set.

For received data, the parity error bit in the UART\_LSR\_UART register is set when a bit with a parity of 0x1 is received indicating an address frame and the received address matches based on the values of UART\_MAR, UART\_MMR, UART\_MBR and UART\_EFR2[2] MULTIDROP bit.

In Multi-drop mode no parity is used, as the parity bit is used to differentiate address and data frames. The parity error bit is used for indicating an address match.

For enabling the interrupt generation for address matching UART\_IER\_UART[2] LINE\_STS\_IT bit has to be set to 0x1.

An interrupt for the matching address can be identified by reading the UART\_IIR\_UART[5-1] IT\_TYPE bit fields, a value of 0x00011 indicates a receiver line status error. After the UART\_LSR\_UART[2] RX\_PE bit has to be

read, a value of 0x1 indicates that an address match occurred. The reception of a frame is indicated with a value of 0x1 in the UART\_LSR\_UART[0] RX\_FIFO\_E bit as the matching value is written into the FIFO regardless of the frame type (data or address). UART\_LSR\_UART[7] RX\_FIFO\_STS bit will also be set to 0x1 as the parity error bit is used to indicate a matching address.

Note that the operation of the UART\_LSR\_UART[2] RX\_PE bit depends on the value set in UART\_EFR2[2] MULTIDROP bit. If UART\_EFR2[2] MULTIDROP bit is set to 0x0, UART\_LSR\_UART[2] RX\_PE bit is used to indicate a received parity error. If UART\_EFR2[2] MULTIDROP bit is set to 0x1, the receiver is in Multi-drop Address Match mode, thus the value in UART\_LSR\_UART[2] RX\_PE bit is used to indicate an address match.

The interrupt is cleared the same way in both operation modes: reading the UART\_LSR\_UART register updates the values.

#### 12.2.4.8.3.3.11 Time-guard

The time-guard feature enables the UART interface to operate with slow remote devices.

When set, it will insert a number of idle states between transmitting two characters, the length of which can be set in the UART\_TIMEGUARD register. The value in the register defines the number of baud clocks of idle period to insert.

This idle state essentially acts like a long stop bit.

#### 12.2.4.8.3.4 SIR Mode Data Formatting

This section provides specific instructions for SIR mode programming.

##### 12.2.4.8.3.4.1 Abort Sequence

The transmitter can prematurely close a frame (abort) by sending the sequence 0x7DC1. The abort pattern closes the frame without a CRC field or an ending flag.

A transmission frame can be aborted by setting the UART\_ACREG[1] ABORT\_EN bit to 1. When this bit is set to 1, 0x7D and 0xC1 are transmitted and the frame is not terminated with CRC or stop flags.

When a 0x7D character followed immediately by a 0xC1 character is received without transparency, the receiver treats a frame as an aborted frame.

#### CAUTION

When the TX FIFO is not empty and the UART\_MDR1[5] SCT bit is set to 1, the UART IrDA starts a new transfer with data of a previous frame when the aborted frame is sent. Therefore, the TX FIFO must be reset before sending an aborted frame.

#### 12.2.4.8.3.4.2 Pulse Shaping

SIR mode supports the 3/16 or the 1.6- $\mu$ s pulse duration methods. The UART\_ACREG[7] PULSE\_TYPE bit selects the pulse width method in the transmit mode.

#### 12.2.4.8.3.4.3 SIR Free Format Programming

The SIR FF mode is selected by setting the module in the UART mode (UART\_MDR1[2-0] MODE\_SELECT = 0x0) and the UART\_MDR2[3] PULSE bit to 1 to allow pulse shaping.

Because the bit format stays the same, some UART mode configuration registers must be set at specific values:

- UART\_LCR[1-0] CHAR\_LENGTH bit field = 0x3 (8 data bits)
- UART\_LCR[2] NB\_STOP bit = 0x0 (1 stop-bit)
- UART\_LCR[3] PARITY\_EN bit = 0x0 (no parity)

The UART mode interrupts are used for the SIR FF mode, but many are not relevant (XOFF, RTS, CTS, modem status register, etc.).

#### 12.2.4.8.3.5 MIR and FIR Mode Data Formatting

This section describes common instructions for FIR and MIR mode programming.

At the end of a frame reception, the CPU reads the line status register (UART\_LSR\_UART) to detect errors in the received frame.

When the UART\_MDR1[6] SIP\_MODE bit is set to 1, the TX state-machine always sends one SIP at the end of a transmission frame. However, when the SIP\_MODE bit is set to 0, SIP transmission depends on the UART\_ACREG[3] SEND\_SIP bit.

The CPU can set the SEND\_SIP bit at least once every 500 ms. The advantage of this approach over the default approach is that the TX state-machine does not have to send the SIP at the end of each frame, thus reducing the overhead required.

#### 12.2.4.8.4 CIR Mode

##### 12.2.4.8.4.1 CIR Mode Clock Generation

Depending on the encoding method (variable pulse distance/biphase), the Host CPU must develop a data structure that combines 1 and 0 with a  $t$  period to encode the complete frame to transmit. This can then be transmitted to the infrared output with a modulation method, as shown in Figure 12-123.



uart-034

Figure 12-123. CIR Mode Block Components

Based on the requested modulation frequency, the UART\_CFPS register must be set with the correct dividing value to provide an accurate pulse frequency:

$$\text{Dividing value} = (\text{FCLK} / 12) / \text{MODfreq}$$

Where:

FCLK = System clock frequency (48 MHz)

12 = Real value of baud multiple

MODfreq = Effective frequency of the modulation (MHz)

Example: For a targeted modulation frequency of 36 kHz, the value of CFPS must be set to 0x7 (decimal), which provides a modulation frequency of 36.04 kHz.

---

#### Note

The UART\_CFPS register starts with a reset value of 105 (decimal), which translates to a frequency of 38.1 kHz.

---

The duty cycle of these pulses is user-defined by the pulse duty register bits in the UART\_MDR2 register. [Table 12-118](#) shows the duty cycle.

**Table 12-118. CIR Duty Cycle**

| UART_MDR2[5-4]<br>CIR_PULSE_MODE | Duty Cycle (High-Level) |
|----------------------------------|-------------------------|
| 00                               | 1/4                     |
| 01                               | 1/3                     |
| 10                               | 5/12                    |
| 11                               | 1/2                     |

#### 12.2.4.4.8.4.2 CIR Data Formatting

The methods described in this section apply to all CIR modes.

##### 12.2.4.4.8.4.2.1 IR RX Polarity Control

The IR RX polarity control for CIR mode has the same function as that for IrDA mode (see [Section 12.2.4.4.8.3.3.1, IR RX Polarity Control](#)).

##### 12.2.4.4.8.4.2.2 CIR Transmission

In transmission, the Host CPU software must exercise an element of real-time control to transmit data packets, each of which must be emitted at a constant delay from the start-bits of each individual packet. Thus, when sending a series of packets, the packet-to-packet delay must respect a specific delay. Two methods can be used to control this delay:

- Filling the TX FIFO with a number of zero bits that are transmitted with a  $t$  period
- Using an external system timer to control the delay between each start-of-frame or between the end of a frame and the start of the next one. This can be performed by:
  - Controlling the start of the frame using the UART\_MDR1[5] SCT bit and the UART\_ACREG[2] SCTX\_EN bit, depending on the timer status
  - Using the UART\_IIR\_UART[5] TX\_STATUS\_IT interrupt bit to preload the next frame in the TX FIFO and to control the start of the timer (in case of control delay between the end of a frame and the start of the next frame)

##### 12.2.4.4.8.4.2.3 CIR Reception

In reception, there are 2 ways to stop it

- The Host CPU can disable the reception by setting the UART\_ACREG[5] DIS\_IR\_RX bit to 1. When it considers that the reception is finished because a large number of 0 has been received. To receive a new frame, the UART\_ACREG[5] DIS\_IR\_RX bit must be set to 0.
- Using a specific mechanism, depending on the value set in the BOF length register (UART\_EBLR), allows stopping automatically the reception. If the value set in the UART\_EBLR register is different than 0, this feature is enabled and counts a number of bits received at 0. When the counter achieves the value defined in the UART\_EBLR register, the reception is automatically stopped and UART\_IIR\_CIR[2] RX\_STOP\_IT bit is set. When a 1 is detected on the RX pin, the reception is automatically enabled.

There is a limitation when receiving data in UART CIR mode. The IrDA transceivers on the market have a common characteristic that shrinks the hold time of the received modulation pulse. The UART filtering schema on receiving is based on the same encoding mechanism used in transmission.

For the following scenario:

- shift register period: 0.9us
- modulation frequency: 36kHz
- duty cycle: 1/4 of a modulation frequency period

So the data sent in those conditions would look like 7us pulses within 28us period. The UART expects to receive similar incoming data on receive, but available transceiver timing characteristics typically send 2us modulated pulses. Those will be filtered out and RX FIFO will not receive any data.

This does not affect UART CIR mode in transmission.

---

**Note**

The CIR RX demodulation can be bypassed by setting the UART\_MDR3[0] DISABLE\_CIR\_RX\_DEMOD bit.

---

#### 12.2.4.5 UART Programming Guide

This section describes the procedure for operating the UART with FIFO and DMA or interrupts. This three-part procedure ensures the quick start of the UART. It does not cover every UART feature.

The first programming model covers software reset of the UART. The second programming model describes FIFO and DMA configuration. The last programming model describes protocol, baud rate, and interrupt configuration.

##### Note

Each programming model can be used independently of the other two; for instance, reconfiguring the FIFOs and DMA settings only.

Each programming model can be executed starting from any UART register access mode (register modes, submodes, and other register dependencies). However, if the UART register access mode is known before executing the programming model, some steps that enable or restore register access are optional. For more information, see [Section 12.2.4.4.7.1, Register Access Modes](#).

#### 12.2.4.5.1 UART Global Initialization

##### 12.2.4.5.1.1 Surrounding Modules Global Initialization

This section identifies the requirements for initializing the surrounding modules when the UART module is to be used for the first time after a device reset. This initialization of surrounding modules is based on the integration of the UART.

For more information, see [, UART Integration](#).

##### 12.2.4.5.1.2 UART Module Global Initialization

The procedure in [Table 12-119](#) can be used to initialize UART when performing software reset.

**Table 12-119. UART Global Initialization**

| Step                          | Register/Bit Field/Programming Model | Value |
|-------------------------------|--------------------------------------|-------|
| Perform a software reset.     | UART_SYSC[1] SOFTRESET               | 1     |
| Wait until reset is finished. | UART_SYSS[0] RESETDONE               | =1    |

#### 12.2.4.5.2 UART Mode selection

[Table 12-120](#) describes how to set different register access mode.

**Table 12-120. UART Configure Register Access Mode**

| Step                           | Register/Bit Field/Programming Model | Value |
|--------------------------------|--------------------------------------|-------|
| Set the register access mode A | UART_LCR[7] DIV_EN                   | 1     |
|                                | UART_LCR[7-0]                        | #0xBF |
| Set the register access mode B | UART_LCR[7-0]                        | 0xBF  |
| Set the operational mode       | UART_LCR[7] DIV_EN                   | 0     |

#### 12.2.4.5.3 UART Submode selection

This section describes how to set different register access submode.

**Table 12-121. UART Configure Register Access Submode TCR\_TLR**

| Step                                          | Register/Bit Field/Programming Model | Value |
|-----------------------------------------------|--------------------------------------|-------|
| Configure the submode TCR_TLR                 |                                      |       |
| Configure mode B                              | see <a href="#">Table 12-120</a>     |       |
| Enable writing to register bits UART_MCR[7-5] | UART_EFR[4] ENHANCED_EN              | 1     |
| Configure mode A                              | see <a href="#">Table 12-120</a>     | 0x1   |

**Table 12-121. UART Configure Register Access Submode TCR\_TLR (continued)**

| Step                    | Register/Bit Field/Programming Model | Value |
|-------------------------|--------------------------------------|-------|
| Set the submode TCR_TLR | UART_MCR[6] TCR_TLR                  | 1     |

**Table 12-122. UART Configure Register Access Submode MSR\_SPR**

| Step                                          | Register/Bit Field/Programming Model | Value |
|-----------------------------------------------|--------------------------------------|-------|
| First option: configure the submode MSR_SPR   |                                      |       |
| Configure mode B                              | see <a href="#">Table 12-120</a>     |       |
| Set the submode MSR_SPR                       | UART_EFR[4] ENHANCED_EN              | 0     |
| Second option: configure the submode MSR_SPR  |                                      |       |
| Configure mode B                              | see <a href="#">Table 12-120</a>     |       |
| Enable writing to register bits UART_MCR[7-5] | UART_EFR[4] ENHANCED_EN              | 1     |
| Set the submode MSR_SPR                       | UART_MCR[6] TCR_TLR                  | 0     |

**Table 12-123. UART Configure Register Access Submode XOFF**

| Step                  | Register/Bit Field/Programming Model | Value |
|-----------------------|--------------------------------------|-------|
| Configure of the XOFF |                                      |       |
| Configure B           | see <a href="#">Table 12-120</a>     |       |
| Set the submode XOFF  | UART_EFR[4] ENHANCED_EN              | 0     |

#### 12.2.4.5.4 UART Load FIFO trigger and DMA mode settings

##### 12.2.4.5.4.1 DMA mode Settings

To enable and configure program the DMA mode, perform the following steps:

**Table 12-124. DMA Mode Settings**

| Step                                                                               | Register/Bit Field/Programming Model | Value |
|------------------------------------------------------------------------------------|--------------------------------------|-------|
| Set the option of DMA mode configuration                                           | UART_SCR[0] DMA_MODE_CTL             | -     |
| IF Configure DMA mode 0 and 1                                                      | UART_SCR[0] DMA_MODE_CTL             | =0    |
| Select the DMA mode, for more information see <a href="#">Section 12.2.4.4.6.4</a> | UART_FCR[3] DMA_MODE                 | -     |
| IF Configure DMA mode from 0 to 3                                                  | UART_SCR[0] DMA_MODE_CTL             | =1    |
| Select the DMA mode, for more information see <a href="#">Section 12.2.4.4.6.4</a> | UART_SCR[2-1] DMA_MODE_2             | -     |

##### 12.2.4.5.4.2 FIFO Trigger Settings

In this section is described configuration and settings of FIFO trigger level, which enable DMA and interrupt generation.

**Table 12-125. Load FIFO Triggers Defined by the FCR**

| Step                                 | Register/Bit Field/Programming Model | Value |
|--------------------------------------|--------------------------------------|-------|
| Configure register submode TCR_TLR   | see <a href="#">Table 12-121</a>     | 0x-   |
| Set the desire RX FIFO trigger level | UART_FCR[5-4] TX_FIFO_TRIG           | 0x-   |
| Set the desire TX FIFO trigger level | UART_FCR[7-6] RX_FIFO_TRIG           | 0x-   |

**Table 12-126. Load FIFO Triggers Defined by the TLR**

| Step                                 | Register/Bit Field/Programming Model | Value |
|--------------------------------------|--------------------------------------|-------|
| Configure register submode TCR_TLR   | see <a href="#">Table 12-121</a>     | 0x-   |
| Set the desire RX FIFO trigger level | UART_TLR[7-4] RX_FIFO_TRIG_DMA       | 0x-   |
| Set the desire TX FIFO trigger level | UART_TLR[3-0] TX_FIFO_TRIG_DMA       | 0x-   |

**Table 12-127. Load FIFO Triggers Defined by the Concatenated Value**

| Step                                 | Register/Bit Field/Programming Model                         | Value |
|--------------------------------------|--------------------------------------------------------------|-------|
| Configure register submode TCR_TLR   | see <a href="#">Table 12-121</a>                             | 0x-   |
| Set the register bit                 | UART_SCR[7] RX_TRIG_GRANU1                                   | 1     |
| Set the desire RX FIFO trigger level | UART_TLR[7-4] RX_FIFO_TRIG_DMA<br>UART_FCR[7-6] RX_FIFO_TRIG | 0x-   |
| Set the register bit                 | UART_SCR[6] TX_TRIG_GRANU1                                   | 1     |
| Set the desire TX FIFO trigger level | UART_TLR[3-0] TX_FIFO_TRIG_DMA<br>UART_FCR[5-4] TX_FIFO_TRIG | 0x-   |

**12.2.4.5.5 UART Protocol, Baud rate and interrupt settings****12.2.4.5.5.1 Baud rate settings****Table 12-128. UART Baud Rate Settings**

| Step                                         | Register/Bit Field/Programming Model               | Value |
|----------------------------------------------|----------------------------------------------------|-------|
| Disable UART mode                            | UART_MDR1[2-0] MODE_SELECT                         | 0x7   |
| Switch to register configuration mode B      | see <a href="#">Table 12-120</a>                   |       |
| Enable access to UART_IER_UART[7-4]          | UART_EFR[4] ENHANCED_EN                            | 1     |
| Switch register operational mode             | see <a href="#">Table 12-120</a>                   |       |
| Disable sleep mode                           | UART_IER_UART[4] SLEEP_MODE                        | 0     |
| Switch to register configuration mode A or B | see <a href="#">Table 12-120</a>                   |       |
| Set the appropriate divisor value            | UART_DLL[7-0] CLOCK_LSB<br>UART_DLH[5-0] CLOCK_MSB | 0x-   |

**12.2.4.5.5.2 Interrupt settings****Table 12-129. UART Interrupt Settings**

| Step                                                                                        | Register/Bit Field/Programming Model                                                                                                                                                                                                 | Value |
|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Switch to register configuration mode B                                                     | see <a href="#">Table 12-120</a>                                                                                                                                                                                                     | 0x7   |
| Enable access to UART_IER_UART[7-4]                                                         | UART_EFR[4] ENHANCED_EN                                                                                                                                                                                                              | 1     |
| Switch register operational mode                                                            | see <a href="#">Table 12-120</a>                                                                                                                                                                                                     |       |
| Set the desired interrupt configuration (0: Disable the interrupt; 1: Enable the interrupt) | UART_IER_UART[7] CTS_IT<br>UART_IER_UART[6] RTS_IT<br>UART_IER_UART[5] XOFF_IT<br>UART_IER_UART[4] SLEEP_MODE<br>UART_IER_UART[3] MODEM_STS_IT<br>UART_IER_UART[2] LINE_STS_IT<br>UART_IER_UART[1] THR_IT<br>UART_IER_UART[0] RHR_IT | 0x-   |

**12.2.4.5.5.3 Protocol settings**

Load the desired protocol formatting (parity, stop-bit, character length) and switch to register operational mode.

**Table 12-130. UART Protocol Settings**

| Step                                                                                             | Register/Bit Field/Programming Model                                                                                                  | Value |
|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------|
| Load desired protocol formatting, see <a href="#">Section 12.2.4.4.8.1.3.1, Frame Formatting</a> | UART_LCR[5] PARITY_TYPE_2<br>UART_LCR[4] PARITY_TYPE_1<br>UART_LCR[3] PARITY_EN<br>UART_LCR[2] NB_STOP<br>UART_LCR[1-0] PARITY_LENGTH | 0x-   |

**Table 12-130. UART Protocol Settings (continued)**

| Step                                | Register/Bit Field/Programming Model | Value |
|-------------------------------------|--------------------------------------|-------|
| Switch to register operational mode | UART_LCR[7] DIV_EN                   | 0     |
|                                     | UART_LCR[6] BREAK_EN                 |       |

**12.2.4.5.5.4 UART/RS-485/IrDA(SIR/MIR/FIR)/CIR****Table 12-131. UART Mode Selection**

| Step                                                                                                                                                | Register/Bit Field/Programming Model | Value |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Load the desired UART/IrDA (SIR, MIR, FIR)/CIR modes, see <a href="#">Section 12.2.4.4.7.2, UART/RS-485/IrDA (SIR, MIR, FIR)/CIR Mode Selection</a> | UART_MDR1[2-0] MODE_SELECT           | 0x-   |
| Load the desire RS-485 mode, see <a href="#">Section 12.2.4.4.7.2, UART/RS-485/IrDA (SIR, MIR, FIR)/CIR Mode Selection</a>                          | UART_MDR3[4] DIR_EN                  | 0x1   |

**12.2.4.5.5.5 UART Multi-drop Parity Address Match Mode Configuration****Table 12-132. UART Multi-drop Parity Address Match Mode Configuration**

| Step                                        | Register/Bit Field/Programming Model | Value |
|---------------------------------------------|--------------------------------------|-------|
| Disable receive mode                        | UART_ECR[3] RX_EN                    | 0     |
| Enable Multi-drop parity Address match mode | UART_EFR2[2] MULTIDROP               | 1     |
| Set the matching device address             | UART_MAR[7-0] ADDRESS                | 0x-   |
| Set the address match masking               | UART_MMR[7-0] MASK                   | 0x-   |
| Set the broadcast address match             | UART_MBR[7-0] BROADCAST_ADDRESS      | 0x-   |
| Enable broadcast address matching if needed | UART_EFR2[7] BROADCAST               | 1     |
| Enable receive mode                         | UART_ECR[3] RX_EN                    | 1     |

**12.2.4.5.6 UART Hardware and Software Flow Control Configuration**

This section describes the programming steps to enable and configure hardware and software flow control. Hardware and software flow control cannot be used at the same time.

**12.2.4.5.6.1 Hardware Flow Control Configuration****Table 12-133. UART Hardware Flow Control Configuration**

| Step                                                               | Register/Bit Field/Programming Model                        | Value |
|--------------------------------------------------------------------|-------------------------------------------------------------|-------|
| Configure register submode TCR_TLR                                 | see <a href="#">Table 12-121</a>                            | 0x7   |
| Load the start and halt trigger value.                             | UART_TCR[7-4] AUTO_RTS_START<br>UART_TCR[3-0] AUTO_RTS_HALT | 0x-   |
| Enable or disable receive and transmit hardware flow control mode. | UART_EFR[7] AUTO_CTS_EN<br>UART_EFR[6] AUTO_RTS_EN          | 0x-   |

**12.2.4.5.6.2 Software Flow Control Configuration****Table 12-134. UART Software Flow Control Configuration**

| Step                                                        | Register/Bit Field/Programming Model                                                                                         | Value |
|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-------|
| Set the register access submode XOFF                        | see <a href="#">Table 12-123</a>                                                                                             |       |
| Load the software control characters                        | UART_XON1_ADDR1[7-0] XON_WORD1<br>UART_XON2_ADDR2[7-0] XON_WORD2<br>UART_XOFF1[7-0] XOFF_WORD1<br>UART_XOFF2[7-0] XOFF_WORD2 | 0x-   |
| Set the register access submode TCR_TLR                     | see <a href="#">Table 12-121</a>                                                                                             |       |
| Enable or disable XON any function (0: Disable; 1: Enable). | UART_MCR[5] XON_EN                                                                                                           | --    |

**Table 12-134. UART Software Flow Control Configuration (continued)**

| Step                                                                 | Register/Bit Field/Programming Model                        | Value |
|----------------------------------------------------------------------|-------------------------------------------------------------|-------|
| Load start and halt trigger value for software flow control          | UART_TCR[7-4] AUTO_RTS_START<br>UART_TCR[3-0] AUTO_RTS_HALT | 0x-   |
| Enable or disable special character function (0: Disable; 1: Enable) | UART_EFR[5] SPEC_CHAR                                       | 0x-   |
| Set the software flow control mode                                   | UART_EFR[3-0] SW_FLOW_CONTROL                               | 0x-   |

**12.2.4.5.7 IrDA Programming Model****12.2.4.5.7.1 SIR mode****12.2.4.5.7.1.1 Receive**

The following programming model explains how to program the module to receive an IrDA frame with parity forced to 1, baud rate = 115.2 kbps, FIFOs disabled, 2 stop-bits, and 8-bit word length:

**Table 12-135. SIR Mode Receive Settings**

| Step                                                  | Register/Bit Field/Programming Model               | Value        |
|-------------------------------------------------------|----------------------------------------------------|--------------|
| Disable UART mode                                     | UART_MDR1[2-0] MODE_SELECT                         | 0x7          |
| Grant access to the UART_DLL and UART_DLH registers   | UART_LCR[7-0]                                      | 0x80         |
| Load the baud rate(115.2 Kbps)                        | UART_DLL[7-0] CLOCK_LSB<br>UART_DLH[5-0] CLOCK_MSB | 0x1A<br>0x00 |
| Set SIR mode                                          | UART_MDR1[2-0] MODE_SELECT                         | 0x1          |
| Disable access to the UART_DLL and UART_DLH registers | UART_LCR[7-0]                                      | 0x00         |
| Enable the UART_RHR interrupt                         | UART_IER_IRDA[0] RHR_IT                            | 1            |

**12.2.4.5.7.1.2 Transmit**

The following programming model explains how to program the module to transmit an IrDA 6-byte frame with no parity, baud rate = 115.2 kbps, FIFOs disabled, 3/16 encoding, 2 stop-bits, and 7-bit word length:

**Table 12-136. SIR Mode Transmit Settings**

| Step                                                  | Register/Bit Field/Programming Model               | Value        |
|-------------------------------------------------------|----------------------------------------------------|--------------|
| Disable UART mode                                     | UART_MDR1[2-0] MODE_SELECT                         | 0x7          |
| Grant access to the UART_DLL and UART_DLH registers   | UART_LCR[7-0]                                      | 0x80         |
| Load the baud rate (115.2 Kbps)                       | UART_DLL[7-0] CLOCK_LSB<br>UART_DLH[5-0] CLOCK_MSB | 0x1A<br>0x00 |
| Set SIR mode                                          | UART_MDR1[2-0] MODE_SELECT                         | 0x1          |
| Disable access to the UART_DLL and UART_DLH registers | UART_LCR[7-0]                                      | 0x00         |
| Force output DTR to active                            | UART_MCR[0] DTR                                    | 1            |
| Enable the UART_THR interrupt                         | UART_IER_IRDA[1] THR_IT                            | 0x1          |
| Set transmit frame length to 6 bytes                  | UART_TXFLL[7-0] TXFLL                              | 0x06         |
| Set the seven starts of frame transmission            | UART_EBLR[7-0] EBLR                                | 0x08         |
| Set SIR pulse width to be 1.6 $\mu$ s                 | UART_ACREG[7] PULSE_TYPE                           | 1            |

**12.2.4.5.7.2 MIR mode****12.2.4.5.7.2.1 Receive**

The following programming model explains how to program the module to receive an IrDA frame with no parity, baud rate = 1.152 Mbps, and FIFOs disabled.

**Table 12-137. MIR Mode Receive Settings**

| Step                                                  | Register/Bit Field/Programming Model | Value |
|-------------------------------------------------------|--------------------------------------|-------|
| Disable UART mode                                     | UART_MDR1[2-0] MODE_SELECT           | 0x7   |
| Grant access to the UART_DLL and UART_DLH registers   | UART_LCR[7-0]                        | 0x80  |
| Load the baud rate (1.152 bps)                        | UART_DLL[7-0] CLOCK_LSB              | 0x01  |
|                                                       | UART_DLH[5-0] CLOCK_MSB              | 0x00  |
| Set MIR mode                                          | UART_MDR1[2-0] MODE_SELECT           | 0x4   |
| Disable access to the UART_DLL and UART_DLH registers | UART_LCR[7-0]                        | 0x00  |
| Force outputs DTR and RTS to active                   | UART_MCR[1-0]                        | 0x3   |
| Enable the UART_RHR interrupt                         | UART_IER_IRDA[0] RHR_IT              | 1     |

**12.2.4.5.7.2.2 Transmit**

The following programming model explains how to program the module to transmit an IrDA 60-byte frame with no parity, baud rate = 1.152 Mbps, and FIFOs disabled.

**Table 12-138. MIR Mode Transmit Settings**

| Step                                                  | Register/Bit Field/Programming Model | Value |
|-------------------------------------------------------|--------------------------------------|-------|
| Disable UART mode                                     | UART_MDR1[2-0] MODE_SELECT           | 0x7   |
| Grant access to the UART_DLL and UART_DLH registers   | UART_LCR[7-0]                        | 0x80  |
| Load the baud rate (115.2 kbps)                       | UART_DLL[7-0] CLOCK_LSB              | 0x01  |
|                                                       | UART_DLH[5-0] CLOCK_MSB              | 0x00  |
| Set SIR mode                                          | UART_MDR1[2-0] MODE_SELECT           | 0x4   |
| Disable access to the UART_DLL and UART_DLH registers | UART_LCR[7-0]                        | 0x00  |
| Force output DTR to active                            | UART_MCR[0] DTR                      | 1     |
| Enable the UART_THR interrupt                         | UART_IER_IRDA[1] THR_IT              | 0x1   |
| Set transmit frame length to 60 bytes                 | UART_TXFLL[7-0] TXFLL                | 0x3C  |
| Set the eight additional starts of frame transmission | UART_EBLR[7-0] EBLR                  | 0x08  |
| SIP is sent at the end of transmission                | UART_ACREG[3] SEND_SIP               | 1     |

**12.2.4.5.7.3 FIR mode****12.2.4.5.7.3.1 Receive**

The following programming model explains how to program the module to receive the IrDA frame with no parity, baud rate = 4 Mbps, FIFOs enabled, 8-bit word length.

**Table 12-139. FIR Mode Receive Settings**

| Step                                                  | Register/Bit Field/Programming Model                            | Value |
|-------------------------------------------------------|-----------------------------------------------------------------|-------|
| Disable UART mode                                     | UART_MDR1[2-0] MODE_SELECT                                      | 0x7   |
| Grant access to the UART_DLL and UART_DLH registers   | UART_LCR[7-0]                                                   | 0x80  |
| Enable access to change UART_FCR[0]                   | UART_DLL[7-0] CLOCK_LSB                                         | 0x0   |
|                                                       | UART_DLH[7-0] CLOCK_MSB                                         |       |
| FIFO clear and enable                                 | UART_FCR[2-0]                                                   | 0x7   |
| Set the FIFO trigger level                            | see Section 12.2.4.5.4, Load FIFO trigger and DMA mode settings |       |
| Set FIR mode                                          | UART_MDR1[2-0] MODE_SELECT                                      | 0x5   |
| Set frame length                                      | UART_RXFLL[7-0] RXFLL                                           | 0xA   |
| Disable access to the UART_DLL and UART_DLH registers | UART_LCR[7-0]                                                   | 0x00  |

**Table 12-139. FIR Mode Receive Settings (continued)**

| Step                          | Register/Bit Field/Programming Model | Value |
|-------------------------------|--------------------------------------|-------|
| Enable the UART_RHR interrupt | UART_IER_IRDA[0] RHR_IT              | 1     |

**12.2.4.5.7.3.2 Transmit**

The following programming model explains how to program the module to transmit an IrDA 4-byte frame with no parity, baud rate = 4 Mbps, FIFOs enabled, and 8-bit word length.

**Table 12-140. FIR Mode Transmit Settings**

| Step                                                  | Register/Bit Field/Programming Model                                            | Value      |
|-------------------------------------------------------|---------------------------------------------------------------------------------|------------|
| Disable UART mode                                     | UART_MDR1[2-0] MODE_SELECT                                                      | 0x7        |
| Grant access to the UART_DLL and UART_DLH registers   | UART_LCR[7-0]                                                                   | 0x80       |
| Enable access to change UART_FCR[0]                   | UART_DLL[7-0] CLOCK LSB<br>UART_DLH[5-0] CLOCK MSB                              | 0x0        |
| FIFO clear and enable                                 | UART_FCR[2-0]                                                                   | 0x7        |
| Set the FIFO trigger level                            | see <a href="#">Section 12.2.4.5.4, Load FIFO trigger and DMA mode settings</a> |            |
| Set FIR mode                                          | UART_MDR1[2-0] MODE_SELECT                                                      | 0x1        |
| Disable access to the UART_DLL and UART_DLH registers | UART_LCR[7-0]                                                                   | 0x00       |
| Set FIR mode and enable auto-SIP mode                 | UART_MDR1[7-0]                                                                  | 0x45       |
| Set frame length                                      | UART_TXFLL[7-0] TXFLL<br>UART_TXFLH[7-0] TXFLH                                  | 0x4<br>0x0 |
| Force output DTR to active                            | UART_MCR[0] DTR                                                                 | 1          |
| Enable the UART_THR interrupt                         | UART_IER_IRDA[1] THR_IT                                                         | 1          |
| Set the eight additional starts of frame transmission | UART_EBLR[7-0] EBLR                                                             | 0x08       |
| SIP is sent at the end of transmission                | UART_ACREG[3] SEND_SIP                                                          | 1          |

## 12.3 High-speed Serial Interfaces

This section describes the high-speed serial interfaces in the device.

### 12.3.1 Gigabit Ethernet Switch (CPSW3G)

This chapter describes the Gigabit Ethernet Switch (CPSW3G) subsystem in the device.

#### 12.3.1.1 CPSW0 Overview

The 3-port Gigabit Ethernet Switch (CPSW0) subsystem provides Ethernet packet communication for the device and can be configured as an Ethernet switch.

The device has integrated one 3-port Gigabit Ethernet Switch subsystem into device MAIN domain named CPSW0. [Table 12-141](#) shows the CPSW0 module allocation within device domains.

**Table 12-141. CPSW0 Module Allocation within Device Domains**

| Module Instance | Domain |      |
|-----------------|--------|------|
|                 | MCU    | MAIN |
| CPSW0           | -      | ✓    |

[Figure 12-124](#) shows the CPSW0 module overview.



**Figure 12-124. CPSW0 Overview**

#### 12.3.1.1.1 CPSW0 Features

The 3-port CPSW0 subsystem provides the following features:

- Two Ethernet ports (port 1 and 2) with selectable RGMII and RMII interfaces and an internal Communications Port Programming Interface (CPPI) port (port 0)
- Synchronous 10/100/1000 Mbit operation
- Flexible logical FIFO-based packet buffer structure
- Cut through switch support
- Eight priority level Quality Of Service (QOS) support (802.1p)
- Support for Audio/Video Bridging (P802.1Qav/D6.0)
- Support for IEEE 1588 Clock Synchronization (2008 Annex D, Annex E and Annex F)
  - Timestamp module capable of time stamping external timesync events like Pulse-Per-Second and also generating Pulse-Per-Second outputs
  - CPTS module that supports time stamping for IEEE1588 with support for 4 hardware push events and generation of compare output pulses
- DSCP Priority Mapping (IPv4 and IPv6)

- Energy Efficient Ethernet (EEE) support (802.3az)
- Flow Control Support (802.3x)
- Wire rate switching (802.1d)
- Non-Blocking switch fabric
- Time Sensitive Network Support
  - IEEE P802.3br Interspersing Express Traffic
  - IEEE 802.1Qbv Enhancements for Scheduled Traffic
- Address Lookup Engine (ALE)
  - 512 ALE table entries
  - Configurable number of addresses plus VLANs
  - Wire rate lookup
  - Host controlled time-based aging and/or auto-aging
  - Spanning tree support
  - L2 address lock and L2 filtering support
  - MAC authentication (802.1x)
  - Receive-based or destination-based Multicast and Broadcast rate limits
  - MAC address blocking
  - Source port locking
  - OUI (Vendor ID) host accept/deny feature
  - Configurable number of classifier/policers (32)
  - VLAN support
    - 802.1Q compliant
      - Auto add port VLAN for untagged frames on ingress
      - Auto VLAN removal on egress and auto pad to minimum frame size
- EtherStats and 802.3Stats Remote Network Monitoring (RMON) statistics gathering (per port statistics)
- Ethernet Mac transmit to Ethernet Mac receive Loopback mode (digital loopback) supported
- CPSGMII Loopback Modes (transmit to receive)
- Maximum frame size of 2024 bytes
- Management Data Input/Output (MDIO) module for PHY Management with Clause 45 support
- Programmable interrupt control with selected interrupt pacing
- Host port CPPI Streaming Packet Interface (CPPI\_GCLK)
- Digital loopback and FIFO loopback modes supported
- Emulation support
- Full duplex mode supported in 10/100/1000 Mbps. Half-duplex mode supported only in 10/100 Mbps modes only.
- RAM Error Detection and Correction (SECDED)

#### **12.3.1.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

---

##### **Note**

Some features may not be available. See *Module Integration* for more information.

---

#### **12.3.1.1.3 CPSW Terminology**

**Terminology:**

|              |                                           |
|--------------|-------------------------------------------|
| <b>AVB</b>   | Audio Video Bridging                      |
| <b>AVBTP</b> | Audio Video Bridging Trasport Protocol    |
| <b>BCCA</b>  | Best Controller Clock Algorithm           |
| <b>CFI</b>   | Canonical Format Indicator                |
| <b>CPPI</b>  | Communications Port Programming Interface |
| <b>CPSW</b>  | Common Platform Switch                    |
| <b>DLR</b>   | Device Level Ring                         |
| <b>DSCP</b>  | Differentiated Services Code Point        |
| <b>EEE</b>   | Energy Efficient Ethernet                 |
| <b>EMAC</b>  | Ethernet Media Access Control             |
| <b>EOP</b>   | End of Packet                             |
| <b>EOQ</b>   | End of Queue                              |
| <b>IPG</b>   | Inter-Packet Gap                          |
| <b>LPI</b>   | Low Power Indicator                       |
| <b>MDIO</b>  | Management Data Input/Output              |
| <b>MOF</b>   | Middle of Frame                           |
| <b>OUI</b>   | Organizationally Unique Identifier        |
| <b>PFC</b>   | Priority based Flow Control               |
| <b>PTP</b>   | Precision Time Protocol                   |
| <b>RMON</b>  | Remote Monitoring                         |
| <b>RTCP</b>  | RTP Control Protocol                      |
| <b>RTP</b>   | Real-time Transport Protocol              |
| <b>SCR</b>   | Switched Central Resource                 |
| <b>SRP</b>   | Stream Reservation Protocol               |
| <b>TOS</b>   | Type of Service                           |
| <b>VLAN</b>  | Virtual Local Area Network                |

### 12.3.1.2 CPSW0 Environment

This section describes the CPSW0 external connections (environment).

#### 12.3.1.2.1 CPSW0 RMII Interface

Figure 12-125 shows a device with integrated EMAC and MDIO interfaced via a RMII connection in a typical system. The individual CPSW0 and MDIO signals for the RMII interface are summarized in Table 12-142.

The CPSW0 module integrated in the device supports internal and external clock sources in RMII mode. Figure 12-125 shows the internal clock source for RMII\_MHZ\_50\_CLK clock. It is 50 MHz clock source that is provided on the CLKOUT0 device pin. This clock has to be routed on the PCB to the RMII\_REF\_CLK device pin and the external PHY, RMII clock input.

For more information, refer to either the IEEE 802.3 standard or ISO/IEC 8802-3:2000(E).



**Figure 12-125. RMII Interface Typical Application (Internal Clock Source)**

Figure 12-126 shows the external clock source for RMII\_MHZ\_50\_CLK clock. In this case a 50 MHz clock is available on the PCB and it can be sourced from an oscillator or from the Ethernet PHY. This externally generated clock should be routed to both RMII\_REF\_CLK device pin and the external PHY, RMII clock input.



**Figure 12-126. RMII Interface Typical Application (External Clock Source)**

**Table 12-142. RMII I/O Description**

| Signal <sup>(2)</sup> | Device Pin(s)   | I/O <sup>(1)</sup> | Description                                                                                                                                                                                                                                                                                                                |
|-----------------------|-----------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RMIIin_RXD[1:0]       | RMIIin_RXD[1:0] | O                  | Transmit data. The transmit data pins are a collection of 2 bits of data. TXD0 is the least-significant bit (LSB). The signals are synchronized by RMII_MHZ_50_CLK and valid only when RMIIin_TX_EN is asserted.                                                                                                           |
| RMIIin_TX_EN          | RMIIin_TX_EN    | O                  | RMII transmit enable. The transmit enable signal indicates that the RMIIin_RXD[1:0] pins are generating data for use by the PHY. RMIIin_TX_EN is synchronous to RMII_MHZ_50_CLK.                                                                                                                                           |
| RMII_MHZ_50_CLK       | RMII_REF_CLK    | I                  | RMII 50MHz reference clock. The reference clock is used to synchronize all RMII signals. RMII_MHZ_50_CLK must be continuous and fixed at 50 MHz.                                                                                                                                                                           |
| RMIIin_RXD[1:0]       | RMIIin_RXD[1:0] | I                  | Receive data. The receive data pins are a collection of 2 bits of data. RXD0 is the least-significant bit (LSB). The signals are synchronized by RMII_MHZ_50_CLK and valid only when RMIIin_CRS_DV is asserted and RMIIin_RX_ER is de-asserted.                                                                            |
| RMIIin_CRS_DV         | RMIIin_CRS_DV   | I                  | Carrier sense/receive data valid. Multiplexed signal between carrier sense and receive data valid.                                                                                                                                                                                                                         |
| RMIIin_RX_ER          | RMIIin_RX_ER    | I                  | Receive error. The receive error signal is asserted to indicate that an error was detected in the received frame.                                                                                                                                                                                                          |
| MDIO_MCLK             | MDIO0_MDC       | O                  | Management data clock (MDIO_MCLK). The MDIO data clock is sourced by the MDIO module on the system. It is used to synchronize MDIO data access operations done on the MDIO0_MDIO data pin.                                                                                                                                 |
| MDIO_MDIO             | MDIO0_MDIO      | I/O                | MDIO data pin drives PHY management data into and out of the PHY by way of an access frame consisting of start of frame, read/write indication, PHY address, register address, and data bit cycles. The MDIO0_MDIO pin acts as an output for all but the data bit cycles at which time it is an input for read operations. |

(1) I = Input; O = Output

(2) **n 1 to 2**

### 12.3.1.2.2 CPSW0 RGMII Interface

Figure 12-127 shows a device with integrated EMAC and MDIO interfaced via a RGMII connection in a typical system. The individual CPSW0 and MDIO signals for the RGMII interface are summarized in Table 12-143.



**Figure 12-127. RGMII Interface Typical Application**

**Table 12-143. RGMII I/O Description**

| Signal <sup>(2)</sup> | Device Pin(s)   | I/O <sup>(1)</sup> | Description                                                                                                                                                                                                                                                                                                                     |
|-----------------------|-----------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RGMIIin_TD[3:0]       | RGMIIin_TD[3:0] | O                  | The transmit data pins are a collection of 4 bits of data. TD0 is the least-significant bit (LSB). The signals are valid only when RGMIIin_TCTL is asserted.                                                                                                                                                                    |
| RGMIIin_TCTL          | RGMIIin_TX_CTL  | O                  | Transmit Control/enable. The transmit enable signal indicates that the TD pins are generating data for use by the PHY.                                                                                                                                                                                                          |
| RGMIIin_TCLK          | RGMIIin_TXC     | O                  | The transmit reference clock. The clock is 2.5 MHz at 10 Mbps operation, 25 MHz at 100 Mbps operation, and 125 MHz at 1000 Mbps of operation.                                                                                                                                                                                   |
| RGMIIin_RD[3:0]       | RGMIIin_RD[3:0] | I                  | The receive data pins are a collection of 4 bits of data. RD0 is the least-significant bit (LSB).<br>The signals are valid only when RGMIIin_RX_CTL is asserted                                                                                                                                                                 |
| RGMIIin_RCTL          | RGMIIin_RX_CTL  | I                  | The receive data valid/control signal indicates that the RD pins are nibble data for use by the EMAC.                                                                                                                                                                                                                           |
| RGMIIin_RCLK          | RGMIIin_RXC     | I                  | The receive clock is a continuous clock that provides the timing reference for receive operations. The clock is generated by the PHY and is 2.5 MHz at 10 Mbps operation, 25 MHz at 100 Mbps operation, 125 MHz at 1000 Mbps of operation.                                                                                      |
| MDIO_MCLK             | MDIO0_MDC       | O                  | Management data clock (MDIO_MCLK). The MDIO data clock is sourced by the MDIO module on the system. It is used to synchronize MDIO data access operations done on the MDIO0_MDIO pin.                                                                                                                                           |
| MDIO_MDIO             | MDIO0_MDIO      | I/O                | The MDIO0_MDIO pin drives PHY management data into and out of the PHY by way of an access frame consisting of start of frame, read/write indication, PHY address, register address, and data bit cycles. The MDIO0_MDIO pin acts as an output for all but the data bit cycles at which time it is an input for read operations. |

(1) I = Input; O = Output

(2) n 1 to 2

---

**Note**

The Control Module registers assign the specific function to the device pads. For more information on Control Module settings, see *Pad Configuration Registers* in *Control Module (CTRL\_MMR)* and the device-specific Datasheet.

---

**12.3.1.3 Integration**

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.3.1.4 CPSW0 Functional Description

The three-port switch Ethernet subsystem module (CPSW) is compliant to the IEEE Std 802.3 Specification. CPSW top level functional block diagram is shown in [Figure 12-128](#).

##### 12.3.1.4.1 Functional Block Diagram

The three-port Ethernet subsystem consists of:

- CPSW\_3G
- One RGMII<sub>n</sub> (where  $n = 1$  to  $2$ ) interface module
- One RMII<sub>n</sub> (where  $n = 1$  to  $2$ ) interface module
- One MII<sub>n</sub> (where  $n = 1$  to  $2$ ) interface module
- One Host Port 0 CPPI Packet Streaming Interface
- CPSW subsystem control registers (REG)
- One MDIO interface module
- One Interrupt Controller module



**Figure 12-128. CPSW Top Level Block Diagram**

##### 12.3.1.4.2 CPSW Ports

The Ethernet Subsystem has three ports. Port 0 is the Host port (internal to the Subsystem). Port 1 and 2 are the external ports connected to RGMII, RMII, MII interfaces as per the interface selected.

Naming conventions followed in this chapter:

- Port0 is referred to the CPPI Host Port
- Port1 and 2 are referred to the interfaces RGMII/RMII/MII

##### 12.3.1.4.2.1 Interface Mode Selection

The three-port switch (CPSW) Ethernet Subsystem has one 10/100/1000 Ethernet port with selectable RMII, RGMII, and MII interfaces.

The interface modes for all 2 Ethernet ports are selected by configuring the Ethernet interface mode selection bitfield (PORT\_MODE\_SEL) in the CTRLMMR\_ENET1\_CTRL and CTRLMMR\_ENET2\_CTRL registers.

See the device-specific Datasheet for configuring the pin mux mode as per the interface selected.

##### 12.3.1.4.3 Clocking

###### 12.3.1.4.3.1 Subsystem Clocking

CPSW clocking summary is shown in *CPSW Integration*.

#### 12.3.1.4.3.2 Interface Clocking

Data is transmitted and received with respect to the reference clocks of the interface pins.

##### 12.3.1.4.3.2.1 RGMII Interface Clocking

RGMII\_RXC, RGMII\_TXC frequencies are:

- 2.5 MHz at 10 Mbps
- 25 MHz at 100 Mbps
- 125 MHz at 1000 Mbps

##### 12.3.1.4.3.2.2 RMII Interface Clocking

RMII interface clock RMII\_50MHZ\_CLK frequency is:

- 50 MHz at 10 Mbps
- 50 MHz at 100 Mbps

For more details on RMII clocking, please see *CPSW0 Integration*

CTRLMMR\_CLKOUT\_CTRL[4]CLK\_EN and CTRLMMR\_CLKOUT\_CTRL[0]CLK\_SEL bits are used to enable and select the clock source for CLKOUT device pin.

##### 12.3.1.4.3.2.3 MDIO Clocking

The MDIO clock is based on a divide-down of the interface (CPPI\_ICLK) clock. The application software or driver must control the divide-down value.

See the CPSW\_MDIO\_CONTROL\_REG register for configuring the Clock Divider ([15-0]CLKDIV) value.

##### 12.3.1.4.4 Software IDLE

The submodule software idle register bits enable CPSW operation to be completely or partially suspended by software control. There are two CPSW submodules that contain software idle register bits. Each of the two submodules may be individually commanded to enter the idle state. The idle state is entered at packet boundaries, and no further packet operations will occur on an idled submodule until the idle command is removed. The CPSW module enters the idle state when all two submodules are commanded to enter and have entered the idle state. Idle status is determined by reading or polling the two submodule idle bits. The CPSW\_3G is in the idle state when all two submodules are in the idle state. The CPSW\_SOFT\_IDLE\_REG[0] SOFT\_IDLE bit may be set if desired after the submodules are in the idle state. The SOFT\_IDLE bit causes packets to not be transferred from one FIFO to another FIFO internal to the switch.

##### 12.3.1.4.5 Interrupt Functionality

CPSW Ethernet Subsystem has six interrupt outputs:

- Cn\_FH\_PEND\_INTR - FHost (from host to Ethernet) level interrupt
- Cn\_TH\_PEND\_INTR - THost (from Ethernet to host) level interrupt
- Cn\_TH\_THRESH\_PEND\_INTR - THost (from Ethernet to host) non-paced level interrupt
- Cn\_MISC\_PEND\_INTR - Miscellaneous non-paced pending interrupt
- ECC\_SEC\_PEND\_INTR: ECC SEC pending interrupt - from CPSW ECC module. This interrupt is also included in the C0\_MISC\_PEND\_INTR if enabled or can be used separately if desired.
- ECCDED\_PEND\_INTR: ECC DED pending interrupt - from CPSW ECC module. This interrupt is also included in the C0\_MISC\_PEND\_INTR if enabled or can be used separately.

---

##### Note

n = 0 to \$num\_cores-1

---

##### 12.3.1.4.5.1 EVNT\_PEND Interrupt

See [Section 12.3.1.4.7, Common Platform Time Sync \(CPTS\)](#) for more details on this interrupt.

#### **12.3.1.4.5.2 Statistics Interrupt (STAT\_PEND0)**

The statistics level interrupt (STAT\_PEND0) will be asserted, if enabled when any statistics value is greater than or equal to 8000 0000h. The statistics interrupt is cleared by writing to decrement any statistics values greater than 8000 0000h (such that their new values are less than 8000 0000h). The statistics are mapped into internal memory space and are 32-bits wide. The raw and masked statistics interrupt status may be read by reading the CPSW\_CPTS\_INTSTAT\_RAW\_REG and CPSW\_CPTS\_INTSTAT\_MASKED\_REG registers, respectively.

The statistics interrupt is enabled by setting to 1h the TS\_PEND\_EN bit in the CPSW\_CPTS\_INT\_ENABLE\_REG register.

#### **12.3.1.4.5.3 ECC DED Level Interrupt (ECC\_DED\_INT)**

Level interrupt (ECC\_DED\_INT) indicating an ECC double error has been detected.

#### **12.3.1.4.5.4 ECC SEC Level Interrupt (ECC\_SEC\_INT)**

Level interrupt (ECC\_SEC\_INT) indicating an ECC single error has been detected and corrected.

#### **12.3.1.4.5.5 MDIO Interrupts**

##### **Normal Mode: (CPSW\_MDIO\_POLL\_REG[30] STATECHANGEMODE = 0h)**

MDIO\_LINKINT event is set if there is a change in the link state of the PHY corresponding to the address in the PHYADR\_MON field of the CPSW\_MDIO\_USER\_PHY\_SEL\_REG\_k register and the corresponding LINKINT\_ENABLE bit is set. The MDIO\_LINKINT event is also captured in the MDIO CPSW\_MDIO\_LINK\_INT\_MASKED\_REG register. When the GO bit in the CPSW\_MDIO\_USER\_ACCESS\_REG\_k register transitions from 1 to 0, indicating the completion of a user access, and the corresponding USERINTMASKSET bit in the CPSW\_MDIO\_USER\_INT\_MASK\_SET\_REG register is set, the MDIO\_USERINT signal is asserted. The MDIO\_USERINT event is also captured in the CPSW\_MDIO\_USER\_INT\_MASKED\_REG register.

##### **State Change Mode: (CPSW\_MDIO\_POLL\_REG[30] STATECHANGEMODE = 1h)**

In State Change Mode, the MDIO will assert MDIO\_LINKINT[0] when any bit in the MDIO CPSW\_MDIO\_ALIVE\_REG or CPSW\_MDIO\_LINK\_REG registers changes due to MDIO operations. The MDIO\_LINKINT event is also captured in the CPSW\_MDIO\_LINK\_INT\_MASKED\_REG register. MDIO\_LINKINT[1] output is unused in State Change Mode. The CPSW\_MDIO\_USER\_PHY\_SEL\_REG\_k registers are unused in state change mode.

##### **Manual Mode: (CPSW\_MDIO\_POLL\_REG[31] MANUALMODE = 1h)**

Manual Mode allows software to directly control the MDIO serial clock output (CPSW\_MDIO\_MANUAL\_IF\_REG[2] MDIO\_MDCLK\_O) and the MDIO serial data output enable (CPSW\_MDIO\_MANUAL\_IF\_REG[1] MDIO\_OE). Manual Interface Mode is enabled when the MANUALMODE bit is set in the CPSW\_MDIO\_POLL\_REG register. Manual Mode is intended to be used by software for slow speed general purpose IO operations and not for MDIO PHY operations.

#### **12.3.1.4.6 CPSW\_3G**

The CPSW\_3G RMII/ RGMII interface is compliant to the IEEE Std 802.3 Specification.

The CPSW\_3G contains two Ethernet port interfaces (Ethernet port 1 and 2), one CPPI packet streaming interface host port (port 0), Common Platform Time Sync (CPTS), ALE Engine and Statistics (STATS). A top-level block diagram of the CPSW\_3G is shown in [Figure 12-129](#).



**Figure 12-129. CPSW\_3G Block Diagram**

#### **12.3.1.4.6.1 Address Lookup Engine (ALE)**

The Address Lookup Engine (ALE) is a sub-block of the CPSW Switch and it processes all received packets and determines to which port(s) the packet should be forwarded. The ALE uses the incoming packet received port number, destination address, source address, length/type, and VLAN information to determine how the packet should be forwarded. The ALE outputs the port mask to the switch fabric that indicates the port(s) the packet should be forwarded to. The ALE is enabled when the ENABLE\_ALE bit in the CPSW\_ALE\_CONTROL register is set. All packets are dropped when the ENABLE bit is cleared to 0.

### **12.3.1.4.6.1.1 Error Handling**

In normal operation, the Ethernet port modules are configured to issue an abort, instead of an end of packet, at the end of a packet that contains an error (runt, frag, oversize, jabber, crc, alignment, code etc.) or at the end of a MAC control packet. However, when the CPSW\_PN\_MAC\_CONTROL\_REG\_k configuration bit(s) RX\_CEF\_EN, RX\_CSF\_EN, or RX\_CMF\_EN are set, error frames, short frames or MAC control frames have a normal end of packet instead of an abort at the end of the packet. When the ALE receives a packet that contains errors (due to a set header error bit), or a MAC control frame and does not receive an abort, the packet will be forwarded only to the host port (port 0). Packets with errors that are forwarded to the host have no VLAN untagging or drop due to rate limiting. No ALE learning occurs on packets with errors or mac control frames. Learning is based on source address and lookup is based on destination address. Directed packets from the host are not learned, updated, or touched.

### **12.3.1.4.6.1.2 Bypass Operations**

The ALE may be configured to operate in bypass mode by setting the ENABLE\_BYPASS bit in the CPSW\_ALE\_CONTROL register. When in bypass mode, all Ethernet port received packets are forwarded only to the host port (port 0). In bypass mode, the ALE processes host port transmit packets the same as in normal mode. In general, packets would be directed by the host in bypass mode.

#### 12.3.1.4.6.1.3 OUI Deny or Accept

The ALE may be configured to operate in OUI deny mode by setting the ENABLE\_OUI\_DENY bit in the CPSW\_ALE\_CONTROL register. When in OUI deny mode, a packet with a non-matching OUI source address will be dropped unless the destination address matches a multicast table entry with the SUPER bit set. When ENABLE\_OUI\_DENY bit is cleared, any packet source address matching an OUI address table entry will be dropped to the host unless the destination address matches with a supervisory address table entry. Broadcast packets will be dropped unless the broadcast address is entered into the table with the SUPER bit set. Unicast packets will be dropped unless the unicast address is in the table with BLOCK and SECURE both set (supervisory unicast packet).

#### 12.3.1.4.6.1.4 Statistics Counting

ALE sends many statistics along with the frame routing so the CPSW can count them on a per port basis. There are many reasons to drop frames the below drop events are individually counted in CPSW per port statistics counters.

**Table 12-144. Learned Address Control Bits**

| Abbreviation | Description                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------|
| vddc         | Dual VLAN or Double VLAN drop counter.                                                                                |
| frdc         | IPv4 fragmented drop counter.                                                                                         |
| nldc         | IPv4 Protocol or IPv6 Next Header drops due to next header limit drop counter.                                        |
| etdc         | Ether Type field is <= 1500 and the frame size is too small drop counter.                                             |
| smdc         | The Source Address has bit 40 set drop counter.                                                                       |
| badc         | The Source or Destination Address blocked drop counter.                                                               |
| svdc         | The Source Address is locked to a different port drop counter.                                                        |
| des          | The Source and Destination are equal and the Source Address is not in the table drop counter.                         |
| adc          | The Source Address is not in the table in authentication mode drop counter.                                           |
| vicdc        | The VLAN ingress check failed drop counter.                                                                           |
| rldc         | Rate Limit Drop Counter.                                                                                              |
| over         | Lookup Overflow, the rate of the ALE clock is not sufficient to handle the incoming frame rate (Should never happen). |
| drop         | Packet is dropped and not forwarded.                                                                                  |

#### 12.3.1.4.6.1.5 Automotive Security Features

The ALE has many automotive security features that most enterprise switches do not require.

- VLANs can be configured to not allow fragmented IPv4 frames. That is a VLAN can be configured to not allow fragmented IPv4 traffic.
- VLANs can be configured to only allow up to four different IPv4 Protocols or IPv6. Next Header values, for example a VLAN can be configured to only allow TCP traffic in both IPv4 and IPv6 packets.
- Drop invalid Source Addresses, that is drop Source Addresses with bit 40 set (Multicast/Broadcast indicator on Destination Addresses)
- IEEE802.3 Length Check, drop frames that the IEEE802.3 Length is not contained within the frame. (Ether Types 0-1500)
- Any Source Address can be secured to a port dropping any attempts from other ports to masquerade as a service.

- Any source or destination address can be blocked.
- Per Port or Per VLAN ingress checking, dropping traffic from non-member ports.
- Classification, Policing on L2 and L3 information.

#### **12.3.1.4.6.1.6 CPSW Switching Solutions**

The host port can operate in many different modes as well depending on the functionality of the host. It is important to understand the modes and configure them properly.

The ALE Table is designed to maximize the modes without compromise of the system functionality as well.

##### **12.3.1.4.6.1.6.1 Basics of 3-port Switch Type**

The 3-port switch has a host port, and that port can operate in two fundamental modes. Bridge mode allows the host to extent the switched domain to another network like Wi-Fi or another multi-port switch. In this case the host must be able to see unknown unicast addresses so they can be broadcast to the other network. In Port mode the host need not see any unknown unicast traffic. The CPSW\_ALE\_CONTROL[8] EN\_HOST\_UNI\_FLOOD bit determines the host mode for unknown unicast traffic. This bit should only be set if the user is bridging two or more networks together.

The 3-port switch can operate like a two-port switch using the ALE table just for the host info, the only adder is now other VLANs need to be supported for transit traffic between the external ports. This can easily be done using the default VLAN rules so no ALE table entries are used.

The 3-port switch can also operate in a fully authenticated environment where all network nodes are registered via the 802.1x based protocols. In this case the ALE table is filled with network node addresses that have been authenticated

#### **12.3.1.4.6.1.7 VLAN Routing and OAM Operations**

##### **12.3.1.4.6.1.7.1 InterVLAN Routing**

The CPSW module supports wire rate InterVLAN routing for a small number of routes, that is the host will setup an ALE classifier with and associated egress operation that will cause the CPSW to perform particular egress operations. The ALE can optionally check time to live validity as well.

The ALE uses the classifier along with an egress opcode, destination port mask and TTL check field to tell the CPSW to manipulate the packet on the egress. The CPSW will use the opcode along with a per port operation table to process the packet. By setting up the CPSW egress operation table you can replace the DA, SA and VLAN along with optionally updating the time to live IP header field. This allows the CPSW to perform the routing function for a small set of routes without getting the local host/CPU involved.

The Egress opcode will only be use for a classifier match and the packet would normally be sent only to the host. That is the host would have routed the packet but the CPSW has been configured to do the work instead. In the event that the time-to-live check feature is enabled and the time-to-live is either 0 or 1, the packet will not get the egress opcode and instead be sent to the host as if the route is not setup. This allows the host to deal with invalid TTL fields.

##### **12.3.1.4.6.1.7.2 OAM Operations**

The ALE supports OAM loopback on ports so that a remote link can be tested. That is a port placed in OAM loopback will echo packets received on a port back to the port with an egress op of 0xFF which will swap the SA and DA on egress in the CPSW.

Any supervisory packet will not be affected, so the spanning tree and other bridging functions are not affected.

Packets will only be echoed if the port is in OAM loopback mode, the received packet is not a supervisor packet. The port is in a forwarding state and the packet received DA!=SA and there are no errors in the packet.

When a port is in OAM loopback the port will not egress traffic from other ports, no address for loop backed traffic will be learned if enabled. Any packet received on the OAM loopback port with an error will be process as if the port is not in OAM. That is if the host has enabled copy errored frames the errored frames will be sent to the host instead.

#### 12.3.1.4.6.1.8 Supervisory packets

Multicast supervisory packets are designated by the SUPER bit in the table entry. Unicast supervisory packets are indicated when BLOCK and SECURE are both set. Supervisory packets are not dropped due to rate limiting, OUI, or VLAN processing. The purpose of supervisory packets is to allow packets that would be otherwise blocked to be forwarded for special purposes.

#### 12.3.1.4.6.1.9 Address Table Entry

The ALE table contains multiple table entry types. Each table entry represents a free entry, an address, a VLAN, an address/VLAN pair, or an OUI address. Software should ensure that there are not double address entries in the table. The double entry used would be indeterminate. Reserved table bits must be written with zeroes.

Source Address learning occurs for packets with a unicast, multicast or broadcast destination address and a unicast or multicast (including broadcast) source address. Multicast source addresses have the group bit (bit 40) cleared before ALE processing begins, changing the multicast source address to a unicast source address. A multicast address of all ones is the broadcast address which may be added to the table. A learned unicast source address is added to the table with the following control bits:

**Table 12-145. Learned Address Control Bits**

| Bit(s)  | Value |
|---------|-------|
| Ageable | 1     |
| Touch   | 1     |
| BLOCK   | 0     |
| SECURE  | 0     |

If a received packet has a source address that is equal to the destination address then the following occurs:

- The address is learned if the address is not found in the table.
- The address is updated if the address is found.
- The packet is dropped.

#### Table Entry Type

00 - Free Entry

01 - Address Entry : unicast or multicast determined by destination **address bit 40**.

10 - VLAN entry

11 - VLAN Address Entry : unicast or multicast determined by **address bit 40**.

#### 12.3.1.4.6.1.9.1 Multicast Address Table Entry

**Table 12-146. Multicast Address Table Entry Bit Values**

| 70:68    | 67:66     | 65    | 64       | 63:62               | 61:60              | 59:48    | 47:0                  |
|----------|-----------|-------|----------|---------------------|--------------------|----------|-----------------------|
| Reserved | PORT_MASK | SUPER | Reserved | MCAST_FWD_<br>STATE | ENTRY_TYPE<br>(01) | Reserved | MULTICAST_A<br>DDRESS |

#### Supervisory Packet (SUPER)

When set, this field indicates that the packet with a matching multicast destination address is a supervisory packet.

0: Non-supervisory packet

1: Supervisory packet

#### Port Mask(1:0) (PORT\_MASK)

This 2-bit field is the port bit mask that is returned with a found multicast destination address. There may be multiple bits set indicating that the multicast packet may be forwarded to multiple ports (but not the receiving port).

#### **Multicast Forward State (MCAST\_FWD\_STATE)**

Indicates the port state(s) required for the received port on a destination address lookup in order for the multicast packet to be forwarded to the transmit port(s). A transmit port must be in the Forwarding state in order to forward the packet. If the transmit PORT\_MASK has multiple set bits then each forward decision is independent of the other transmit port(s) forward decision.

00 - Forwarding

01 - Blocking/Forwarding/Learning

10 - Forwarding/Learning

11 - Forwarding

The forward state test returns a true value if both the RX and TX ports are in the required state.

#### **Table Entry Type (ENTRY\_TYPE)**

Address entry type. Unicast or multicast determined by address bit 40.

01: Address entry. Unicast or multicast determined by address bit 40.

#### **Packet Address (MULTICAST\_ADDRESS)**

This is the 48-bit packet MAC address. For an OUI address, only the upper 24-bits of the address are used in the source or destination address lookup. Otherwise, all 48-bits are used in the lookup.

##### **12.3.1.4.6.1.9.2 OUI Unicast Address Table Entry**

**Table 12-147. OUI Unicast Address Table Entry Bit Values**

| 70:64    | 63:62             | 61:60           | 59:48    | 47:24       | 23:0     |
|----------|-------------------|-----------------|----------|-------------|----------|
| Reserved | UNICAST_TYPE (10) | ENTRY_TYPE (01) | Reserved | UNICAST_OUI | Reserved |

#### **Unicast Type (UNICAST\_TYPE)**

This field indicates the type of unicast address the table entry contains.

00 - Unicast address that is not ageable.

01 - Ageable unicast address that has not been touched.

10 - OUI address - lower 24-bits are don't cares (not ageable).

11 - Ageable unicast address that has been touched.

#### **Table Entry Type (ENTRY\_TYPE)**

Address entry. Unicast or multicast determined by address bit 40.

01: Address entry. Unicast or multicast determined by address bit 40.

#### **Packet Address (UNICAST\_OUI)**

For an OUI address, only the upper 24-bits of the address are used in the source or destination address lookup.

##### **12.3.1.4.6.1.9.3 Unicast Address Table Entry (Bit 40 == 0)**

**Table 12-148. Unicast Address Table Entry Bit Values**

| 70:69    | 68    | 67:66           | 65    | 64     | 63    | 62      | 61:60               | 59:48        | 47:0                |
|----------|-------|-----------------|-------|--------|-------|---------|---------------------|--------------|---------------------|
| RESERVED | TRUNK | PORT_NU<br>MBER | BLOCK | SECURE | TOUCH | AGEABLE | ENTRY_TY<br>PE (3h) | RESERVE<br>D | UNICAST_<br>ADDRESS |

### Trunk Indicator (TRUNK)

0h = The port bits in the entry are the port number

1h = The port bits in the entry are the trunk number

### Port Number (PORT\_NUMBER)

This field indicates the port number (not port mask) that the packet with a unicast destination address may be forwarded to. Packets with unicast destination addresses are forwarded only to a single port (but not the receiving port).]

### Block (BLOCK)

The block bit indicates that a packet with a matching source or destination address should be dropped (block the address).

0h = Address is not blocked.

1h = Drop a packet with a matching source or destination address (secure must be zero)

If block and secure are both set, then they no longer mean block and secure. When both are set, the block and secure bits indicate that the packet is a unicast supervisory (super) packet and they determine the unicast forward state test criteria. If both bits are set then the packet is forwarded if the receive port is in the Forwarding/Blocking/Learning state. If both bits are not set then the packet is forwarded if the receive port is in the Forwarding state.

### Secure (SECURE)

This bit indicates that a packet with a matching source address should be dropped if the received port number is not equal to the table entry PORT\_NUMBER.

0h = Received port number is a don't care.

1h = Drop the packet if the received port is not the secure port for the source address and do not update the address (block must be zero)

### Touch Indicator (TOUCH)

Only valid when AGEABLE is a 1h.

0h = Ageable unicast address has not been touched

1h = Ageable unicast address that has been touched

### Ageable (AGEABLE)

This bit indicates that the address is ageable.

0h = Unicast address that is not ageable

1h = Unicast address that is ageable

### Table Entry Type (ENTRY\_TYPE)

Address entry. Unicast or multicast determined by address bit 40.

01: Address entry. Unicast or multicast determined by address bit 40.

### Packet Address (UNICAST\_ADDRESS)

This is the 48-bit packet MAC address. All 48-bits are used in the lookup.

#### 12.3.1.4.6.1.9.4 Multicast Address Table Entry (Bit 40==1)

**Table 12-149. Multicast Address Table Entry Bit Values**

| 70:69 | 68:66 | 65 | 64 | 63:62 | 61:60 | 59:48 | 47:0 |
|-------|-------|----|----|-------|-------|-------|------|
|-------|-------|----|----|-------|-------|-------|------|

**Table 12-149. Multicast Address Table Entry Bit Values (continued)**

| RESERVED | PORT_MASK | SUPER | IGNMBITS | FWDSTLVL | ENTRY_TYPE<br>(1h) | RESERVED | MULTICAST_A<br>DDRESS |
|----------|-----------|-------|----------|----------|--------------------|----------|-----------------------|
|----------|-----------|-------|----------|----------|--------------------|----------|-----------------------|

**Port Mask(2:0) (PORT\_MASK)**

This 3-bit field is the port bit mask that is returned with a found multicast destination address. There may be multiple bits set indicating that the multicast packet may be forwarded to multiple ports (but not the receiving port).

**Supervisory Packet (SUPER)**

When set, this field indicates that the packet with a matching multicast destination address is a supervisory packet.

0: Non-supervisory packet

1: Supervisory packet

**Ignore Multicast Bits (IGNMBITS)**

Indication that the Multicast Address has ignored bits.

**Forward State Level (FWDSTLVL)**

Indicates the port state(s) required for the received port on a destination address lookup in order for the multicast packet to be forwarded to the transmit port(s).

A transmit port must be in the Forwarding state in order to forward the packet. If the transmit port\_mask has multiple set bits then each forward decision is independent of the other transmit port(s) forward decision.

0h = Forwarding

1h = Blocking/Forwarding/Learning

2h = Forwarding/Learning

3h = Forwarding

The forward state test returns a true value if both the RX and TX ports are in the required state.

**Table Entry Type (ENTRY\_TYPE)**

Address entry type. Unicast or multicast determined by address bit 40.

01: Address entry. Unicast or multicast determined by address bit 40.

**Packet Address (MULTICAST\_ADDRESS)**

This is the 48-bit packet MAC address. For an OUI address, only the upper 24-bits of the address are used in the source or destination address lookup. Otherwise, all 48-bits are used in the lookup.

**12.3.1.4.6.1.9.5 VLAN/Unicast Address Table Entry (Bit 40 == 0)****Table 12-150. Unicast Address Table Entry Bit Values**

| 70:69    | 68    | 67:66           | 65    | 64     | 63    | 62      | 61:60               | 59:48   | 47:0                |
|----------|-------|-----------------|-------|--------|-------|---------|---------------------|---------|---------------------|
| RESERVED | TRUNK | PORT_NU<br>MBER | BLOCK | SECURE | TOUCH | AGEABLE | ENTRY_TY<br>PE (3h) | VLAN_ID | UNICAST_<br>ADDRESS |

**Trunk Indicator (TRUNK)**

0h = The port bits in the entry are the port number

1h = The port bits in the entry are the trunk number

**Port Number (PORT\_NUMBER)**

This field indicates the port number (not port mask) that the packet with a unicast destination address may be forwarded to. Packets with unicast destination addresses are forwarded only to a single port (but not the receiving port).]

### **Block (BLOCK)**

The block bit indicates that a packet with a matching source or destination address should be dropped (block the address).

0h = Address is not blocked.

1h = Drop a packet with a matching source or destination address (secure must be zero)

If block and secure are both set, then they no longer mean block and secure. When both are set, the block and secure bits indicate that the packet is a unicast supervisory (super) packet and they determine the unicast forward state test criteria. If both bits are set then the packet is forwarded if the receive port is in the Forwarding/Blocking/Learning state. If both bits are not set then the packet is forwarded if the receive port is in the Forwarding state.

### **Secure (SECURE)**

This bit indicates that a packet with a matching source address should be dropped if the received port number is not equal to the table entry PORT\_NUMBER.

0h = Received port number is a don't care.

1h = Drop the packet if the received port is not the secure port for the source address and do not update the address (block must be zero)

### **Touch Indicator (TOUCH)**

Only valid when AGEABLE is a 1h.

0h = Ageable unicast address has not been touched

1h = Ageable unicast address that has been touched

### **Ageable (AGEABLE)**

This bit indicates that the address is ageable.

0h = Unicast address that is not ageable

1h = Unicast address that is ageable

### **Table Entry Type (ENTRY\_TYPE)**

Address entry. Unicast or multicast determined by address bit 40.

3h: VLAN address entry. Unicast or multicast determined by address bit 40.

### **VLAN ID (VLAN\_ID)**

The unique identifier for VLAN identification. This is the 12-bit VLAN ID.

### **Packet Address (UNICAST\_ADDRESS)**

This is the 48-bit packet MAC address. All 48-bits are used in the lookup.

#### **12.3.1.4.6.1.9.6 VLAN/Multicast Address Table Entry (Bit 40==1)**

**Table 12-151. VLAN/Multicast Address Table Entry Bit Values**

| 70:69    | 68:66     | 65    | 64       | 63:62    | 61:60              | 59:48   | 47:0                  |
|----------|-----------|-------|----------|----------|--------------------|---------|-----------------------|
| RESERVED | PORT_MASK | SUPER | IGNMBITS | FWDSTLVL | ENTRY_TYPE<br>(11) | VLAN_ID | MULTICAST_AD<br>DRESS |

### Port Mask(2:0) (PORT\_MASK)

This 3-bit field is the port bit mask that is returned with a found multicast destination address. There may be multiple bits set indicating that the multicast packet may be forwarded to multiple ports (but not the receiving port).

### Supervisory Packet (SUPER)

When set, this field indicates that the packet with a matching multicast destination address is a supervisory packet.

0: Non-supervisory packet

1: Supervisory packet

### Ignore Multicast Bits (IGNMBITS)

Indication that the Multicast Address has ignored bits.

### Forward State Level (FWDSTLVL)

Indicates the port state(s) required for the received port on a destination address lookup in order for the multicast packet to be forwarded to the transmit port(s).

A transmit port must be in the Forwarding state in order to forward the packet. If the transmit port\_mask has multiple set bits then each forward decision is independent of the other transmit port(s) forward decision.

0h = Forwarding

1h = Blocking/Forwarding/Learning

2h = Forwarding/Learning

3h = Forwarding

The forward state test returns a true value if both the RX and TX ports are in the required state.

### Table Entry Type (ENTRY\_TYPE)

Address entry type. Unicast or multicast determined by address bit 40.

11: VLAN address entry. Unicast or multicast determined by address bit 40.

### VLAN ID (VLAN\_ID)

The unique identifier for VLAN identification. This is the 12-bit VLAN ID.

### Packet Address (MULTICAST\_ADDRESS)

This is the 48-bit packet MAC address. For an OUI address, only the upper 24-bits of the address are used in the source or destination address lookup. Otherwise, all 48-bits are used in the lookup.

#### 12.3.1.4.6.1.9.7 Inner VLAN Table Entry

**Table 12-152. Inner VLAN Table Entry**

| 70:69    | 68:66                     | 65                               | 64:62    | 61:60              | 59:48    | 47                   | 46:39    | 38:36                     |
|----------|---------------------------|----------------------------------|----------|--------------------|----------|----------------------|----------|---------------------------|
| RESERVED | NO_LEARN_M<br>ASK         | VLAN_FORCE<br>_INGRESS_C<br>HECK | 0h       | ENTRY_TYPE<br>(1h) | VLAN_ID  | NOFRAG               | RESERVED | REG_MCAST_F<br>LOAD_INDEX |
| 35:27    | 26:24                     | 23                               | 22:15    | 14:12              | 11:3     | 2:0                  |          |                           |
| RESERVED | FORCE_UNTAGGE<br>D_EGRESS | LMTNXTHDR                        | RESERVED | UREGMSK            | RESERVED | VLAN_MEMBER_LI<br>ST |          |                           |

### No Learn Mask (NO\_LEARN\_MASK)

When a bit is set in this mask, a packet with an unknown source address received on the associated port will not be learned (i.e. When a VLAN packet is received and the source address is not in the table, the source address will not be added to the table).

#### **VLAN Force Ingress Check (VLAN\_FORCE\_INGRESS\_CHECK)**

If the receive port is not a member of this VLAN then the packet is dropped. This is similar to the ly\_REG\_Py\_VID\_INGRESS\_CHECK bit in the CPSW\_ly\_ALE\_PORTCTL0\_y registers except this check is for this VLAN only (not all VLANs).

#### **Table Entry Type (ENTRY\_TYPE)**

2h: VLAN entry

#### **VLAN ID (VLAN\_ID)**

The unique identifier for VLAN identification. This is the 12-bit VLAN ID.

#### **(NOFRAG)**

VLAN No IPv4 Fragmented frames Control - Causes IPv4 fragmented IP frames to be dropped.

#### **Registered Multicast Flood Index (REG\_MCAST\_FLOOD\_INDEX)**

This field indicates which port(s) are the registered multicast flood mask.

#### **Force Untagged Packet Egress (FORCE\_UNTAGGED\_EGRESS)**

This field causes the packet VLAN tag to be removed on egress for the specified port(s) (except on port 0).

#### **VLAN Limit Next Header Control (LMTNXTHDR)**

This bit causes frames to be dropped if the Protocol/Nxt Header does not match the CPSW\_ALE\_NXT\_HDR register values.

#### **VLAN Unregister Multicast Mask (UREGMSK)**

This field indicates which port(s) are the unregistered multicast flood mask.

#### **VLAN Member List (VLAN\_MEMBER\_LIST)**

This field indicates which port(s) are members of the associated VLAN. One bit per port.

#### **12.3.1.4.6.1.9.8 Outer VLAN Table Entry**

**Table 12-153. Outer VLAN Table Entry**

| 70:69    | 68:66                     | 65                               | 64:62    | 61:60              | 59:48    | 47                   | 46:39    | 38:36                     |
|----------|---------------------------|----------------------------------|----------|--------------------|----------|----------------------|----------|---------------------------|
| RESERVED | NO_LEARN_M<br>ASK         | VLAN_FORCE<br>_INGRESS_C<br>HECK | 2h       | ENTRY_TYPE<br>(2h) | VLAN_ID  | NOFRAG               | RESERVED | REG_MCAST_F<br>LOOD_INDEX |
| 35:27    | 26:24                     | 23                               | 22:15    | 14:12              | 11:3     |                      | 2:0      |                           |
| RESERVED | FORCE_UNTAGGE<br>D_EGRESS | LMTNXTHDR                        | RESERVED | UREGMSK            | RESERVED | VLAN_MEMBER_LI<br>ST |          |                           |

#### **No Learn Mask (NO\_LEARN\_MASK)**

When a bit is set in this mask, a packet with an unknown source address received on the associated port will not be learned (i.e. When a VLAN packet is received and the source address is not in the table, the source address will not be added to the table).

#### **VLAN Force Ingress Check (VLAN\_FORCE\_INGRESS\_CHECK)**

If the receive port is not a member of this VLAN then the packet is dropped. This is similar to the ly\_REG\_Py\_VID\_INGRESS\_CHECK bit in the CPSW\_ly\_ALE\_PORTCTL0\_y registers except this check is for this VLAN only (not all VLANs).

### Table Entry Type (ENTRY\_TYPE)

2h: VLAN entry

#### VLAN ID (VLAN\_ID)

The unique identifier for VLAN identification. This is the 12-bit VLAN ID.

#### (NOFRAG)

VLAN No IPv4 Fragmented frames Control - Causes IPv4 fragmented IP frames to be dropped.

#### Registered Multicast Flood Index (REG\_MCAST\_FLOOD\_INDEX)

Index into CPSW\_ALE\_MSK\_MUX0 to CPSW\_Ix\_ALE\_MSK\_MUXx register array that is used to create the registered multicast flood mask.

#### Force Untagged Packet Egress (FORCE\_UNTAGGED\_EGRESS)

This field causes the packet VLAN tag to be removed on egress for the specified port(s) (except on port 0).

#### VLAN Limit Next Header Control (LMTNXTHDR)

This bit causes frames to be dropped if the Protocol/Nxt Header does not match the CPSW\_ALE\_NXT\_HDR register values.

#### VLAN Unregister Multicast Mask (UREGMSK)

This field indicates which port(s) are the unregistered multicast flood mask.

#### VLAN Member List (VLAN\_MEMBER\_LIST)

This field indicates which port(s) are members of the associated VLAN. One bit per port.

#### 12.3.1.4.6.1.9.9 EtherType Table Entry

Table 12-154. EtherType Table Entry

| 70:65    | 64:62 | 61:60           | 59:16    | 15:0      |
|----------|-------|-----------------|----------|-----------|
| RESERVED | 4h    | ENTRY_TYPE (2h) | RESERVED | ETHERTYPE |

### Table Entry Type (ENTRY\_TYPE)

2h: VLAN entry

#### Ether Type (ETHERTYPE)

16-bits Ether Type field.

#### 12.3.1.4.6.1.9.10 IPv4 Table Entry

Table 12-155. IPv4 Table Entry

| 70       | 69:65    | 64:62 | 61:60           | 59:32    | 31:0    |
|----------|----------|-------|-----------------|----------|---------|
| RESERVED | IGNMBITS | 6h    | ENTRY_TYPE (2h) | RESERVED | IPV4ADR |

#### Ignore Multicast Bits (IGNMBITS)

Indication that the Multicast Address has ignored bits.

#### Table Entry Type (ENTRY\_TYPE)

2h: VLAN entry

#### IPv4 Address (IPV4ADR)

32-bit IPv4 Address. Any ignored bits must be zero value in the table entry.

### 12.3.1.4.6.1.9.11 IPv6 Table Entry High

**Table 12-156. IPv6 Table Entry High**

|          |          |      |                 |                 |
|----------|----------|------|-----------------|-----------------|
| 70:64    | 63       | 62   | 61:60           | 59:0            |
| IGNMBITS | RESERVED | (1h) | ENTRY_TYPE (2h) | IPV6ADR[127:68] |

#### Ignore Multicast Bits (IGNMBITS)

Indication that the Multicast Address has ignored bits.

#### Table Entry Type (ENTRY\_TYPE)

2h: VLAN entry

#### IPv6 Address - upper 64 bits (IPV6ADR[127:68])

This address is split into three fields in the IPv6 High and IPv6 Low table entry. Any ignored bits must be zero in the table entry(s).

### 12.3.1.4.6.1.9.12 IPv6 Table Entry Low

**Table 12-157. IPv6 Table Entry Low**

|                |    |                 |               |
|----------------|----|-----------------|---------------|
| 70:63          | 62 | 61:60           | 59:0          |
| IPV6ADR[67:60] | 1h | ENTRY_TYPE (2h) | IPV6ADR[59:0] |

#### Table Entry Type (ENTRY\_TYPE)

2h: VLAN entry

#### IPv6 Address - upper 8 bits (IPV6ADR[67:60])

#### IPv6 Address - upper 60 bits (IPV6ADR[59:0])

This address is split into three fields in the IPv6 High and IPv6 Low table entry. Any ignored bits must be zero in the table entry(s).

Note: IPv6 table address entries operate differently than all other table entry types. IPv6 table entries have a high entry concatenated with a low entry. The high entry must have an entry\_pointer value of the low entry\_pointer plus 0x40. Bit six of the entry\_pointer must be set for the high entry and must be zero for the low entry.

### 12.3.1.4.6.1.10 Multicast Address

Multicast addresses are addresses with bit 40 set. Only destination addresses can be Multicast addresses. The group bit (bit 40) of the source address is reserved in the IEEE standard.

A multicast address of all ones is the broadcast address which can be added to the lookup table if forwarding of broadcast packets need be modified.

#### 12.3.1.4.6.1.10.1 Multicast Ranges

Added IgnMbits to indicate at least one bit of the multicast address is ignored. Up to 10 bits of the multicast address can be ignored to provide the ability to create multiple multicast address ranges.

```

if ((IgnMbits)&(MultiCastAddress[0]==0x000)) { MultiCastAddress[0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[1:0]==0x001)) { MultiCastAddress[1:0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[2:0]==0x003)) { MultiCastAddress[2:0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[3:0]==0x007)) { MultiCastAddress[3:0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[4:0]==0x00F)) { MultiCastAddress[4:0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[5:0]==0x01F)) { MultiCastAddress[5:0] is ignored in compare}

```

```
if ((IgnMbits)&(MultiCastAddress[6:0]==0x03F)) { MultiCastAddress[6:0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[7:0]==0x07F)) { MultiCastAddress[7:0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[8:0]==0x0FF)) { MultiCastAddress[8:0] is ignored in compare}
if ((IgnMbits)&(MultiCastAddress[9:0]==0x1FF)) { MultiCastAddress[9:0] is ignored in compare}
```

Below is 'C' code to modify ALE MultiCastAddress and IgnMbits when iNumOfBitsToIgnore is greater than zero. Where fGenMask(iOffset,iBitsToMask) creates a Mask for the value provided. For example fGenMask(0,5) will return 0x1F.

```
if(iNumOfBitsToIgnore)
{
    int iIgnClrMsk,iIgnSetMsk;
    iIgnClrMsk=fGenMask(0, iNumOfBitsToIgnore);
    iIgnSetMsk=fGenMask(0, iNumOfBitsToIgnore -1);
    MultiCastAddress &= ~iIgnClrMsk;
    MultiCastAddress |= iIgnSetMsk;
    IgnMbits = 1;
}
else
{
    IgnMbits = 0;
}
```

Multicast Addresses or Ranges can overlap, in the event of an overlap; the higher ALE index will be used.

#### 12.3.1.4.6.1.11 Aging and Auto Aging

The ALE supports software control or automatic aging of agable addresses.

Any time an agable address is seen as a source address entering from a port the source address entry will be marked as touched.

If the aging timer expires or the software sets the [29] AGE\_OUT\_NOW bit in the CPSW\_ALE\_CONTROL, the aging process will be started.

The aging process will read each ALE entry and for all entries that are an address with or without VLAN that is also agable, the touch check process will be done.

The touch check process will test the TOUCH bit and if clear, the entry will be marked as free, else the TOUCH bit will be cleared.

What this means is that if the aging interval was programmed as one second, any unused entry could stay in the ALE table for 1.000001 to 1.999999 seconds

#### 12.3.1.4.6.1.12 ALE Policing and Classification

The ALE has a number of configurable classifier engines (policers) that can be used for classification. Classification is a subset of the policing function and uses a policer without the color marking or rate limiting functions. A policer is a hardware engine that is used for policing. The POLCNTDIV8 field in the CPSW\_ALE\_STATUS register indicates the number of policers available to be used for classification. Each policer can be enabled to match on one or more of any of the below packet fields for classification. All but Port and Priority are index references to the ALE table entries.

- Port Number
- Priority extracted from VLAN, mapped from DSCP if enabled, or Default Port Priority
- Organization Network Unique identifier - ONU
- Destination Address - DA
- Source Address - SA
- Outer VLANID -S-VLANID
- Inner VLANID -C-VLANID
- Ether Type
- IP Source Address - IPSA with full CIDR masking for IPv4 and IPv6
- IP Destination Address - IPSA with full CIDR masking for IPv4 and IPv6
- Support Host Thread/Flow ID mapping based on any packet classification above

#### **12.3.1.4.6.1.12.1 ALE Policing**

The policing function on each policer engine is implemented as dual-counter three-color marking engine as described in the IETF RFC2698. The first counter is the Committed Information Rate (CIR) counter and the second counter is the Peak Information Rate (PIR) counter. The policing function can use either or both counters. Based on the counter values the packet color is determined. The color is used to determine whether the packet is dropped or forwarded. The ALE has a local feature that can drop packets regardless of queue state.

The policing rates are determined by the below equations:

CIR policing rate in Mbit/s = ((ALE frequency in Mhz) \* CPSW\_ALE\_POLICECFG7[31-0] CIR\_IDLE\_INC\_VAL) / 32768

PIR policing rate in Mbit/s = ((ALE frequency in Mhz) \* CPSW\_ALE\_POLICECFG6[31-0] PIR\_IDLE\_INC\_VAL) / 32768

Each policer has 10 different match operations (see [Section 12.3.1.4.6.1.12](#)). Since multiple policing entries can be hit on a single packet this provides the ability to create precise traffic stream control.

Packets are colored at ALE lookup time. Packets can be colored RED, YELLOW, or GREEN. If multiple policers are configured for a packet stream then the packet color is merged from all matching (hit) policers. If any policer is RED then the packet is marked RED. Else if any policer is YELLOW then the packet is marked YELLOW. Otherwise the packet is marked GREEN.

The Policing engine supports several modes such that packets that don't hit a policing/classifier match can be treated as RED, YELLOW, GREEN or policer 0 color. Using policer 0 allows for a system to regulate unregulated traffic.

#### **12.3.1.4.6.1.12.2 Classifier to Host Thread Mapping**

The ALE module allows Host Thread mapping based on any packet classification. That is the ALE can generate a thread ID used by the host based on ALE classifier matches.

When enabled the highest classifier match can map to a particular thread ID value.

The ALE also supports an optional default Thread ID value in the event that no classifier match.

Each Thread ID, including the default thread ID, has an enable functionality such that, if no classifier matches occur the default value is used, if the default is not enabled, the switch will use the {port,priority} value instead. If multiple classifier matches occur, the highest matching entry with a thread enable bit set will be used.

Three registers are used for ALE classification thread mapping configuration (CPSW\_ALE\_THREADMAPDEF, CPSW\_ALE\_THREADMAPCTL and CPSW\_ALE\_THREADMAPVAL). The three thread mapping registers are used independently and are separate from the other ALE policing registers. The CPSW\_ALE\_THREADMAPCTL register allows the CPSW\_ALE\_THREADMAPVAL register contents to be written to the selected classifier. There is a CPSW\_ALE\_THREADMAPDEF register that is used for all classifiers. The thread mapping registers can be written or changed at any time but any packets that are already processed will not have their thread altered.

#### 12.3.1.4.6.1.12.3 ALE Classification

When the policers are configured as classifiers, the color marking and policing functions of the policing/classifier engines are not used. One or multiple classifiers can be configured to match on a single packet. For example, a classifier can be enabled to match on priority while another classifier could match IP address.

#### 12.3.1.4.6.1.12.3.1 Classifier to CPPI Transmit Flow ID Mapping

The ALE can generate a 6-bit transmit CPPI Flow ID based on classifier matches that can be used instead of the switch default transmit Flow ID mapping. The switch default flow ID is the remapped received packet priority (0 to 7). Thread and flow ID are used interchangeably for this since there is a single hardware thread (TXST\_THREAD\_MREADY) but there are 6-bits of FLOW\_ID in the transmit CPPI INFO word 0. When enabled, the highest classifier match can map to a particular 6-bit flow ID value that is associated with the classifier. The ALE also supports an optional ALE default thread/flow ID value in the event that no classifiers match. Each thread/flow ID, including the ALE default thread/flow ID, has an enable such that the ALE default thread/Flow ID is used if enabled and if no matches occur (instead of the remapped received packet priority). If the ALE default is not enabled and no matches occur then the switch default value will be used. If multiple classifier matches occur, the highest match with a thread enable bit set will be used. The resultant flow ID has the CPSW\_P0\_FLOW\_ID\_OFFSET\_REG register value added to it to determine the actual value in the INFO 0 Flow ID field.

Three registers are used for ALE classification thread/flow ID mapping configuration (CPSW\_ALE\_THREADMAPDEF, CPSW\_ALE\_THREADMAPCTL and CPSW\_ALE\_THREADMAPVAL). The three thread mapping registers are used independently and are separate from the other ALE policing registers. The CPSW\_ALE\_THREADMAPCTL register allows the CPSW\_ALE\_THREADMAPVAL register contents to be written to the selected classifier. There is a single CPSW\_ALE\_THREADMAPDEF that is used for all classifiers. The thread mapping registers can be written or changed at any time but any packets that are already processed will not have their thread altered.

#### 12.3.1.4.6.1.13 Mirroring

The ALE supports three mirroring modes: destination port, source port and or table entry.

**Destination port mirroring** allows packets from any ingress port or trunk which ends up switching to a particular egress destination port or trunk to be mirrored to yet another egress destination port or trunk. For example any traffic from any port that is switched to port 'A' can be also mirrored to port 'B'. (MIRROR\_DP=A, MIRROR\_DEN=1h, MIRROR\_TOP=B in the CPSW\_ALE\_CONTROL register).

**Source port mirroring** allows packets received on any enabled ingress source port or trunk to be switched to the mirror egress port as well as the actual egress destination ports. For example traffic received on ingress port 'A' can be switched to egress port 'B' as well as the intended egress destination port. (ly\_REG\_Py\_MIRROR\_SP=1h in the CPSW\_ly\_ALE\_PORTCTL0\_y register, MIRROR\_SEN=1h, MIRROR\_TOP=B in the CPSW\_ALE\_CONTROL register).

**Table entry mirroring** allows for any MAC Address, MAC Address with VLAN, ONU Address or VLAN entry that matches on ingress to be switched to the egress destination as well as the actual egress destination. For example all traffic for VLAN ID of 35 can be mirrored to port 'B'. That is any traffic switched on VLAN ID of 35 will be mirrored. ({VLAN ID of 35 in ALE Table entry index=C}, MIRROR\_MIDX=C, MIRROR\_MEN=1h, MIRROR\_TOP=B)

In the event that mirrored packets are mirrored to or from a port that is also the mirror port the packet will not be duplicated or marked as a mirror packet since the packet has already been on the port as ingress or egress. The packet sent to the mirror port may have modified VLAN info based on the port and VLAN lookup table entries. The mirror port need not be a member of the VLAN ID it is mirroring, the ALE will forward traffic to the mirror port after ingress and egress filters are applied.

The switch may decide to drop any mirror traffic based on switch buffer thresholds as to prevent required traffic from becoming congested.

Port mirroring is controlled by register fields in CPSW\_ALE\_CONTROL, CPSW\_ALE\_CTRL2 and the port control registers.

- MIRROR\_DP - The destination port that will have its traffic mirrored (CPSW\_ALE\_CONTROL register).
- MIRROR\_TOP - The port to which mirrored traffic is sent (CPSW\_ALE\_CONTROL register).
- MIRROR\_MEN - The enable for mirroring traffic that matches a supported lookup table entry (CPSW\_ALE\_CONTROL register).
- MIRROR\_DEN - The Enable for destination port mirroring (CPSW\_ALE\_CONTROL register).
- MIRROR\_SEN - The Enable for source port mirroring (CPSW\_ALE\_CONTROL register).
- MIRROR\_MIDX - The index of a lookup table entry that will be mirrored CPSW\_ALE\_CTRL2 register).
- ly\_REG\_Py\_MIRROR\_SP - The enable for the Source port to be mirrored. Although multiple source ports can be mirrored concurrently, a mirror traffic bandwidth issue may occur on the mirror egress port (CPSW\_ly\_ALE\_PORTCTL0\_y register).

#### 12.3.1.4.6.1.14 Trunking

The ALE supports port trunking of any port in any of four trunk groups. That is, four trunk groups can be supported with up to eight ports in each trunk group. There are no port adjacency rules for trunk groups. When ports are a member of a trunk group, addresses added and used in the lookup table will refer to the trunk group rather than port as indicated in the lookup table entries. If ports are removed from a trunk group, the ALE will redistribute the traffic based on the crc polynomial of enabled fields and the remaining ports within the trunk group. A trunk group may contain only one port. Packet priority, DA, SA, C-VLAN ID, IPv4SA, IPv4DA, IPv6SA, and/or IPv6DA can be used in the hash to generate destination port within the trunk group. If all hash enables are disabled, the packet can be directed to a particular port within the trunk group which allows for testing paths etc. A host directed frame is directed to the directed port regardless of trunk group settings.

Trunking is controlled through fields in the CPSW\_ALE\_CTRL2 register and in each ALE CPSW\_ly\_ALE\_PORTCTL0\_y register:

- TRK\_EN\_DST - Enable destination address hashing for trunk port calculation.
- TRK\_EN\_SRC - Enable source address hashing for trunk port calculation.
- TRK\_EN\_PRI - Enable priority hashing for trunk port calculation.
- TRK\_EN\_IVLAN - Enable inner C-VLAN ID hashing for trunk port calculation.
- TRK\_EN\_SIP - Enable source IP address hashing for trunk port calculation.
- TRK\_EN\_DIP - Enable destination IP address hashing for trunk port calculation.
- TRK\_BASE - Hashing formula starting value and test port offset.
- ly\_REG\_Py\_TRUNKEN - Enable this port as a trunk group
- ly\_REG\_Py\_TRUNKNUM - Trunk group number defines this port as a member of a particular trunk group.

#### 12.3.1.4.6.1.15 DSCP

The ALE can map DSCP field to priority prior to classification matching. When enabled the DSCP is mapped via 64 priority entries such that any DSCP value can be mapped to any of the eight priorities. When a packet is received without a VLAN priority this remapped priority can be used instead of the default Port VLAN priority field. See CPSW\_P0\_RX\_DSCP\_MAP\_REG\_y and CPSW\_PN\_RX\_DSCP\_MAP\_REG\_y registers in the Register Manual section for DSCP mapping.

#### 12.3.1.4.6.1.16 Packet Forwarding Processes

There are four processes that an incoming received packet may go through to determine packet forwarding. The processes are *Ingress Filtering*, *VLAN\_Aware Lookup*, and *Egress*.

Packet processing begins in the Ingress Filtering process. Each port has an associated packet forwarding state that can be one of four values (Disabled, Blocked, Learning, or Forwarding). The default state for all ports is Disabled. The host sets the packet forwarding state for each port.

In the packet ingress process (receive packet process), there is a forward state test for unicast destination addresses and a forward state test for multicast addresses. The multicast forward state test indicates the port states required for the receiving port in order for the multicast packet to be forwarded to the transmit port(s). A transmit port must be in the Forwarding state for the packet to be forwarded for transmission. The

MCAST\_FWD\_STATE indicates the required port state for the receiving port as indicated in the preceding table. The unicast forward state test indicates the port state required for the receiving port in order to forward the unicast packet. The transmit port must be in the Forwarding state in order to forward the packet. The BLOCK and SECURE bits determine the unicast forward state test criteria. If both bits are set then the packet is forwarded if the receive port is in the Forwarding/Blocking/Learning state. If both bits are not set then the packet is forwarded if the receive port is in the Forwarding state. The transmit port must be in the Forwarding state regardless. The forward state test used in the ingress process is determined by the destination address packet type (multicast/unicast).

In general, packets received with errors are dropped by the address lookup engine without learning, updating, or touching the address. The error condition and the abort are indicated by the Ethernet port to the ALE. Packets with errors may be passed to the host (not aborted) by a Ethernet port port, if the port has the RX\_CMF\_EN, RX\_CEF\_EN, or RX\_CSF\_EN bit(s) set in the CPSW\_PN\_MAC\_CONTROL\_REG register. Error packets that are passed to the host by the Ethernet port are considered to be bypass packets by the ALE and are sent only to the host. Error packets do not learn, update, or touch addresses regardless of whether they are aborted or sent to the host. Packets with long or short errors received by the host are dropped. Packets with errors received by the host are forwarded as normal.

The following control bits are in the CPSW\_PN\_MAC\_CONTROL\_REG register:

- [22] RX\_CEF\_EN - enables frames that are fragments, long, jabber, CRC, code, and alignment errors to be forwarded
- [23] RX\_CSF\_EN - enables short frames to be forwarded
- [24] RX\_CMF\_EN - enables MAC control frames to be forwarded.

#### 12.3.1.4.6.1.16.1 Ingress Filtering Process

| Condition and action                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| If ((ALE BYPASS) and (host port is not the receive port))<br>then use host portmask and go to Egress process                                                                                                                                                                                                                           |
| if (directed packet)<br>then use directed port number and go to Egress process                                                                                                                                                                                                                                                         |
| If (Rx ly_REG_Py_PORTSTATE is Disabled)<br>then discard the packet                                                                                                                                                                                                                                                                     |
| if ((ALE BYPASS or error packet) and (host port is not the receive port))<br>then use host portmask and go to Egress process                                                                                                                                                                                                           |
| if (((BLOCK) and (unicast source address found)) or ((BLOCK) and (unicast destination address found)))<br>then discard the packet                                                                                                                                                                                                      |
| if ((ENABLE_RATE_LIMIT) and (rate limit exceeded) and (not BCAST_MCAST_CTL))<br>then if (((Multicast/Broadcast destination address found) and (not SUPER)) or (Multicast/Broadcast destination address not found))<br>then discard the packet                                                                                          |
| if ((not forward state test valid) and (destination address found))<br>then discard the packet to any port not meeting the requirements <ul style="list-style-type: none"> <li>• Unicast destination addresses use the unicast forward state test and multicast destination addresses use the multicast forward state test.</li> </ul> |
| if ((destination address not found) and ((not transmit port forwarding) or (not receive port forwarding)))<br>then discard the packet to any ports not meeting the above requirements                                                                                                                                                  |
| if (source address found) and (secure) and (not block) and (receive port number != port_number))<br>then discard the packet                                                                                                                                                                                                            |
| if ((not super) and (drop_untagged) and ((non-tagged packet) or ((priority tagged) and not(en_vid0_mode)))<br>then discard the packet                                                                                                                                                                                                  |

```

If (VLAN_Unaware)
CPSW_ALE_UVLAN_UNTAG = "000000"
CPSW_ALE_UVLAN_UCAST = "111111"
CPSW_ALE_UVLAN_UCAST = "111111"
UVLAN_MEMBER_LIST = "111111"
else if (VLAN not found)
CPSW_ALE_UVLAN_UNTAG = CPSW_ALE_UVLAN_UNTAG
CPSW_ALE_UVLAN_RMCAST = CPSW_ALE_UVLAN_RMCAST
CPSW_ALE_UVLAN_RMCAST = CPSW_ALE_UVLAN_RMCAST
CPSW_ALE_UVLAN_MEMBER = CPSW_ALE_UVLAN_MEMBER
else
CPSW_ALE_UVLAN_UNTAG = found CPSW_ALE_UVLAN_UNTAG
CPSW_ALE_UVLAN_UCAST = found CPSW_ALE_UVLAN_UCAST
CPSW_ALE_UVLAN_RMCAST = found CPSW_ALE_UVLAN_RMCAST
UVLAN_MEMBER_LIST = found UVLAN_MEMBER_LIST

if ((not SUPER) and (ly_REG_Py_VID_INGRESS_CHECK) and (Rx port is not VLAN member))
then discard the packet

if ((ENABLE_AUTH_MODE) and (source address not found) and not(destination address found and (SUPER)))
then discard the packet

if (destination address equals source address)
then discard the packet

if (VLAN_AWARE) goto VLAN_Aware_Lookup process
else goto VLAN_Unaware_Lookup process

```

#### **12.3.1.4.6.1.16.2 VLAN\_Aware Lookup Process**

| <b>Condition and action</b>                                                                                                                                                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| if ((unicast packet) and (destination address found with or without VLAN) and (not SUPER))<br>then portmask is the logical "AND" of the PORT_NUMBER and UVLAN_MEMBER_LIST less the host port<br>and goto Egress process                                          |
| if ((unicast packet) and (destination address found with or without VLAN) and (not SUPER))<br>then portmask is the logical "AND" of the PORT_NUMBER and the UVLAN_MEMBER_LIST and goto Egress process                                                            |
| if ((unicast packet) and (destination address found with or without VLAN) and (SUPER))<br>then portmask is the PORT_NUMBER and goto Egress process                                                                                                               |
| if (Unicast packet) # destination address not found<br>then portmask is VLAN member LIST less host port and goto Egress process                                                                                                                                  |
| if ((Multicast packet) and (destination address found with or without VLAN) and (not SUPER))<br>then portmask is the logical "AND" of CPSW_ALE_UVLAN_UCAST and found destination address/VLAN portmask (PORT_MASK) and UVLAN_MEMBER_LIST and goto Egress process |
| if ((Multicast packet) and (destination address found with or without VLAN) and (SUPER))<br>then portmask is the PORT_MASK and goto Egress process                                                                                                               |

```

if (Multicast packet) # destination address not found
then portmask is the logical "AND" of CPSW_ALE_UVLAN_UCAST and UVLAN_MEMBER_LIST
then goto Egress process
if (Broadcast packet)
then use found UVLAN_MEMBER_LIST and goto Egress process

```

#### Note

The UVLAN\_MEMBER\_LIST, UVLAN\_UNREG\_MCAST\_FLOOD\_MASK, UVLAN\_REG\_MCAST\_FLOOD\_MASK and UVLAN\_FORCE\_UNTAGGED\_EGRESS are set in the [Section 12.3.1.4.6.1.16.1 Ingress Filtering Process](#), based on VLAN\_Unaware, Unknown\_VLAN rules and VLAN table entries.

#### 12.3.1.4.6.1.16.3 Egress Process

| Condition and action                                                                                                                                    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clear Rx port from portmask (don't send packet to Rx port).                                                                                             |
| Clear disabled ports from portmask.                                                                                                                     |
| if ((ENABLE_OUI_DENY) and (OUI source address not found) and (not ALE BYPASS) and (not error packet) and ((not mcast destination address) and (SUPER))) |
| then Clear host port from portmask                                                                                                                      |
| if ((not ENABLE_OUI_DENY) and (OUI source address found) and (not ALE BYPASS) and (not error packet) and not ((mcast destination address) and (SUPER))) |
| then Clear host port from portmask                                                                                                                      |
| if ((ENABLE_RATE_LIMIT) and (BCAST_MCAST_CTL))                                                                                                          |
| then if (not SUPER) and (rate limit exceeded on any tx port)                                                                                            |
| then clear rate limited tx port from portmask                                                                                                           |
| If address not found then SUPER cannot be set.                                                                                                          |
| If portmask is zero then discard packet                                                                                                                 |
| Send packet to portmask ports.                                                                                                                          |

#### 12.3.1.4.6.1.16.4 Learning/Updating/Touching Processes

The learning, updating, and touching processes are applied to each receive packet that is not aborted. The processes are concurrent with the packet forwarding process. In addition to the following, a packet must be received without error in order to learn/update/touch an address.

##### 12.3.1.4.6.1.16.4.1 Learning Process

The learning process is applied to each receive packet that is not aborted. The learning process is a concurrent process with the packet forwarding process.

| Condition and action                                                                                                           |
|--------------------------------------------------------------------------------------------------------------------------------|
| If (directed) then do not learn, update, or set touched else continue                                                          |
| If (not (Learning or Forwarding) or (ENABLE_AUTH_MODE) or (packet error) or (ly_REG_Py_NO_LEARN))<br>then do not learn address |
| if ((Non-tagged packet) and (ly_REG_Py_DROP_UN_TAGGED))<br>then do not learn address                                           |

```

if ((VLAN_AWARE) and (VLAN not found) and (unknown UVLAN_MEMBER_LIST = "000"))
then do not learn address

if ((ly_REG_Py_VID_INGRESS_CHECK) and (Rx port is not VLAN member) and (VLAN found))
then do not learn address

if ((source address found) and (receive port_number != PORT_NUMBER) and (SECURE or BLOCK)) then do not update address else
continue

if ((source address found) and (receive port number != PORT_NUMBER)) then update address else continue

if ((source address not found) and (VLAN_AWARE) and not (LEARN_NO_VLANID))
then learn address with VLAN

if ((source address not found) and ((not VLAN_AWARE) or (VLAN_AWARE and LEARN_NO_VLANID)))
then learn address without VLAN

```

#### 12.3.1.4.6.1.16.4.2 Updating Process

| Condition and action                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------|
| if (dlr_unicast)<br>then do not update address                                                                                     |
| If (not(Learning or Forwarding) or (ENABLE_AUTH_MODE) or (packet error) or (ly_REG_Py_NO_SA_UPDATE))<br>then do not update address |
| if ((Non-tagged packet) and (ly_REG_Py_DROP_UN_TAGGED))<br>then do not update address                                              |
| if ((VLAN_AWARE) and (VLAN not found) and (unknown UVLAN_MEMBER_LIST = "000")) then do not update address                          |
| if ((ly_REG_Py_VID_INGRESS_CHECK) and (Rx port is not VLAN member) and (VLAN found)) then do not update address                    |
| if ((source address found) and (receive port number != PORT_NUMBER) and (SECURE or BLOCK)) then do not update address              |
| if ((source address found) and (receive port number != PORT_NUMBER)) then update address                                           |

#### 12.3.1.4.6.1.16.4.3 Touching Process

```

if ((source address found) and (ageable) and (not touched))
then set touched

```

#### 12.3.1.4.6.1.17 VLAN Aware Mode

The CPSW is in VLAN aware mode when the VLAN\_AWARE bit is set in the CPSW\_CONTROL\_REG register.

In VLAN aware mode, transmitted packet data is changed depending on the packet type (PKT\_TYPE), packet priority (PKT\_PRI), and VLAN information.

The VLAN\_LTYPE\_SEL value is selected by the S\_CN\_SWITCH bit in the CPSW\_CONTROL\_REG register and is either the VLAN\_LTYPE\_INNER (8100h default) or VLAN\_LTYPE\_OUTER (88A8h default) value.

#### 12.3.1.4.6.1.18 VLAN Unaware Mode

An egress port is operating in the VLAN unaware mode when the VLAN\_AWARE bit in the CPSW\_CONTROL\_REG register is cleared to 0h. In VLAN unaware mode, transmit (egress) packets are not modified on egress.

#### 12.3.1.4.6.2 Packet Priority Handling

Packets are received on two ports, one Ethernet port and one CPPI host port. Received packets have a received packet priority (0 to 7, with 7 being the highest priority).

The received packet priority is determined as follows:

1. If the first packet LTYPE = VLAN\_LTYPE\_SEL then the received packet priority is the packet priority (VLAN tagged and priority tagged packets).
2. Else if the first packet LTYPE = 0x0800 and byte 14 (following the LTYPE) is equal to 0x4X, and DSCP\_IPV4\_EN is set in CPSW\_P0\_CONTROL\_REG or CPSW\_PN\_CONTROL\_REG, then the received packet priority is the 6-bit TOS field in byte 15 (upper 6 bits) mapped through the port's DSCP priority mapping registers (IPv4 packet).
3. Else if the first packet LTYPE = 0x86DD and the most significant nibble of byte 14 (following the LTYPE) is equal to 0x6, and DSCP\_IPV6\_EN is set in CPSW\_P0\_CONTROL\_REG or CPSW\_PN\_CONTROL\_REG, then the received packet priority is the 6-bit priority (in the 6-bits following the upper nibble 0x6) mapped through the port's DSCP priority mapping registers (IPv6 packet).
4. Else the received packet priority is the source (ingress) port priority.

The received packet priority is mapped through the receive ports associated packet-priority-to-header-packet-priority-mapping register (CPSW\_PN\_RX\_PRI\_MAP\_REG) to obtain the header packet priority. The header packet priority is the hardware switch priority. The header packet priority is also used as the actual transmit packet priority if the VLAN information is to be sent on egress.

The header packet priority is mapped at each destination FIFO through the CPSW\_PN\_TX\_PRI\_MAP\_REG register (header priority to switch priority mapping register) to obtain the hardware switch priority (hardware queue 0 through 7).

#### 12.3.1.4.6.2.1 Priority Mapping and Transmit VLAN Priority

There are three priorities that are used inside the Gigabit Ethernet Switch: **packet priority**, **header packet priority**, and **switch priority**. The **header packet priority** is used as the outgoing VLAN priority if the packet is egressing from the switch with a VLAN tag. The **switch priority** determines which of the 8 FIFO priority queues the packet uses during egress.

Figure 12-130 below, as well as the corresponding explanation that follows, explains each of the priorities, how they are determined, and how they are used. A number in parentheses in the figure indicates a process (Ethernet port ingress, host port egress, etc.). Each bullet in the text following the diagram explains one of the 5 processes pointed out in the figure.



**Figure 12-130. Gigabit Ethernet Switch Priority Mapping and Transmit VLAN Processing**

From Figure 12-130 above:

- (1) is the ingress process that occurs at the external Ethernet ports
  - The incoming packet is assigned a **packet priority** based on either its VLAN priority, IPv4 or IPv6 DSCP value, or the ingress port's priority. This **packet priority** is then mapped to a **header packet priority** using the CPSW\_PN\_RX\_PRI\_MAP\_REG register where N is the port where the packet entered the switch. This process is explained in further detail in [Section 12.3.1.4.6.2](#).
- (2) is the egress process that occurs at the external Ethernet ports
  - If the switch is in VLAN Aware mode then the VLAN header may be added, replaced, or removed during the egress process. If the VLAN header is to be added or replaced, the VLAN priority will come from the **header packet priority** that was determined in process (1) or (5). Transmit VLAN processing is the same for both the host port and the external Ethernet ports and is described in [Section 12.3.1.4.6.4.1](#).
- (3) is the process by which it is decided which priority TX queue to place the packet on in the Port N TX FIFO during egress
  - Each Port's TX FIFO has 8 queues that each correspond to a priority that is used when determining which packet will egress from the switch next at that port. The **header packet priority** (Ethernet port ingress, process (1)) or the receive packet thread (host port 0 ingress, process (5)) gets mapped through the CPSW\_PN\_RX\_PRI\_MAP\_REG register (where N is the egress port number) to determine the **switch priority** of the packet. The **switch priority** determines which TX FIFO queue to place the packet in. The FIFO architecture is described in [Section 12.3.1.4.6.10.5](#). The header packet priority to switch priority mapping is discussed in [Section 12.3.1.4.6.2](#).
- (4) is the egress process that occurs at Host Port 0 toward the transmit streaming interface (TXST)
  - The TXST has 8 egress threads for each external Ethernet port (32 threads in a 5-port switch and 64 threads in a 9-port switch). The TX thread that is selected for a packet is determined by the Ethernet port of ingress and the **switch priority** of the packet that was determined in process (3).
  - If the switch is in VLAN Aware mode then the VLAN header may be added, replaced, or removed during the egress process. If the VLAN header is to be added or replaced, the VLAN priority will come from the **header packet priority** that was determined in process (1). Transmit VLAN processing is the same for both the host port and the external Ethernet ports and is described in [Section 12.3.1.4.6.4.1](#).
- (5) is the ingress process that occurs at Host Port 0
  - The incoming packet is assigned a **packet priority** based on either its VLAN priority, IPv4 or IPv6 DSCP value, or the host port's priority. This packet priority is then mapped to a **header packet priority** using the CPSW\_PN\_RX\_PRI\_MAP\_REG register.
  - Host port 0 also has a received packet thread. The receive packet thread is based on either the packet's VLAN priority, IPv4 or IPv6 DSCP value, or the streaming interface (RXST) thread that the packet entered host port 0 on.

#### 12.3.1.4.6.3 CPPI Port Ingress

Packets received on the CPPI host port have a received packet priority (0 to 7 with 7 being the highest priority).

The received packet priority is determined as follows:

1. If the first packet LTYPE = VLAN\_LTYPE\_SEL then the received packet priority is the packet priority (VLAN tagged and priority tagged packets).
2. Else if the first packet LTYPE = 0x0800 and byte 14 (following the LTYPE) is equal to 0x4X, and DSCP\_IPV4\_EN is set in CPSW\_P0\_CONTROL\_REG or CPSW\_PN\_CONTROL\_REG register, then the received packet priority is the 6-bit TOS field in byte 15 (upper 6 bits) mapped through the port's DSCP priority mapping registers (IPv4 packet).
3. Else if the first packet LTYPE = 0x86DD and the most significant nibble of byte 14 (following the LTYPE) is equal to 0x6, and DSCP\_IPV6\_EN is set in CPSW\_P0\_CONTROL\_REG or CPSW\_PN\_CONTROL\_REG register, then the received packet priority is the 6-bit priority (in the 6-bits following the upper nibble 0x6) mapped through the port's DSCP priority mapping registers (IPv6 packet).
4. Else the received packet priority is the source (ingress) port priority

The CPPI Port (port 0) also has a received packet thread. The received packet thread is determined exactly as the received packet priority except for untagged packets. For untagged packets, the received packet thread is the packet streaming interface thread that the packet was received on (instead of the port VLAN priority or DSCP priority). The received packet thread is the hardware switch priority. The received packet thread only determines which hardware switch priority the packet should be sent to, the egress VLAN rules are identical to packets that were received on Ethernet ports (as determined by the header packet priority).

For CPPI ingress packets, the destination port hardware switch priority is the below selected value remapped through CPSW\_PN\_RX\_PRI\_MAP\_REG:

1. If the ingress packet is priority tagged or vlan tagged:
  - If RX\_REMAP\_VLAN in CPSW\_P0\_CONTROL\_REG register is clear then the destination hardware switch priority is the CPPI receive thread number.
  - If RX\_REMAP\_VLAN in CPSW\_P0\_CONTROL\_REG register is set then the destination hardware switch priority is the packet priority value. Port transmit remapping (CPSW\_PN\_TX\_PRI\_MAP\_REG should remain the default value) is not compatible with this bit being set, but remapping can be configured on port 0 receive.
2. Else if the ingress packet has the first packet LTYPE = 0x0800 and byte 14 (following the LTYPE) is equal to 0x4X, and DSCP\_IPV4\_EN is set in CPSW\_P0\_CONTROL\_REG register:
  - If RX\_REMAP\_DSCP\_V4 bit in CPSW\_P0\_CONTROL\_REG register is clear then the destination hardware switch priority is the CPPI receive thread number.
  - If RX\_REMAP\_DSCP\_V4 bit in CPSW\_P0\_CONTROL\_REG register is set then the destination hardware switch priority is the 6-bit TOS field in byte 15 (upper 6-bits) mapped through the port's DSCP priority mapping registers (IPV4 packet). Port 1 transmit remapping (CPSW\_PN\_TX\_PRI\_MAP\_REG should remain the default value) is not compatible with this bit being set, but remapping can be configured on port 0 receive.
3. Else if the ingress packet has the first packet LTYPE = 0x86DD and the most significant nibble of byte 14 (following the LTYPE) is equal to 0x6, and DSCP\_IPV6\_EN is set in P0\_CONTROL\_REG register:
  - If RX\_REMAP\_DSCP\_V6 bit in CPSW\_P0\_CONTROL\_REG register is clear then the destination hardware switch priority is the CPPI receive thread number.
  - If RX\_REMAP\_DSCP\_V6 bit in CPSW\_P0\_CONTROL\_REG register is set then the destination hardware switch priority is the 6-bit priority (in the 6-bits following the upper nibble 0x6) mapped through the port's DSCP priority mapping registers (IPV6 packet). Port 1 transmit remapping (CPSW\_PN\_TX\_PRI\_MAP\_REG should remain the default value) is not compatible with this bit being set, but remapping can be configured on port 0 receive.
4. Else the ingress packet is non-tagged and the destination hardware switch priority is the CPPI receive thread number.

#### **12.3.1.4.6.4 Packet CRC Handling**

The P0\_TX\_CRC\_REMOVE bit in the CPSW\_CONTROL\_REG register determines if host port egress packets have CRC included or not. If P0\_TX\_CRC\_REMOVE is set to 1h then all packets that are transmitted from port 0 do not contain CRC. If P0\_TX\_CRC\_REMOVE bit is cleared to 0h then all packets that are transmitted from port 0 contain CRC. The CRC type, if present, is determined by the CRC\_TYPE bit in the CPSW\_PN\_MAC\_CONTROL\_REG register. If the CRC\_TYPE bit is cleared to 0h then the CRC present in each packet after host port egress is Ethernet CRC. If the CRC\_TYPE bit is set to 1h then the CRC present in each packet after host port egress is Castagnoli CRC.

---

#### **Note**

The CRC type present in the packet after host port egress is determined solely by the CRC\_TYPE bit in the CPSW\_PN\_MAC\_CONTROL\_REG register regardless of the CRC type present in the packet during Ethernet port ingress.

#### 12.3.1.4.6.4.1 Transmit VLAN Processing

Transmit packets are NOT modified during switch egress when the VLAN\_AWARE bit in the CPSW\_CONTROL\_REG register is cleared to 0h. This means that the switch is not in VLAN-aware mode.

The next three sections cover transmit processing when the switch is in VLAN-aware mode for different packet types. The Gigabit Ethernet switch is in VLAN-aware mode when the VLAN\_AWARE bit is set in the CPSW\_CONTROL\_REG register. While in VLAN-aware mode, VLAN is added, removed, or replaced according to the type of packet as well as the CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit in the packet header as explained below.

##### 12.3.1.4.6.4.1.1 Untagged Packets (No VLAN or Priority Tag Header)

Untagged packets are all packets that are not a VLAN packet or a priority tagged packet. According to the CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit in the packet header the packet may exit the switch with a VLAN tag inserted or the packet may leave the switch unchanged. The two cases are discussed below.

- Insert VLAN Case:

Untagged input packets have the header packet VLAN inserted when the CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit in the transmit packet header is de-asserted. For untagged packets, the VLAN EtherType = 0x8100 is inserted after the source address followed by the two byte header packet VLAN. The header packet VLAN is composed of the header packet priority along with the PORT\_CFI and PORT\_VID values from the CPSW\_PN\_PORT\_VLAN\_REG register (where N is the port that the untagged packet entered the switch) through. The packet length/type field is output four bytes later than it is input and is not removed or replaced. If the CRC is present in the packet data (PASS\_CRC is asserted), then the packet CRC is replaced with a hardware generated CRC.

- No Change Case:

Untagged input packets are output unchanged when the CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS transmit packet header bit is asserted.

##### 12.3.1.4.6.4.1.2 Priority Tagged Packets (VLAN VID == 0 && EN\_VID0\_MODE ==0h)

Priority tagged packets are packets that contain a VLAN header with VID = 0. According to the CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit in the packet header, priority tagged packets may exit the switch with their VLAN ID and priority replaced or they may have their priority tag completely removed. The two cases are discussed below.

---

##### Note

In order for a priority tagged packet to fall into this category the ENABLE\_VID0\_MODE bit in the CPSW\_ALE\_CONTROL register must also be set to 0h. If the ENABLE\_VID0\_MODE bit in the CPSW\_ALE\_CONTROL register is set to 1h, then packets with a VLAN VID of 0 will fall into the VLAN Tagged Packets category in [Section 12.3.1.4.6.4.1.3](#) below.

- Replace Priority and VLAN ID Case:

Priority tagged input packets have the packet VLAN ID and the packet priority replaced with the header packet VLAN ID and the header packet priority when the transmit packet header CPSW\_FORCE\_UNTAGGED\_EGRESS\_REG[1-0] MASK bit is de-asserted. The header packet VLAN ID comes from the PORT\_VID bits in the CPSW\_PN\_PORT\_VLAN\_REG register (where N is the port where the packet entered the switch). The header packet priority is based on the packet priority to header packet priority mapping in the CPSW\_PN\_RX\_PRI\_MAP\_REG register (where N is the port where the packet entered the switch).

- Remove VLAN Header Case:

Priority tagged input packets have the 4-byte packet VLAN information removed when the transmit packet header CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit is asserted. The 0x8100 EtherType is removed as is the two byte packet VLAN. Input 64-67 byte priority tagged packets go out with the VLAN removed and padded to 64-bytes if the PASS\_CRC input bit is asserted. The input CRC bytes are used as the pad data. Input 64-byte priority-tagged packets use all four input CRC bytes as pad, input 65-byte priority-tagged packets use three of the input CRC bytes as pad, and so on. No pad is performed if the PASS\_CRC input bit is not asserted - input 64-67 byte (on the wire) priority-tagged packets go out as 60-63 byte packets. The output CRC is replaced with a generated CRC when the VLAN is removed.

#### **12.3.1.4.6.4.1.3 VLAN Tagged Packets (VLAN VID != 0 || (EN\_VID0\_MODE ==1h && VLAN VID ==0))**

VLAN tagged packets are packets that contain a VLAN header specifying the VLAN the packet belongs to (VID), the packet priority (PRI), and the drop eligibility indicator (CFI). According to the CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit in the packet header, VLAN tagged packets may exit the switch with their VLAN priority replaced or they may have their VLAN header completely removed. The two cases are discussed below.

- Replace Priority Case:

VLAN tagged input packets are output with the packet priority replaced with the header packet priority when the transmit packet header CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit is deasserted. The header packet priority is based on the packet priority to header packet priority mapping in the CPSW\_PN\_RX\_PRI\_MAP\_REG register (where N is the port where the packet entered the switch). If the CRC is present in the packet data (PASS\_CRC is asserted), then the packet CRC is replaced with a generated CRC.

- Remove VLAN Header Case:

VLAN tagged input packets have the 4-byte packet VLAN information removed when the transmit packet header CPSW\_ALE\_UVLAN\_UNTAG[1-0] UVLAN\_FORCE\_UNTAGGED\_EGRESS bit is asserted. The 0x8100 EtherType is removed as is the two byte packet VLAN. Input 64-67 byte priority tagged packets go out with the VLAN removed and padded to 64-bytes if the PASS\_CRC input bit is asserted. The input CRC bytes are used as the pad data. Input 64-byte priority tagged packets use all four input CRC bytes as pad, input 65-byte priority tagged packets use three of the input CRC bytes as pad, and so on. No pad is performed if the PASS\_CRC input bit is not asserted - input 64-67 byte (on the wire) priority tagged packets go out as 60-63 byte packets. The output CRC is replaced with a generated CRC when the VLAN is removed.

#### **12.3.1.4.6.4.2 Ethernet Port Ingress Packet CRC**

All Ethernet ports check the ingress packet CRC in all modes/speeds. The receive port can check either Ethernet CRC or Castagnoli CRC as determined by the CRC\_TYPE bit in the CPSW\_PN\_MAC\_CONTROL\_REG register.

#### **12.3.1.4.6.4.3 Ethernet Port Egress Packet CRC**

Ethernet ports transmit each egress packet with the CRC selected by the CRC\_TYPE bit in the CPSW\_PN\_MAC\_CONTROL\_REG register, regardless of the type of CRC that the packet had on ingress to the switch. At the egress port after passing through the switch, the packet CRC is checked for correctness and if the CRC is correct then the packet is output with the generated selected output CRC. If the packet CRC is incorrect, due either to a bit flip in a memory or an error CRC passed in on host ingress, then the generated egress CRC type is used with at least a single byte of the CRC inverted to indicate the error. If the packet length including CRC is divisible by 4 then all 4 CRC bytes will be inverted on error. If there are three bytes remainder after dividing the packet length by 4 then three bytes will be inverted (and so on down to one byte remainder).

#### **12.3.1.4.6.4.4 CPPI Port Ingress Packet CRC**

CPPI port ingress packets can be passed in with or without a CRC. The host port is Ethernet CRC only. CPPI ingress packets are not checked for CRC correctness on CPPI ingress, however they are checked for

correctness on Ethernet egress and are output with a CRC error if they came in with a CRC error. If a CPPI ingress packet does not have the INFO0 PASSED\_CRC bit set then a CRC will be generated for the packet on CPPI ingress. If the PASSED\_CRC bit is set then the packet is received and forwarded unchanged. The CRC type is input in the INFO0 word CRC\_TYPE bit and must be Ethernet CRC.

#### 12.3.1.4.6.4.5 CPPI Port Egress Packet CRC

The P0\_TX\_CRC\_REMOVE bit in the CPSW\_CONTROL\_REG register determines if CPPI egress packet have an Ethernet CRC included or not.

#### 12.3.1.4.6.5 FIFO Memory Control

Each of the two CPSW\_2G ports has an identical associated FIFO. Each FIFO contains a single logical receive queue and eight logical transmit queues (priority 0 through 7 with 7 the highest priority). Each FIFO memory contains 20,480 bytes (20k) total organized as 2560 by 64-bit words contained in a single memory instance. The FIFO memory is used for the associated port transmit and receive queues. The TX\_MAX\_BLKS field in the FIFOs associated CPSW\_PN\_MAX\_BLKS\_REG register determines the maximum number of 1k FIFO memory blocks to be allocated to the eight logical transmit queues (transmit total). The RX\_MAX\_BLKS field in the FIFO's associated CPSW\_PN\_MAX\_BLKS\_REG register determines the maximum number of 1k memory blocks to be allocated to the logical receive queue. The TX\_MAX\_BLKS value plus the RX\_MAX\_BLKS value must sum to 20 (the total number of blocks in the FIFO). If the sum were less than 20, then some memory blocks would be unused. The default is 17 (decimal) transmit blocks and three receive blocks. The FIFOs follow the naming convention of the Ethernet ports. Host Port is Port0 and External Ports is Port1.

Each transmit FIFO contains a configurable number of blocks (20 max) that are either 1k or 4k byte blocks that can be allocated to any priority.

#### 12.3.1.4.6.6 FIFO Transmit Queue Control

There are eight transmit queues in the Ethernet port transmit FIFO. Software has some flexibility in determining how packets are loaded into the queues and on how packet priorities are selected for transmission (how packets are removed and transmitted from queues).

#### 12.3.1.4.6.6.1 CPPI Port Receive Rate Limiting

Port 0 receive operations can be configured to rate limit the host ingress data for each receive thread (priority). CPPI Receive has 8 threads for QOS. There is a committed information rate (CPSW\_P0\_PRI\_CIR\_REG\_y, where y = 0 to 7) and an excess information rate for each thread (CPSW\_P0\_PRI\_EIR\_REG\_y, where y = 0 to 7). Rate limiting is enabled for a thread when the committed information rate for the thread is non-zero. The excess information rate for a priority is enabled when the excess information rate for the priority is non-zero. The committed information rate must be non-zero if the excess information rate is configured to be non-zero. That is, there must be a configured non-zero committed information rate for there to be a configured non-zero excess information rate. Bulk traffic on other non-rate limited priorities does not impact the committed information traffic on a priority. However, bulk traffic on other non-rate limited threads does impact the excess information rates. No bulk thread will be enabled to send unless there are CPSW\_PN\_PRI\_CTL\_REG[15:12] TX\_HOST\_BLKS\_Rem number of unused blocks remaining in each of the Ethernet port transmit FIFOs. The “blocks remaining check” ensures that bulk traffic from the host will not block rate-limited traffic from the host. Rate limited channels must be the highest priority channels. For example, if two rate limited channels are required then threads 7 and 6 should be configured for committed information (and excess information if desired). When any channels are configured to be rate-limited, the priority type must be fixed for receive. Round-robin priority type is not allowed when rate-limiting is configured for any thread. The configured transfer rate includes the inter-packet gap (12 bytes) and the preamble (8 bytes). The rate in Mbits/second that each priority is configured to receive is controlled by the below equation. If the configured excess information rate is zero, then only the committed information rate is transferred:

$$\text{Priority Transfer rate [Mbit/s]} = (((\text{Frequency in MHZ}) * \text{CPSW_P0_PRI_CIR_REG}_y) / 32768) + (((\text{Frequency in MHZ}) * \text{CPSW_P0_PRI_EIR_REG}_y) / 32768))$$

Where the *frequency* is the CPPI\_ICLK frequency (in MHz) and priority 0 to 7.

For example, 10Mbps on priority 7 would give the below:

10Mbps =  $\sim ((350 * 936) / 32768)$ , at 350Mhz and CPSW\_P0\_PRI\_CIR\_REG\_y[27-0] PRI\_CIR value = 936 (no excess information rate)

#### 12.3.1.4.6.6.2 Ethernet Port Transmit Rate Limiting

Ethernet port transmit operations can be configured to rate limit egress data for each egress priority. There is a committed information rate (CPSW\_P0\_PRI\_CIR\_REG\_y, where y = 0 to 7) and an excess information rate for each priority (CPSW\_P0\_PRI\_EIR\_REG\_y, where y = 0 to 7). Rate limiting is enabled for a priority when the committed information rate for the priority is non-zero. The excess information rate for a priority is enabled when the excess information rate for the priority is non-zero. The committed information rate must be non-zero if the excess information rate is configured to be non-zero. That is, there must be a configured non-zero committed information rate for there to be a configured non-zero excess information rate. Bulk traffic on other non-rate limited priorities does not impact the committed information traffic on a priority. However, bulk traffic on other non-rate limited threads does impact the excess information rates. Rate limited channels must be the highest priority channels. For example, if two rate limited channels are required then priorities 7 and 6 should be configured for committed information (and excess information if desired). The configured transfer rate includes the inter-packet gap (12 bytes) and the preamble (8 bytes). The rate in Mbits/second that each priority is configured to send is controlled by the below equation. If the excess information rate is disabled then the committed information rate only is transferred:

Priority Transfer rate [Mbit/s] =  $((((\text{Frequency in MHZ}) * \text{CPSW_P0_PRI_CIR_REG_y}) / 32768) + ((\text{Frequency in MHZ}) * \text{CPSW_P0_PRI_EIR_REG_y}) / 32768))$

Where the *frequency* is the CPPI\_ICLK frequency (in MHz) and priority 0 to 7.

#### 12.3.1.4.6.7 Interspersed Express Traffic (IET – P802.3br/D2.0)

When IET is enabled through CPSW\_CONTROL\_REG[17] IET\_ENABLE = 1h and configured, IET allows preemptable traffic on selected transmit priorities to be preempted by express traffic on selected express priorities. Received traffic is separated onto express and preempt receive queues. When IET is disabled (IET\_ENABLE = 0h), all Ethernet traffic is express traffic and switch operation is as if IET does not exist. Traffic is only intended to be moved to the preempt queue after preemption is verified and enabled.

##### 12.3.1.4.6.7.1 IET Configuration

1. Using the preempt receive queue requires more blocks to be allocated to the ports receive FIFO. Write a value of decimal 7 to the CPSW\_PN\_MAX\_BLKS\_REG\_k[7-0] RX\_MAX\_BLKS bit field, and a value of decimal 13 to the CPSW\_PN\_MAX\_BLKS\_REG\_k[15-8] TX\_MAX\_BLKS register for every port to be enabled for IET.
2. Write the [23-0]MAC\_VERIFY\_CNT bit field in the Ethernet port CPSW\_PN\_IET\_VERIFY\_REG\_k register to set the verify/response timeout count. The default is 10ms for Gigabit mode. For other time values or link speeds the verify count should be updated. If CPSW\_PN\_IET\_CONTROL\_REG\_k[2] MAC\_DISABLEVERIFY bit is to be set (this is forced mode) then this step is unneeded.
3. The receive FIFO block allocation is insufficient if CPSW\_STAT0\_RX\_BOTTOM\_OF\_FIFO\_DROP/CPSW\_STATN\_RX\_BOTTOM\_OF\_FIFO\_DROP\_k[31-0] COUNT is nonzero, indicating that receive packets are being dropped due to FIFO block allocation.
4. Write the CPSW\_PN\_IET\_CONTROL\_REG\_k register in the Ethernet port as below:
  - Set the CPSW\_PN\_CONTROL\_REG\_k[16] IET\_PORT\_EN bit. The port will not actually be enabled until bit IET\_ENABLE is set in the CPSW\_CONTROL\_REG.
  - The CPSW\_PN\_IET\_CONTROL\_REG\_k[0] MAC\_PENABLE bit can be set as desired. No effect will occur until IET\_ENABLE is set. This bit enables preemptable packets to be preempted by express traffic but does not preclude packets from being sent to the preempt queue.
  - If verify/response is desired then CPSW\_PN\_IET\_CONTROL\_REG\_k[3] MAC\_LINKFAIL should be cleared by software to enable verify and response packets. Otherwise, MAC\_DISABLEVERIFY bit should be set for forced mode. Verification and response will occur immediately after clearing this bit.
  - Configure the remaining CPSW\_PN\_IET\_CONTROL\_REG\_k register bits as desired.
5. Set the IET\_ENABLE bit in the CPSW\_CONTROL\_REG register to enable IET operations.

6. After preemption has been verified, the CPSW\_PN\_IET\_CONTROL\_REG\_k[23-16] MAC\_PREMPT field is written to configure the FIFO priorities to be sent to the preempt queue (the other priorities with cleared bits go to the express queue). The hardware switch for each queue from express to preempt happens only when there are no packets queued on the priority.

#### 12.3.1.4.6.8 Enhanced Scheduled Traffic (EST – P802.1Qbv/D2.2)

##### 12.3.1.4.6.8.1 Enhanced Scheduled Traffic Overview

- When enabled and configured, EST allows express queue traffic to be scheduled (placed) on the wire at specific repeatable time intervals.
- EST operates on a repeating time interval generated by the CPTS EST function generator. For example, a 125us repeating time interval can be configured.
- Each Ethernet port has 128 EST fetch commands maximum in the global EST fetch RAM.
- Each 22-bit fetch command consists of a 14-bit fetch count (14 MSB's) and an 8-bit priority fetch allow (8 LSB's) that will be applied for the fetch count time in wireside clocks.
- The configured port fetch commands are executed in sequence, beginning at port address zero each time through the time interval beginning at cycle start.
- EST allows non-scheduled express and preempt queue traffic to be cleared from the wire to ensure that the scheduled traffic is transmitted at the proper time (zero allow).
- EST can be used with or without preemption. The CPSW\_PN\_IET\_CONTROL\_REG[23-16] MAC\_PREMPT value determines whether the priority is enabled on the express or preempt queue. Whether a priority is on the express or preempt queue only effects the wire clear time from an EST operation perspective.
- Software should not move priorities to the preempt queue unless preemption is configured, enabled, and verified allowing preemption to occur.
- Express packet time stamp events can be enabled to assist software in configuring and timing EST operations.

##### 12.3.1.4.6.8.2 Enhanced Scheduled Traffic Fetch RAM

- The EST fetch RAM is read/writable in the CPSW configuration address space.
- The Ethernet transmit port has 128 locations in the global EST fetch RAM.
  - Ethernet port 1 has EST fetch RAM addresses 0x000-0x07F.
- **One buffer operation:** When CPSW\_PN\_EST\_CONTROL\_REG[0] EST\_ONEBUF is set to 1h, the 128 port locations operate as one buffer. The EST\_BUFACT bit in CPSW\_PN\_FIFO\_STATUS\_REG register is the upper address bit of the port's fetch RAM address indicating whether operation is currently in the upper or lower 64 locations of the port's fetch RAM.
- **Two buffer operation:** When CPSW\_PN\_EST\_CONTROL\_REG[0] EST\_ONEBUF is cleared there are two 64-location buffers with CPSW\_PN\_EST\_CONTROL\_REG[1] EST\_BUFSEL selecting the buffer to be used. When the buffer is switched by changing the CPSW\_PN\_EST\_CONTROL\_REG[1] EST\_BUFSEL value, the actual switch occurs on cycle start. The actual buffer being used is indicated by the EST\_BUFACT bit in CPSW\_PN\_FIFO\_STATUS\_REG. Software should avoid writing the switched out buffer fetch RAM locations until it detects that the actual switch has occurred.
- The first address location in the port's fetch RAM space (location zero) is read at the beginning of each EST time interval (cycle start). Addresses are then read in ascending order for the duration of the interval. The port address zero is then read again at the beginning of the next cycle repeating the time interval packet operations.

##### 12.3.1.4.6.8.3 Enhanced Scheduled Traffic Time Interval

- Each Ethernet port has an Enhanced Scheduled Traffic Function (ESTF) generator in the CPTS submodule.
- The EST function generator generates the EST time interval as a configured number of CPTS reference clocks (CPTS\_RFT\_CLK).
- The EST function generator rising edge is the cycle start time and the cycle repeats (cycle start occurs) after every time interval.

- The first fetch allowed value is at the port base address zero in the EST fetch RAM and is actually applied 16 wireside clocks after cycle start. The 16 clock cycle delay allows the first fetch value time to be fetched from the EST fetch RAM (prefetch time at cycle start).
- Each successive fetch allow is applied for the associated fetch count thereafter. The minimum non-zero fetch count is 16. The minimum value of 16 guarantees that the next fetch value has time to be fetched before the current fetch count is over. There are 64 maximum fetch values when CPSW\_PN\_EST\_CONTROL\_REG[0] EST\_ONEBUF = 0h, and 128 maximum fetch values when CPSW\_PN\_EST\_CONTROL\_REG[0] EST\_ONEBUF = 1h.
- The next cycle start then causes the fetch to once again start at the port address zero.

#### **12.3.1.4.6.8.4 Enhanced Scheduled Traffic Fetch Values**

- The 22-bit fetch value is made up of the 14-bit fetch count and the 8-bit fetch allow.
- The fetch time indicates the number of wireside clocks that the fetch allow will be active.
- The fetch count is in Ethernet wireside clocks which is bytes in Gigabit mode (CPSW\_PN\_MAC\_CONTROL\_REG[7] GIG = 1h) and nibbles in 10/100Mbps mode.
- When a fetch allow bit is set, the corresponding priority is enabled to begin packet transmission on an allowed priority subject to rate limiting. The actual packet transmission on the wire may carry over into the next fetch count and is the reason for the wire clear time in the fetch zero allow.
- When a fetch allow bit is cleared, the corresponding priority is not enabled to transmit for the fetch count time.
- A non-zero fetch allow value with a non-zero fetch count causes the fetch allow value to be applied for the fetch count number of wireside clocks.
- A zero fetch count causes the associated fetch allow to be held for the duration of the cycle (until the next cycle start).
- A zero fetch allow with a non-zero fetch count is intended to clear the wire for a scheduled (timed) express packet in the next fetch. A zero fetch allow indicates that no packet can be started for transmission for the associated fetch count. The associated fetch count must be sufficient to guarantee that the wire is cleared given that a packet on an allowed priority in the previous fetch could have been started on the previous clock and that there is hardware latency in the clear time. The timed packet should be sent on a priority that is enabled in the next fetch but disabled in the current zero allow fetch. The fetch allow previous to a zero allow should have only preempt priorities enabled or only express priorities enabled but not both.
- The number of clocks required to clear the wire varies depending Ethernet wire speed and on whether express or preempt priorities were allowed in the previous fetch command.

#### **12.3.1.4.6.8.5 Enhanced Scheduled Traffic Packet Fill**

Packet fill can (should) be configured and enabled to occur in the fetch count time associated with a fetched zero allow that precedes a timed express packet. The intention with fill is that a smaller packet on a non-timed priority might be able to be inserted on the wire during the wire clear time which would increase wire utilization. Fill must be configured to ensure that any fill packet does not conflict with the timed express packet allowed in the next fetch. Incorrect configuration might push out in time any express timed packet which indicates that the fill margin needs to be increased.

Fill Configuration:

- The **pn\_est\_fill\_margin** value in **Enet\_Pn\_EST\_Control** should be written with a 0x100 value.
- The **pn\_est\_preempt\_comp** value in **Enet\_Pn\_EST\_Control** should be written with a 0x12 value (if IET is to be configured and enabled). This value times eight is the number of wireside clocks required to clear preempt packets off the wire at the end of a zero allow.
- The **pn\_est\_fill\_en** bit in **Enet\_Pn\_EST\_Control** should be set.

#### **12.3.1.4.6.8.6 Enhanced Scheduled Traffic Time Stamp**

The EST can be configured to generate CPTS timestamp events for selected express traffic. The EST timestamp events use the CPTS host event type (CPSW\_CPTS\_EVENT\_1\_REG[23-20] EVENT\_TYPE = 7 decimal. The EST timestamps will not override host sent timestamps for packets that were sent from the host with an enabled host timestamp.

- EST Events (host events) contain the below information:
  - Time Stamp of the selected express packet.
  - The event CPSW\_CPTS\_EVENT\_1\_REG[28-24] PORT\_NUMBER indicates the transmit port number.
  - The event CPSW\_CPTS\_EVENT\_1\_REG[23-20] EVENT\_TYPE is decimal 7 (host event).
  - The event CPSW\_CPTS\_EVENT\_1\_REG[23-20] MESSAGE\_TYPE indicates the packet transmit hardware switch priority.
  - The event CPSW\_CPTS\_EVENT\_1\_REG[15-0] SEQUENCE\_ID upper nibble indicates the packet receive port number.
  - The event CPSW\_CPTS\_EVENT\_1\_REG[15-0] SEQUENCE\_ID lower byte indicates the sequence number of the express packet in numerical order. The first event is event one, the second is event two and so on. The sequence ID rolls over to zero after 0xFF (8-bits).
  - The event domain is the value from the CPSW\_EST\_TS\_DOMAIN\_REG[7-0] EST\_TS\_DOMAIN register.
- When CPSW\_PN\_EST\_CONTROL\_REG[2] EST\_TS\_EN is set, timestamp events will be generated on selected express traffic.
- When CPSW\_PN\_EST\_CONTROL\_REG[3] EST\_TS\_FIRST is also set, events will be generated only on the first express packet in each time interval. If CPSW\_PN\_EST\_CONTROL\_REG[4] EST\_TS\_ONEPRI is also set then the event will only be on the first CPSW\_PN\_EST\_CONTROL\_REG[7-5] EST\_TS\_PRI express packet in the time interval. If CPSW\_PN\_EST\_CONTROL\_REG[4] EST\_TS\_ONEPRI is clear then the event will be generated on the first express packet in the time interval on any priority.
- When CPSW\_PN\_EST\_CONTROL\_REG[3] EST\_TS\_FIRST is clear, events will be generated on every express packet. If CPSW\_PN\_EST\_CONTROL\_REG[4] EST\_TS\_ONEPRI is set then the event will be generated on every CPSW\_PN\_EST\_CONTROL\_REG[7-5] EST\_TS\_PRI express packet. If CPSW\_PN\_EST\_CONTROL\_REG[4] EST\_TS\_ONEPRI is clear then event will be generated on every express packet on any priority.

#### 12.3.1.4.6.8.7 Enhanced Scheduled Traffic Packets Per Priority

The number of packets allowed in a transmit FIFO priority can be selected by writing a non-zero value to CPSW\_P0\_RX\_PKTS\_PRI\_REG register (packet priority 0 to 7). Then port 0 receive gap should then be enabled by setting the corresponding priority through CPSW\_P0\_RX\_GAP\_REG[7-0] RX\_GAP\_EN bit field. The receive gap allows a packet to land in the transmit FIFO before another packet is allowed in which guarantees that only the selected number (max) of packets is allowed in on the specified priority. If the receive gap is not enabled, then there might be one or two more packets allowed in on the priority/thread than the packets per priority value has selected (through CPSW\_P0\_RX\_PKTS\_PRI\_REG register).

#### 12.3.1.4.6.9 Audio Video Bridging

Audio Video Bridging is an ongoing project of IEEE 802.1 concerned with enabling low-latency streaming of time-sensitive audiovisual data over networks. Devices are designated as talkers (transmitters), bridges, or listeners (receivers). It is suggested that the maximum latency could be 2 ms over 7 hops for Class A devices and 20 ms over 7 hops for Class B devices. A hop is essentially a single local area network stage in the journey of a packet. Every time a bridge is encountered between one network section and another a hop is involved. One of the performance goals is that AVB streams will not use more than 75 percent of a link's bandwidth, leaving the remaining capacity for non-AVB streams.

The goal of developing AVB is simply--extend Ethernet's data-networking capabilities to the realm of reliable real-time audio/video networking.

An "Audio Video Bridging" network is one that implements a set of protocols being developed by the IEEE 802.1 Audio/Video Bridging Task Group. There are four primary differences between the proposed Audio Video Bridging architecture and existing 802 architectures (from now on the term "AVB" will be used instead of "Audio Video Bridging"):

1. Precise synchronization - IEEE 802.1AS: "*Timing and Synchronization for Time-Sensitive Applications in Bridged Local Area Networks*. "a.k.a Precision Time Protocol (PTP).
2. Traffic shaping for media streams - IEEE 802.1Qav: "*Virtual Bridged Local Area Networks: Forwarding and Queuing for Time-Sensitive Streams*."

3. Admission controls - IEEE 802.1Qat: "Virtual Bridged Local Area Networks - Amendment 9: Stream Reservation Protocol (SRP)."
4. Identification of non-participating devices - IEEE 802.1BA: "Audio/Video Bridging (AVB) Systems"



**Figure 12-131. The Network Static with AVB**

The following sections describe the media transport protocols that work within the AVB framework.

**12.3.1.4.6.9.1 IEEE 802.1AS: Timing and Synchronization for Time-Sensitive Applications in Bridged Local Area Networks (Precision Time Protocol (PTP))**

The protocol defined by 802.1AS automatically selects a device to be the controller clock, and then distributes this clock throughout the bridged LAN / IP subnet to all other network devices using link-specific transmit/receive time-stamping. However, we only use a two-step solution only on transmit. That is, we do not modify a packet with the timestamp on the way out. The timestamp packet is sent out and then a separate message with the timestamp is sent by the host afterward. Receive can be one or two step.

**Note**

The 802.1AS-distributed clock is not used as a media clock. Rather, the shared 802.1AS clock reference is used to regenerate the media clock at the listener/renderer. Such a reference removes the need to force the latency of the network to be constant, or compute long running averages in order to estimate the actual media rate of the transmitter in the presence of substantial network jitter. IEEE 802.1AS is based on the ratified IEEE 1588 standard.

Based on IEEE 1588:2002, A PTP devices exchange standard Ethernet messages that synchronize network nodes to a common time reference by defining clock controller selection and negotiation algorithms, link delay measurement and compensation, and clock rate matching and adjustment mechanisms.

Designed as a simplified profile of IEEE 1588, a primary difference between 1588 and IEEE 802.1AS is that PTP is a layer 2-in other words, a non-IP routable protocol. Like IEEE 1588, PTP defines an automatic method for negotiating the network clock controller, the Best Controller Clock Algorithm (BCCA). PTP nodes can be assigned one of eight priority levels, presumably based on clock quality. BCCA defines the underlying negotiation and signaling mechanism whose purpose is to identify the AVB LAN Grandcontroller. Once a Grandcontroller has been selected, synchronization automatically begins.

At the core of 802.1AS synchronization is time-stamping. In short, during PTP message ingress/egress from the 802.1AS-capable MAC, the PTP Ether type triggers the sampling of the value of a local real-time counter (RTC). Target nodes compare the value of their RTC against the PTP Grandcontroller and, by use of link delay

measurement and compensation techniques, match their RTC value to the time of the AVB LAN PTP domain. After network time throughout the AVB LAN has converged, periodic SYNC and FOLLOW\_UP messages provide the information that enables the PTP rate matching adjustment algorithms. The result is all PTP nodes are then synchronized to the same "Wall Clock" time. PTP assures 1- $\mu$ s accuracy over seven network hops.



**Figure 12-132. AVB Network & PTP Clock Entities**

The media transport protocols that work within the AVB framework are:

#### 12.3.1.4.6.9.1.1 IEEE 1722: "Layer 2 Transport Protocol for Time-Sensitive Streams"

AVBTP or 1722 sits above the IEEE 802.1 AVB plumbing and below the application layer. It acts as the conduit between an Ethernet MAC and a streaming application. AVBTP abstracts the underlying network transmission channel to enable the virtual connection of distributed audio and video CODECs over reliable Ethernet networks. A complete AVBTP Ethernet packet is shown in [Figure 12-133](#) and illustrates how IEC 61883-6 AM824 uncompressed audio samples are encapsulated in an Ethernet frame.

#### IEEE 1722 Packet Construction



**Figure 12-133. IEEE 1722 Packets**

## 1722 or AVBTP Presentation Time and Synchronization:

Synchronization in an AVB network starts with the Precision Time Protocol but ends with synchronized media clocks. PTP is responsible for synchronizing all nodes in an AVB network to identical wall clock time; not for synchronizing media clocks. In other words, PTP does not actually transport synchronized media clocks but instead provides a low-level building block crucial for managing a distributed media synchronization system.

A crucial benefit of this approach is coexistence of multiple, independent media clock domains on an AVB network. Unrelated audio and video streams can simultaneously exist in the same LAN.

### 12.3.1.4.6.9.1.1.1 Cross-timestamping and Presentation Timestamps

AVBTP assumes that AVB node media clocks are clocked by free-running oscillators. It is also assumed that the node's internal concept of wall clock time has been synchronized to the PTP Grandcontroller. AVBTP media clock sources embed "AVBTP Presentation Timestamps" in AVBTP streaming packets. [Figure 12-134](#) illustrates the relationship between PTP network time and AVBTP Presentation Timestamps.



**Figure 12-134. Cross Time Stamping and Presentation Timestamps**

### 12.3.1.4.6.9.1.2 IEEE 1733: Extends RTCP for RTP Streaming over AVB-supported Networks

This standard specifies the protocol, data encapsulations, connection management and presentation time procedures used to ensure interoperability between audio and video based end stations that use standard networking services provided by all IEEE 802 networks meeting QoS requirements for time-sensitive applications by leveraging the Real-time Transport Protocol (RTP) family of protocols and IEEE 802.1 Audio/Video Bridging (AVB) protocols.

#### **12.3.1.4.6.9.2 IEEE 802.1Qav: "Virtual Bridged Local Area Networks: Forwarding and Queuing for Time-Sensitive Streams"**

This standard allows bridges to provide guarantees for time-sensitive (that is, bounded latency and delivery variation), loss-sensitive real-time audio video (AV) data transmission (AV traffic). It specifies per priority ingress metering, priority regeneration, and timing-aware queue draining algorithms. This standard uses the timing derived from IEEE 802.1AS. Virtual Local Area Network (VLAN) tag encoded priority values are allocated, in aggregate, to segregate frames among controlled and non-controlled queues, allowing simultaneous support of both AV traffic and other bridged traffic over and between wired and wireless Local Area Networks (LANs).

Such a guarantee in bandwidth is provided by two functional entities:

- A registration protocol, which registers the service and its maximum network utilization with a device or switch (IEEE 802.1Qat: "Virtual Bridged Local Area Networks - Amendment 9: Stream Reservation Protocol (SRP)")
- A hardware bandwidth management service.
  - Receive policing
  - Transmit rate control.

#### **End Station Behavior**

In order for an end station to successfully participate in the transmission and reception of time-sensitive streams, it is necessary for their behavior to be compatible with the operation of the forwarding and queuing mechanisms employed in bridges.

The requirements for end stations that participate as "talkers" i.e., sources of time-sensitive streams are different from the requirements that apply to "listeners", the destination station(s) for the streams.

#### **Talker Behavior**

In order for Talker-originated data streams to make use of the credit-based shaper behavior in Bridges, it is a requirement for a Talker to use the priorities that the Bridges in the network recognize as being associated with SR classes exclusively for transmitting stream data.

It is also necessary for the Talker and the Bridges in the path to the Listener(s), to have a common view of the bandwidth required in order to transmit the Talker's streams, and for that bandwidth to be reserved along the path to the Listener(s). This latter requirement can be met by means of stream reservation mechanisms, such as defined in SRP, or by other management means.

End stations that are Talkers shall exhibit transmission behavior for frames that are part of "time-sensitive streams" that is consistent with the operation of the credit-based shaper algorithm, both in terms of the way they transmit frames that are part of an individual data stream, and in terms of the way they transmit stream data frames from a Port.

In effect, the queuing model for a Talker Port (and a Listener port), and for given priorities, can be considered to look like [Figure 12-135](#).

#### **Listener Behavior**

The primary requirement for a listener station is that it is capable of buffering the amount of data that could be transmitted for a stream during a time period equivalent to the accumulated maximum jitter that could be experienced by stream data frames in transmission between Talker and Listener.

From the point of view of the specification of the forwarding and queuing requirements for time-sensitive streams, it is assumed that the listener will assess the buffering required for a stream as part of the stream bandwidth reservation mechanisms employed by the implementation.

The credit-based shaper's operation details are beyond the scope of this document.



cpsw-012

**Figure 12-135. AV Stream Queueing/Policing**

#### 12.3.1.4.6.9.2.1 Configuring the Device for 802.1Qav Operation

There is no dedicated register-set to be configured for the time-sensitive stream handling. The list of functional features of CPSW\_2G that will have to be configured are:

- DESCRIPTORS and CHANNEL CONFIGURATIONS:
  - CPPI TX and RX descriptors
  - VLAN and Priority tags

**Table 12-158. Example of TX Configuration**

| TX DMA CHANNEL | Packet Priority | Switch Queue Priority |
|----------------|-----------------|-----------------------|
| 7              | 7               | 3                     |
| 6              | 5               | 2                     |
| 5              | 3               | 1                     |
| 4              | 1               | 0                     |

**Table 12-159. Example of RX Configuration**

| RX DMA CHANNEL | Packet Priority | Switch Queue Priority |
|----------------|-----------------|-----------------------|
| 0              | 7               | 0                     |
| 0              | 5               | 0                     |
| 0              | 3               | 0                     |
| 0              | 1               | 0                     |

- ALE Configuration:
  - ALE in VLAN-ware mode, Non-ALE in bypass mode.

#### 12.3.1.4.6.10 Ethernet MAC Sliver

The Ethernet port peripheral is compliant to the IEEE Std 802.3 Specification. Half-duplex mode is supported in 10/100 Mbps mode, but not in 1000 Mbps (gigabit) mode.

## Features:

- Synchronous 10/100/1000 Mbit operation
- RMII/RGMII Interface
- Hardware Error handling including CRC
- Full-Duplex Gigabit operation (half-duplex gigabit is not supported)
- EtherStats and 802.3Stats RMON statistics gathering support for external statistics collection module
- Transmit CRC generation selectable on a per channel basis
- Emulation Support
- VLAN Aware Mode Support
- Hardware flow control
- Programmable Inter Packet Gap (IPG).

### **12.3.1.4.6.10.1 Ethernet MAC Sliver Overview**

#### **12.3.1.4.6.10.1.1 CRC Insertion**

The MAC generates and appends a 32-bit Ethernet CRC onto the transmitted data, if the transmit packet header PASS\_CRC bit is 0h. For the Ethernet port generated CRC case, a CRC at the end of the input packet data is not allowed.

If the header word PASS\_CRC bit is set, then the last four bytes of the TX data are transmitted as the frame CRC. The four CRC data bytes should be the last four bytes of the frame and should be included in the packet byte count value. The MAC performs no error checking on the outgoing CRC when the PASS\_CRC bit is set.

#### **12.3.1.4.6.10.1.2 MTXER**

The MTXER signal is only used for EEE. If an underflow condition occurs on a transmitted frame, the frame CRC will be inverted to indicate the error to the network. Underflow is a hardware error.

#### **12.3.1.4.6.10.1.3 Adaptive Performance Optimization (APO)**

The Ethernet MAC port incorporates Adaptive Performance Optimization (APO) logic that may be enabled by setting the TX\_PACE bit in the CPSW\_PN\_MAC\_CONTROL\_REG register. Transmission pacing to enhance performance is enabled when set. Adaptive performance pacing introduces delays into the normal transmission of frames, delaying transmission attempts between stations, reducing the probability of collisions occurring during heavy traffic (as indicated by frame deferrals and collisions) thereby increasing the chance of successful transmission.

When a frame is deferred, suffers a single collision, multiple collisions or excessive collisions, the pacing counter is loaded with an initial value of 31. When a frame is transmitted successfully (without experiencing a deferral, single collision, multiple collision or excessive collision) the pacing counter is decremented by one, down to zero.

With pacing enabled, a new frame is permitted to immediately (after one IPG) attempt transmission only if the pacing counter is zero. If the pacing counter is non zero, the frame is delayed by the pacing delay, a delay of approximately four inter-packet gap delays. APO only affects the IPG preceding the first attempt at transmitting a frame. It does not affect the back-off algorithm for re-transmitted frames.

#### **12.3.1.4.6.10.1.4 Inter-Packet-Gap Enforcement**

The measurement reference for the IPG of 96-bit times is changed depending on frame traffic conditions. If a frame is successfully transmitted without collision, and MCRS is de-asserted within approximately 48-bit times of MTXEN being de-asserted, then 96-bit times is measured from MTXEN. If the frame suffered a collision, or if MCRS is not de-asserted until more than approximately 48-bit times after MTXEN is de-asserted, then 96-bit times (approximately, but not less) is measured from MCRS.

The Ethernet port transmit inter-packet gap (IPG) may be shortened by eight bit times when short gap is enabled and triggered. Setting the [10] TX\_SHORT\_GAP\_ENABLE bit in the CPSW\_PN\_MAC\_CONTROL\_REG register enables the gap to be shortened when triggered. The condition is triggered when the ports associated transmit packet FIFO has a user defined number of FIFO blocks used. The associated transmit FIFO blocks used value determines if the gap is shortened, and so on. The CPSW\_GAP\_THRESH\_REG register value determines the

short gap threshold. If the FIFO blocks used is greater than or equal to the GAP\_THRESH value then short gap is triggered.

#### **12.3.1.4.6.10.1.5 Back Off**

The Gigabit Ethernet Mac Sliver implements the 802.3 binary exponential back-off algorithm.

#### **12.3.1.4.6.10.1.6 Programmable Transmit Inter-Packet Gap**

The transmit inter-packet gap (IPG) is programmable through the CPSW\_PN\_MAC\_CONTROL\_REG register. The default value is decimal 12. The transmit IPG may be increased to the maximum value of 1FFh. Increasing the IPG is not compatible with transmit pacing. The short gap feature will override the increased gap value, so the short gap feature may not be compatible with an increased IPG.

#### **12.3.1.4.6.10.1.7 Speed, Duplex and Pause Frame Support Negotiation**

The Ethernet port can operate in half duplex or full duplex in 10/100 Mbit modes, and can operate in full duplex only in 1000 Mbit mode. Pause frame support is included in 10/100/1000 Mbit modes as configured by the host.

#### **12.3.1.4.6.10.2 RMII Interface**

The CPRMII peripheral is compliant to the RMII specification document.

##### **12.3.1.4.6.10.2.1 Features**

- Source Synchronous 10/100 Mbit operation
- Full and Half Duplex support

##### **12.3.1.4.6.10.2.2 RMII Receive (RX)**

The CPRMII receive (RX) interface converts the input data from the external RMII PHY (or switch) into the required MII (CPGMAC) signals. The carrier sense and collision signals are determined from the RMII input data stream and transmit inputs as defined in the RMII specification.

An asserted RMII\_RXER on any di-bit in the received packet will cause an MII\_RXER assertion to the CPGMAC during the packet. In 10Mbps mode, the error is not required to be duplicated on 10 successive clocks. Any di-bit which has an asserted RMII\_RXER during any of the 10 replications of the data will cause the error to be propagated.

Any received packet that ends with an improper nibble boundary aligned RMII\_CRS\_DV toggle will issue an MII\_RXER during the packet to the CPGMAC. Also, a change in speed or duplex mode during packet operations will cause packet corruption.

The CPRMII can accept receive packets with shortened preambles, but 0x55 followed by a 0x5D is the shortest preamble that will be recognized (1 preamble byte with the start of frame byte). At least one byte of preamble with the start of frame indicator is required to begin a packet. An asserted RMII\_CRS\_DV without at least a single correct preamble byte followed by the start of frame indicator will be ignored.

##### **12.3.1.4.6.10.2.3 RMII Transmit (TX)**

The CPRMII transmit (TX) interface converts the CPGMAC MII input data into the RMII transmit format. The data is then output to the external RMII PHY.

The CPGMAC does not source the transmit error (MII\_TXERR) signal. Any transmit frame from the CPGMAC with an error (underrun) will be indicated as an error by an error CRC. Transmit error is assumed to be de-asserted at all times and is not an input into the CPRMII module. Zeroes are output on RMII\_TXD[1:0] for each clock that RMII\_TXEN is de-asserted.

#### **12.3.1.4.6.10.3 RGMII Interface**

The CPRGMII peripheral is compliant to the RGMII specification document.

##### **12.3.1.4.6.10.3.1 Features**

- Supports 1000/100/10 Mbps speed
- Full and Half Duplex support (CPGMAC supports only Full duplex in Gigabit mode).

- MII mode support
- Energy Efficient Ethernet Support

#### 12.3.1.4.6.10.3.2 RGMII Receive (RX)

The CPRGMII receive (RX) interface converts the source synchronous DDR input data from the external RGMII PHY into the required G/MII (CPGMAC) signals.

#### 12.3.1.4.6.10.3.3 In-Band Mode of Operation

The CPRGMII is operating in the in-band mode of operation when the RGMII\_RX\_INBAND input is asserted. RGMII\_RX\_INPUT is asserted by configuring the CTL\_EN bit to 1h of the CPSW\_PN\_MAC\_CONTROL\_REG register. The link status, duplexity, and speed are determined from the RGMII input data stream RXD[3:0] when RX\_CTL is deasserted, as defined in the RGMII specification. The PHY might need to be configured beforehand to output in-band data. The in-band data is indicated as shown in [Table 12-160](#).

**Table 12-160. In-Band Data**

| RXD3            | RXD[2:1]           | RXD0             |
|-----------------|--------------------|------------------|
| Duplex status:  | Link Speed:        | Link Status:     |
| 0h: half-duplex | 0h: 10-Mbps mode   | 0h: Link is down |
| 1h: full-duplex | 1h: 100-Mbps mode  | 1h: Link is up   |
|                 | 2h: 1000-Mbps mode |                  |
|                 | 3h: Reserved       | Reserved         |

#### 12.3.1.4.6.10.3.4 Forced Mode of Operation

The CPRGMII is operating in the forced mode of operation when the RGMII\_RX\_INBAND input is deasserted by setting to 0h bit CTL\_EN of the CPSW\_PN\_MAC\_CONTROL\_REG register. In the forced mode of operation, the in-band data is ignored if present. The link status is forced high, and the duplexity and speed are determined from the CPSW\_PN\_MAC\_CONTROL\_REG[0] FULLDUPLEX and CPSW\_PN\_MAC\_CONTROL\_REG[7] GIG bits. If bit [7] GIG = 1h, then CPRGMII is operating in Gigabit mode. If bit [7] GIG is cleared (0h), then CPRGMII is operating in 100 Mbps mode.

#### 12.3.1.4.6.10.3.5 RGMII Transmit (TX)

The CPRGMII transmit (TX) interface converts the CPGMAC G/MII input data into the DDR RGMII format. The DDR data is then output to the external PHY.

The CPGMAC does not source the transmit error (TXERR) signal. Any transmit frame from the CPGMAC with an error (underrun) will be indicated as an error by an error CRC. Transmit error is assumed to be deasserted at all times and is not an input into the CPRGMII module.

In 10/100 Mbps mode, the TXD[7:0] data bus uses only the lower nibble. The CPRGMII will output the lower nibble twice in 10/100 Mbps mode to avoid unnecessary signal switching.

Packets will be precluded from transmission through the CPRGMII module for 4096 transmit clocks after the rising edge of RGMII\_LINK. Packet transmission will begin on the first TX\_CTL rising edge after the 4096 transmit clock count has expired.

#### 12.3.1.4.6.10.4 Frame Classification

Received frames are proper (good) frames if they are between 64 and CPSW\_P0\_RX\_MAXLEN\_REG[13:0] RX\_MAXLEN in length (inclusive) and contain no errors (code/align/CRC).

Received frames are long frames if their frame count exceeds the value in the CPSW\_P0\_RX\_MAXLEN\_REG CPSW\_PN\_RX\_MAXLEN\_REG register. The register reset (default) value is 1518 (decimal). Long received frames are either oversized or jabber frames. Long frames with no errors are oversized frames. Long frames with CRC, code, or alignment errors are jabber frames.

Received frames are short frames if their frame count is less than 64 bytes. Short frames that contain no errors are undersized frames. Short frames with CRC, code, or alignment errors are fragment frames. If RX\_CSF\_EN

bit in CPSW\_PN\_MAC\_CONTROL\_REG is set to 1h, undersized frames from 33 to 63 bytes will be forwarded only to the host on a best effort basis (meaning that the ALE may or may not be able to keep up with the packet rate and the short packet may be dropped due to bandwidth limitations). If RX\_CSF\_EN and RX\_CEF\_EN in CPSW\_PN\_MAC\_CONTROL\_REG are set, fragment frames from 33 to 63 bytes will also be forwarded only to the host on a best effort basis. Ethernet port received frames shorter than 33 bytes are dropped in all cases.

A received long packet will always contain RX\_MAXLEN number of bytes transferred to memory (if CPSW\_PN\_MAC\_CONTROL\_REG[22]RX\_CEF\_EN = 1h). An example with RX\_MAXLEN = 1518 is:

- If the frame length is 1518, then the packet is not a long packet and there will be 1518 bytes transferred to memory.
- If the frame length is 1519, there will be 1518 bytes transferred to memory. The last three bytes will be the first three CRC bytes.
- If the frame length is 1520, there will be 1518 bytes transferred to memory. The last two bytes will be the first two CRC bytes.
- If the frame length is 1521, there will be 1518 bytes transferred to memory. The last byte will be the first CRC byte.

If the frame length is 1522, there will be 1518 bytes transferred to memory. The last byte will be the last data byte.

#### **12.3.1.4.6.10.5 Receive FIFO Architecture**

This section describes the architecture of the Ethernet port's receive FIFOs. Internal to the Gigabit Ethernet switch, all Ethernet ports have an identical associated packet FIFO. Each transmit packet FIFO contains eight logical transmit queues (priority 0 through 7 with 7 the highest priority). Each transmit FIFO memory contains 81,920 bytes total organized as 2560 by 256-bit words. Each FIFO also contains a single memory for the receive queue. Each receive FIFO memory contains a total of 32768 bytes total organized as 1024 by 256-bit words.

#### **12.3.1.4.6.11 Embedded Memories**

**Table 12-161. Embedded Memories**

| Memory Type Description           | Number of Instances |                     |
|-----------------------------------|---------------------|---------------------|
| Single-port 3072-word × 64 RAM    | 1                   | (Combined FIFO RAM) |
| Single-port 128-word × 28-bit RAM | 1                   | 1 (EST)             |

#### 12.3.1.4.6.12 Memory Error Detection and Correction

The CPSW\_2G error detection and correction logic uses the ECC Aggregator Module.

The ECC CPSW\_ECC\_VECTOR register is used to select which ECC RAM's status and control registers are currently being read or written as shown in [Table 12-162](#). The CPSW FIFO RAMs implement ECC only on packet headers. The packet data is protected by Ethernet CRC. The ALE and EST RAMs have complete ECC as normal.

**Table 12-162. ECC RAM to CPSW RAM Mapping**

| ECC RAM Number | CPSW RAM        |
|----------------|-----------------|
| 0              | ALE RAM         |
| 1              | Port 0 FIFO RAM |

#### 12.3.1.4.6.12.1 Packet Header ECC

Only packet headers bits are protected by ECC in the FIFO RAMs. The ECC\_ERR\_CTRL1[31-0] ECC\_ROW bit is used to activate a row address where force single-bit error or force double-bit error needs to be applied. ECC\_ERR\_CTRL2 [15-0] ECC\_BIT1 is implemented to determine which bit of the header is flipped for an SEC error when the ECC\_CRC\_MODE bit is cleared in the CPSW\_CONTROL\_REG register. The ECC status registers return the RAM row address where the single or double-bit error has occurred (ECC\_ERR\_STAT2[31-0] ECC\_ROW) along with the bit position in the RAM data that is in error (ECC\_ERR\_STAT1[31-16] ECC\_BIT1 value). Forcing double-bit errors in testing can cause indeterminate operation if multiple used packet header bits are flipped given that only single-bit errors are fixed by the ECC logic. Header bits 207 down to 200 are not currently used in the CPSW and may be used to test double bit errors without the possibility of requiring a reset for the switch to recover from the double bit error. No header bits are flipped when ECC\_CRC\_MODE is set to 1h. Either the RX\_ECC\_ERR\_EN (enable receive ECC error operations) or the TX\_ECC\_ERR\_EN (enable transmit ECC error operations) bits must be set in the CPSW\_P0\_CONTROL\_REG register to test ECC header errors.

The header ECC code is stored in bits 255 down to 208. If any bit is flipped in the ECC code, the flipped bit will be corrected, but the index of the flipped bit will be reported as bit zero. This implies that when the aggregator reports that there is a SEC on bit 0, it can mean two things: either SEC on data bit 0 or SEC somewhere inside the ECC code. Any packet header with ECC error issues a pulse interrupt (ECC\_PULSE\_INTR) as does an ALE RAM ECC error.

#### 12.3.1.4.6.12.2 Packet Protect CRC

Each packet received without error is passed through the CPSW\_2G memories with a generated Ethernet protect CRC. The protect CRC is checked on egress for correctness and removed. If the CRC is correct (no RAM bit errors), then the packet is output with the selected port CRC type. If a protect CRC error is detected on host egress then the TXST\_DROP signal will be asserted so that the packet is dropped to the host. If a protect CRC error is detected on Ethernet egress then the egress CRC will be generated on the packet and at least one byte of the CRC will be inverted on output. CRC memory protect errors do not assert the ECC\_PULSE\_INTR signal. CRC memory protect errors are counted in the associated port statistics registers and issue an interrupt on STAT\_PEND\_INTR if any CRC memory protect error occurs (and the statistics for that port are enabled). When the ECC\_CRC\_MODE bit in the CPSW\_CONTROL\_REG register is set, the ECC\_ERR\_CTRL2 [15-0] ECC\_BIT1 bit field will flip the associated column bit in any FIFO memory read operation, inducing a CRC protect error when the protect CRC is checked. No header bits are flipped when ECC\_CRC\_MODE is set. Either the RX\_ECC\_ERR\_EN or the TX\_ECC\_ERR\_EN bits must be set in the CPSW\_P0\_CONTROL\_REG register to test packet CRC errors.

#### 12.3.1.4.6.12.3 Aggregator RAM Control

The ECC logic for each FIFO RAM (receive and transmit) is divided into eight separate ECC encoders/decoders that encode/decode 26-bits of data each. Each of the 8 encoders (0 to 7) generates 6-bits of ECC code (48 code bits total), and each of the eight decoders (0 to 7) checks 6-bits of ECC code across the 26-bits of data (208 data bits total). The 48-bits of ECC code are passed through the RAM in the upper 48 unused bits in the header word.

The header data bits and ECC code bits are shown in [Table 12-163](#). The [15:0] ECC\_BIT1 value returned on error is a 16-bit value that is the concatenation of 5 bits of zero, 3 bits of the encoder/decoder number (0 to 7), 3 bits of zero, and 5 bits of index into the indicated 26-bit encoder/decoder.

For example, an ECC\_BIT1 value of 0x0308 is bit 8 of encoder/decoder 3, which is header bit 86 (that is,  $(26 \times 3) + 8$ ).

**Table 12-163. ECC Submodule Header Data Bit to Encoder/Decoder Mapping**

| Header Data Bits | Encoder/Decoder        |
|------------------|------------------------|
| 25:0             | Encoder/Decoder 0 Data |
| 51:26            | Encoder/Decoder 1 Data |
| 77:52            | Encoder/Decoder 2 Data |
| 103:52           | Encoder/Decoder 3 Data |
| 129:104          | Encoder/Decoder 4 Data |
| 155:130          | Encoder/Decoder 5 Data |
| 181:156          | Encoder/Decoder 6 Data |
| 207:182          | Encoder/Decoder 7 Data |
| 213:208          | Encoder/Decoder 0 ECC  |
| 219:214          | Encoder/Decoder 1 ECC  |
| 225:220          | Encoder/Decoder 2 ECC  |
| 231:226          | Encoder/Decoder 3 ECC  |
| 237:232          | Encoder/Decoder 4 ECC  |
| 243:238          | Encoder/Decoder 5 ECC  |
| 249:244          | Encoder/Decoder 6 ECC  |
| 255:250          | Encoder/Decoder 7 ECC  |

#### 12.3.1.4.6.13 Ethernet Port Flow Control

The Ethernet port have flow control available for transmit and receive. Transmit flow control stops the Ethernet port from transmitting packets to the wire (switch egress) in response to a received pause frame. Transmit flow control does not depend on FIFO usage.

The Ethernet port have flow control available for receive operations (packet ingress). Ethernet port receive flow control is initiated when enabled and triggered. Packets received on an Ethernet port can be sent to the CPPI port. The destination port can trigger the receive Ethernet port flow control. An Ethernet destination port triggers another Ethernet receive flow control when the destination port is full.

When a packet is received on an Ethernet port interface with enabled flow control the below occurs:

- The packet will be sent to all ports that currently have room to take the entire packet.
- The packet will be retried until successful to all ports that indicate they don't have room for the packet.

The flow control trigger to the Ethernet port will be asserted until the packet has been sent, and there is room in the logical receive FIFO for packet runout from another flow control trigger (RX\_BLK\_CNT = 0h). Ethernet port receive flow control is disabled by default on reset. Ethernet port receive flow control requires that the RX\_FLOW\_EN bit in CPSW\_PN\_MAC\_CONTROL\_REG be set to 1h. When receive flow control is enabled on a port, the port's associated FIFO block allocation must be adjusted. The port RX allocation must increase from the default three blocks to accommodate the flow control runout. A corresponding decrease in the TX block allocation is required. If a sending port ignores a pause frame then packets may overrun on receive (and be dropped) but will not be dropped on transmit.

#### 12.3.1.4.6.13.1 Ethernet Receive Flow Control

For every Ethernet port to be configured for fullduplex receive flow control, write a value of decimal 7 to the CPSW\_PN\_MAX\_BLKS\_REG[7-0] RX\_MAX\_BLKS bit field, and a value of decimal 13 to the CPSW\_PN\_MAX\_BLKS\_REG[15-8] TX\_MAX\_BLKS register. This re-allocation allows for flow control runout on the receive FIFO at the expense of FIFO memory on the Ethernet transmit side. 10/100Mbps half-duplex collision based receive flow control does not need this re-allocation. Receive flow control is enabled by the RX\_FLOW\_EN bit in the CPSW\_PN\_MAC\_CONTROL\_REG register.

##### 12.3.1.4.6.13.1.1 Collision Based Receive Buffer Flow Control

Collision-based receive buffer flow control provides a means of preventing frame reception when the port is operating in half-duplex mode (FULLDUPLEX is cleared in CPSW\_PN\_MAC\_CONTROL\_REG). When receive flow control is enabled and triggered, the port will generate collisions for received frames. The jam sequence transmitted will be the twelve byte sequence C3.C3.C3.C3.C3.C3.C3.C3.C3.C3.C3.C3 (hex). The jam sequence will begin no later than approximately as the source address starts to be received. Note that these forced collisions will not be limited to a maximum of 16 consecutive collisions, and are independent of the normal back-off algorithm. Receive flow control does not depend on the value of the incoming frame destination address. A collision will be generated for any incoming packet, regardless of the destination address.

##### 12.3.1.4.6.13.1.2 IEEE 802.3X Based Receive Flow Control

IEEE 802.3x based receive flow control provides a means of preventing frame reception when the port is operating in full-duplex mode (FULLDUPLEX bit is set in the CPSW\_PN\_MAC\_CONTROL\_REG register). When receive flow control is enabled and triggered, the port will transmit a pause frame to request that the sending station stop transmitting for the period indicated within the transmitted pause frame.

The Ethernet port will transmit a pause frame to the reserved multicast address at the first available opportunity (immediately if currently idle, or following the completion of the frame currently being transmitted). The pause frame will contain the maximum possible value for the pause time (FFFFh). The MAC will count the receive pause frame time (decrements FF00h down to 0) and retransmit an outgoing pause frame if the count reaches zero. When the flow control request is removed, the MAC will transmit a pause frame with a zero pause time to cancel the pause request.

Note that transmitted pause frames are only a request to the other end station to stop transmitting. Frames that are received during the pause interval will be received normally (provided the RX FIFO is not full at which time the receive FIFO will overrun and CPSW\_STAT0\_RX\_BOTTOM\_OF\_FIFO\_DROP/ CPSW\_STAT1\_RX\_BOTTOM\_OF\_FIFO\_DROP[31-0] COUNT value will increment).

Pause frames will be transmitted if enabled and triggered regardless of whether or not the port is observing the pause time period from an incoming pause frame.

The Ethernet port will transmit pause frames as described below:

- The 48-bit reserved multicast destination address 01.80.C2.00.00.01.
- The 48-bit source address - from SL\_SA[47-0] input.
- The 16-bit length/type field containing the value 88.08
- The 16-bit pause opcode equal to 00.01
- The 16-bit pause time value FF.FF. A pause-quantum is 512 bit-times. Pause frames sent to cancel a pause request will have a pause time value of 00.00.
- Zero padding to 64-byte data length (The Ethernet port will transmit only 64 byte pause frames).
- The 32-bit frame-check sequence (CRC word).

All quantities above are hexadecimal and are transmitted most-significant byte first. The least-significant bit is transferred first in each byte.

If CPSW\_PN\_MAC\_CONTROL\_REG[3] RX\_FLOW\_EN is cleared to 0h while the pause time is nonzero, then the pause time will be cleared to 0h and a 0 count pause frame will be sent.

#### **12.3.1.4.6.13.2 Flow Control Trigger**

Receive flow control is triggered (when enabled), when the number of words in the receive FIFO is greater than or equal to the value written in the CPSW\_PN\_RX\_FLOW\_THRESH\_REG[8-0] COUNT bit field. The flow control packet runout is then contained in the remainder of the receive FIFO.

#### **12.3.1.4.6.13.3 Ethernet Transmit Flow Control**

Incoming pause frames are acted upon, when enabled, to prevent the Ethernet port from transmitting any further frames. Incoming pause frames are only acted upon when the [0] FULLDUPLEX and [4] TX\_FLOW\_EN bits in the CPSW\_PN\_MAC\_CONTROL\_REG register are set. Pause frames are not acted upon in half-duplex mode. Pause frame action will be taken if enabled, but normally the frame will be filtered and not transferred to memory. MAC control frames will be transferred to memory if the [24] RX\_CMF\_EN (RX Copy MAC Control Frames Enable) bit in the CPSW\_PN\_MAC\_CONTROL\_REG register is set. The [4] TX\_FLOW\_EN and [0] FULLDUPLEX bits effect whether or not MAC control frames are acted upon, but they have no effect upon whether or not MAC control frames are transferred to memory or filtered.

Pause frames are a subset of MAC Control Frames with an opcode field = 0001h. Incoming pause frames will only be acted upon by the port if:

- [4] TX\_FLOW\_EN is set in CPSW\_PN\_MAC\_CONTROL\_REG register, and
- the RX maximum frame length is 64 bytes inclusive (CPSW\_PN\_RX\_MAXLEN\_REG[13-0] RX\_MAXLEN), and
- the frame contains no CRC error or align/code errors.

The pause time value from valid frames will be extracted from the two bytes following the opcode. The pause time will be loaded into the port's transmit pause timer and the transmit pause time period will begin.

If a valid pause frame is received during the transmit pause time period of a previous transmit pause frame then:

- if the destination address is not equal to the reserved multicast address or any enabled or disabled unicast address, then the transmit pause timer will immediately expire, or
- if the new pause time value is zero then the transmit pause timer will immediately expire, else the port transmit pause timer will immediately be set to the new pause frame pause time value. (Any remaining pause time from the previous pause frame will be discarded).

If [4] TX\_FLOW\_EN in CPSW\_PN\_MAC\_CONTROL\_REG register is cleared, then the pause-timer will immediately expire.

The port will not start the transmission of a new data frame any sooner than 512-bit times after a pause frame with a non-zero pause time has finished being received (MRXDV going inactive). No transmission will begin until the pause timer has expired (the port may transmit pause frames in order to initiate outgoing flow control). Any frame already in transmission when a pause frame is received will be completed and unaffected.

Incoming pause frames consist of the below:

- A 48-bit destination address equal to:
  - The reserved multicast destination address 01.80.C2.00.00.01, or the Ethernet port SL\_SA [47:0] input.
- The 48-bit source address of the transmitting device.
- The 16-bit length/type field containing the value 88.08
- The 16-bit pause opcode equal to 00.01
- The 16-bit CPSW\_PN\_MAC\_TX\_PAUSETIMER\_REG[15-0] TX\_PAUSETIMER. A pause-quantum is 512 bit-times.
- Padding to 64-byte data length.
- The 32-bit frame-check sequence (CRC word).

All quantities above are hexadecimal and are transmitted most-significant byte first. The least-significant bit is transferred first in each byte.

The padding is required to make up the frame to a minimum of 64 Bytes. The standard allows pause frames longer than 64 Bytes to be discarded or interpreted as valid pause frames. The Ethernet port will recognize any pause frame between 64 Bytes and CPSW\_PN\_RX\_MAXLEN\_REG[13-0] RX\_MAXLEN bytes in length.

#### 12.3.1.4.6.14 Energy Efficient Ethernet Support (802.3az)

Energy Efficient Ethernet (EEE) allows the LPSC to turn off the module clock during inactive periods as determined by network and host traffic. The module can then be awakened by host queued transmit packet(s) or by a port's external Ethernet PHY. The module EEE clock stop interface is used by the external controller to control module EEE operations. EEE operations are configured as shown below:

1. The 12-bit EEE clock pre-scale value is written to the CPSW\_EEE\_PRESCALE\_REG register. The pre-scaler is used to clock all EEE-related counters
2. The port Idle to LPI count values (CPSW\_PN\_IDLE2LPI\_REG[23-0] COUNT) are written with the desired values
3. The port LPI to Wake count values (CPSW\_PN\_LPI2WAKE\_REG[23-0] COUNT) are written with the desired values
4. The [0] EEE\_EN bit is set in the switch CPSW\_SS\_CONTROL\_REG register

EEE operation can begin after configuration. The host allows (through LPSC) the CPSW to enter a low power state by asserting the EEE\_CLKSTOP\_REQ signal. There are no requirements on host queues or traffic in order for the host to assert or de-assert EEE\_CLKSTOP\_REQ to the CPSW.

Each Ethernet port has a transmit and a receive LPI (low power indicate) state. The PHY indicates LPI by asserting MRXER with a MRXD[7:0] value of 0x01 while MRXDV is deasserted (inter-packet gap). The Ethernet transmit port indicates LPI after the CPSW\_PN\_IDLE2LPI\_REG value has been counted (the transmit port has gone idle for the configured amount of time). If another packet is received for transmit during the count then the count is restarted. When the transmit port has been idle for the Idle to LPI time, the transmit port enters the LPI state and indicates LPI to the associated PHY. The LPI is indicated to the external PHY by an asserted MTXER with a MTXD[7:0] while MTXEN is deasserted (inter-packet gap). The CPPI (port 0) LPI state includes transmit and receive. The CPPI LPI state is entered when the CPPI transmit and receive have both been idle for the Idle to LPI time (CPSW\_P0\_IDLE2LPI\_REG). The Idle to LPI time value for all ports must be large relative to the switch latency to ensure that the count is not able to complete between successive packets.

---

#### Note

External PHY signaling has the following conditions:

- RGMII is a DDR interface. TXEN and TXER are the sampled values of TX\_CTL at the rising and the falling TXC edges, respectively. RXDV and RXER are the sampled values of RX\_CTL at the rising and the falling RXC clock edges, respectively
  - In RMII mode, EEE is not supported.
- 

When all transmit and receive ports are in the LPI state (CPSW LPI state), the EEE\_CLKSTOP\_ACK signal is asserted, and the LPSC is allowed to stop the module clock. When EEE\_CLKSTOP\_ACK is asserted, the clock may be turned on and off as desired by the host. The host is allowed to restart the clock, perform target read/write operations to the CPSW memory address space, and then turn off the clock again while EEE\_CLKSTOP\_ACK is asserted.

The software can remove and disable from re-entering the CPSW LPI state by restarting the module clock and then de-asserting EEE\_CLKSTOP\_REQ. There must be at least one rising edge of the clock before EEE\_CLKSTOP\_REQ is de-asserted. The module EEE\_CLKSTOP\_ACK output signal will be deasserted on the clock after the de-assertion of EEE\_CLKSTOP\_REQ. The host may queue CPPI receive packets at any time without regard to the CPSW module LPI state. The Host must deassert EEE\_CLKSTOP\_REQ on wakeup for a minimum of two clock periods. If EEE\_CLKSTOP\_REQ is deasserted for less than 5 clock periods for a wakeup event from the host to a particular Ethernet port (or visa versa), then the wakeup event will not cause the other Ethernet port port to awaken.

The external Ethernet PHY's can also wakeup the LPSC by removing the Ethernet receive LPI indication. If the CPSW module is in Idle state with EEE\_CLKSTOP\_ACK asserted and the receive LPI indication is removed, the EEE\_CLKSTOP\_WAKEUP signal will be asynchronously asserted. On wakeup, the LPSC restarts the clock and de-assert the EEE\_CLKSTOP\_REQ signal. The EEE\_CLKSTOP\_WAKEUP signal will be synchronously deasserted with EEE\_CLKSTOP\_ACK. Upon the deassertion of EEE\_CLKSTOP\_REQ, the Ethernet ports will count the CPSW\_PN\_LPI2WAKE\_REG time for each port at which time the port is available for transmit.

#### 12.3.1.4.6.15 Ethernet Switch Latency

When CPSW is configured as a store and forward switch, the switch latency is defined as the amount of time between the end of packet reception of the received packet to the start of the output packet transmit.

The store and forward latency is shown in [Table 12-164](#):

**Table 12-164. Switch Latency**

| Mode       | Latency     |
|------------|-------------|
| Gig (1000) | 880 ns      |
| 100        | 1.3 $\mu$ s |
| 10         | 6.5 $\mu$ s |

#### 12.3.1.4.6.16 MAC Emulation Control

The emulation control input (EMUSUSP) and submodule emulation control registers allow CPSW operation to be completely or partially suspended. Each Ethernet port has associated emulation control registers (CPSW\_EM\_CONTROL\_REG and CPSW\_PN\_MAC\_EMCONTROL\_REG). The submodule emulation control registers must be accessed to facilitate CPSW emulation control. The CPSW module enters the emulation suspend state if all three submodules are configured for emulation suspend and the emulation suspend input is asserted. A partial emulation suspend state is entered if one or two submodules is configured for emulation suspend and the emulation suspend input is asserted. Emulation suspend occurs at packet boundaries. The emulation control feature is implemented for compatibility with other peripherals.

#### Ethernet port Emulation Control

The emulation control input (TBEMUSUP) and register bits (SOFT and FREE bits in the CPSW\_PN\_MAC\_EMCONTROL\_REG register) allow Ethernet port operation to be suspended. When the emulation suspend state is entered, the Ethernet port will stop processing receive and transmit frames at the next frame boundary. Any frame currently in reception or transmission will be completed normally without suspension. For receive, frames that are detected by the Ethernet port after the suspend state is entered are ignored.

[Table 12-165](#) shows the operations of the emulation control input and register bits.

**Table 12-165. Emulation Control Input**

| EMUSUSP | SOFT | FREE | Description       |
|---------|------|------|-------------------|
| 0       | X    | X    | Normal Operation  |
| 1       | 0    | 0    | Normal Operation  |
| 1       | 1    | 0    | Emulation Suspend |
| 1       | X    | 1    | Normal Operation  |

#### 12.3.1.4.6.17 MAC Command IDLE

The CMD\_IDLE bit in the CPSW\_PN\_MAC\_CONTROL\_REG register allows MAC operation to be suspended. When the idle state is commanded, the MAC will stop processing receive and transmit frames at the next frame boundary. Any frame currently in reception or transmission will be completed normally without suspension. For transmission, any complete or partial frame in the TX cell FIFO will be transmitted. For receive, frames that are detected by the MAC after the suspend state is entered are ignored. No statistics will be kept for ignored frames. Commanded idle is similar in operation to emulation control and clock stop.

#### 12.3.1.4.6.18 CPSW Network Statistics

The CPSW has a set of statistics that record events associated with frame traffic on selected switch ports. The statistics values are cleared to zero 38 clocks after the rising edge of CPSW0\_RST. When one or more port enable (Pn\_STAT\_EN) bits in the CPSW\_STAT\_PORT\_EN\_REG register are set, all statistics registers are write to decrement. The value written will be subtracted from the register value with the result being stored in the register. If a value greater than the statistics value is written, then zero will be written to the register (writing 0xFFFF FFFF clears a statistics location). When all port enable bits are cleared to zero, all statistics registers are read/write (normal write direct, so writing 0x0000 0000 clears a statistics location). All write accesses must be 32-bit accesses.

The statistics interrupt (STAT\_PEND0) will be issued if enabled when any statistics value is greater than or equal to 0x8000 0000. The statistics interrupt is removed by writing to decrement any statistics value greater than 0x8000 0000. The statistics are mapped into internal memory space and are 32-bits wide. All statistics rollover from 0xFFFF FFFF to 0x0000 0000.

Table 12-166 and Table 12-167 summarize network statistics.

##### 12.3.1.4.6.18.1 Rx-only Statistics Descriptions

###### 12.3.1.4.6.18.1.1 Good Rx Frames (Offset = 3A000h)

###### All ports

The total number of good frames received on the port. A good frame is defined to be:

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Had a length of 64 to RX\_MAXLEN bytes inclusive
- Had no CRC error, alignment error or code error.

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

###### 12.3.1.4.6.18.1.2 Broadcast Rx Frames (Offset = 3A004h)

###### All ports

The total number of good broadcast frames received on the port. A good broadcast frame is defined to be:

- Any data or MAC control frame which was destined for address FF.FF.FF.FF.FF.FF
- Had a length of 64 to RX\_MAXLEN bytes inclusive
- Had no CRC error, alignment error or code error.

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

###### 12.3.1.4.6.18.1.3 Multicast Rx Frames (Offset = 3A008h)

###### All ports

The total number of good multicast frames received on the port. A good multicast frame is defined to be:

- Any data or MAC control frame which was destined for any multicast address other than FF.FF.FF.FF.FF.FF
- Had a length of 64 to RX\_MAXLEN bytes inclusive
- Had no CRC error, alignment error or code error

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

**12.3.1.4.6.18.1.4 Pause Rx Frames (Offset = 3A00Ch)****Ethernet port N where N = 1 to 2**

The total number of IEEE 802.3X pause frames received by the port (whether acted upon or not). Such a frame:

- Contained any unicast, broadcast, or multicast address
- Contained the length/type field value 88.08 (hex) and the opcode 0x0001
- Was of length 64 to RX\_MAXLEN bytes inclusive
- Had no CRC error, alignment error or code error
- Pause-frames had been enabled on the port (TX\_FLOW\_EN = 1h).

The port could have been in either half or full-duplex mode.

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

**12.3.1.4.6.18.1.5 Rx CRC Errors (Offset = 3A010h)****All ports**

The total number of frames received on the port that experienced a CRC error. Such a frame:

- Was any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Was of length 64 to RX\_MAXLEN bytes inclusive
- Had no code/align error
- Had a CRC error

Overruns have no effect upon this statistic.

A CRC error is defined to be:

- A frame containing an even number of nibbles, and
- Failing the Frame Check Sequence test.

**12.3.1.4.6.18.1.6 Rx Align/Code Errors (Offset = 3A014h)****Ethernet port N where N = 1 to 2**

The total number of frames received on the port that experienced an alignment error or code error. Such a frame:

- Was any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Was of length 64 to RX\_MAXLEN bytes inclusive
- Had either an alignment error, or a code error.

Overruns have no effect upon this statistic.

An alignment error is defined to be:

- A frame containing an odd number of nibbles
- Failing the Frame Check Sequence test if the final nibble is ignored

A code error is defined to be a frame which has been discarded because the port's MRXER pin driven with a one for at least one bit-time's duration at any point during the frame's reception.

---

**Note**

RFC 1757 etherStatsCRCAlignErrors Ref. 1.5 can be calculated by summing Rx Align/Code Errors and Rx CRC errors.

---

**12.3.1.4.6.18.1.7 Oversize Rx Frames (Offset = 3A018h)****All ports**

The total number of oversized frames received on the port. An oversized frame is defined to be:

- Was any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Was greater than RX\_MAXLEN in bytes
- Had no CRC error, alignment error, or code error.

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

**12.3.1.4.6.18.1.8 Rx Jabbers (Offset = 3A01Ch)****All ports**

The total number of jabber frames received on the port. A jabber frame:

- Was any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Was greater than RX\_MAXLEN in bytes
- Had no CRC error, alignment error or code error

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

**12.3.1.4.6.18.1.9 Undersize (Short) Rx Frames (Offset = 3A020h)****All ports**

The total number of undersized frames received on the port. An undersized frame is defined to be:

- Was any data frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Was less than 64 bytes
- Had no CRC error, alignment error, or code error

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

**12.3.1.4.6.18.1.10 Rx Fragments (Offset = 3A024h)****Ethernet port N where N = 1 to 2**

The total number of frame fragments received on the port. A frame fragment is defined to be:

- Any data frame (address matching does not matter)
- Less than 64 bytes long
- Having a CRC error, an alignment error, or a code error
- Not the result of a collision caused by half-duplex, collision-based flow control

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

#### **12.3.1.4.6.18.1.11 RX IPG Error (Offset = 3A05Ch)**

The total number of 10G frames received on a port that had a correct preamble but did not have at least five bytes of IDLE preceding the frame. This does not indicate if the frame with the IPG error was kept or ignored.

#### **12.3.1.4.6.18.1.12 ALE Drop (Offset = 3A028h)**

##### **All ports**

The total number of frames received on a port such that the destination address was not equal to the source address and the packet was not destined to the port it was received on, but the frame was not forwarded to any port (the PORT\_MASK was zero).

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- had no CRC error, alignment error, or code error
- the destination address was not equal to the source address
- the packet was not destined for the port it was receive on
- had a zero PORT\_MASK

#### **12.3.1.4.6.18.1.13 ALE Overrun Drop (Offset = 3A02Ch)**

##### **All ports (non cut-thru mode)**

The total number of frames received on a port that were dropped (zero PORT\_MASK) due to exceeding the maximum ALE lookup rate (Port 0 should not have ALE Overrun Drops because the ingress rate is controlled to prevent it). This statistic should be zero and when non-zero indicates a system clock issue or indicates that short packets were sent with RX\_CSF\_EN at a rate that exceeded the maximum lookup rate.

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- The port has no receive priorities enabled for cut-thru, and
- the maximum ALE lookup rate was exceeded so the lookup was aborted and the packet was dropped.

##### **Ethernet Ports (cut-thru mode)**

The total number of received frames on a port that were dropped due to packet errors. This statistic does not count error frames that are sent to the host with a set CPSW\_PN\_MAC\_CONTROL\_REG\_k[22] RX\_CEF\_EN or CPSW\_PN\_MAC\_CONTROL\_REG\_k[24] RX\_CMF\_EN.

- was any data or MAC control frame, and
- the port has at least one receive priority enabled for cut thru, and
- the received packet was long, mac\_control, code, align, crc error, and
- was dropped on receive (not transferred to the host due to error enable bits).

#### **12.3.1.4.6.18.1.14 Rx Octets (Offset = 3A030h)**

##### **All ports**

The total number of bytes in all good frames received on the port. A good frame is defined to be:

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Of length 64 to RX\_MAXLEN bytes inclusive
- Had no CRC error, alignment error or code error

See the [Section 12.3.1.4.6.18.1.6, Rx Align/Code Errors](#) and [Section 12.3.1.4.6.18.1.5, Rx CRC errors](#) statistic descriptions for definitions of alignment, code and CRC errors.

Overruns have no effect upon this statistic.

**12.3.1.4.6.18.1.15 Rx Bottom of FIFO Drop (Offset = 3A084h)****Ethernet port N where N = 1 to 2**

The total number of frames received on a port that overran the port's receive FIFO and were dropped (bottom of receive FIFO). Port 0 (CPPI receive port) should not drop packets on receive because port 0 receive flow control should be enabled. The Ethernet ports will only drop packets in the receive FIFO when receive flow control is enabled and the sending port ignores sent pause frame and then overruns the receive FIFO. An overrun frame is defined to be:

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- Was dropped on port 0 due to a lack of memory space in the receive FIFO.

---

**Note**

This statistic should be zero if proper flow control is being followed.

---

**Host port 0**

This statistic also counts frames dropped on port 0 that were 17 to 63 bytes (only for port 0). For Ethernet ports, the drop count for frames shorter than 33 bytes is included in the undersized or fragment count. Port 0 simply gives an indication that a packet was dropped. No other statistics are counted for frames shorter than 33 bytes.

**12.3.1.4.6.18.1.16 Portmask Drop (Offset = 3A088h)****All ports**

The total number of frames received on a port that were dropped by the ALE (the ALE did not forward the packet to any port). Port mask drop frame is defined to be:

- Any data or MAC control frame
- Any length greater than 32 bytes
- Was dropped by the ALE due to PORT\_MASK=0 (was not sent to any destination port)
- Was not a long or error packet with the port in cut-thru mode
- The frame could have been dropped due to error or other counted reason, so it could be counted elsewhere also.

---

**Note**

This statistic does not count in the overall total as it includes every packet received greater than 32 bytes that had a zero PORT\_MASK.

---

**12.3.1.4.6.18.1.17 Rx Top of FIFO Drop (Offset = 3A08Ch)****All ports**

The total number of frames received on a port that had a start-of-frame (SOF) overrun on any destination port egress (when attempting to load the packet from the top of the ingress port receive FIFO into any other port's transmit FIFO). If a multicast/broadcast packet is dropped by multiple destination ports then this statistic will increment by the number of ports that dropped the packet. Rx Top Of FIFO Drop is defined to be:

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- had no CRC error, alignment error or code error
- had a SOF of frame overrun on another port egress.

#### **12.3.1.4.6.18.1.18 ALE Rate Limit Drop (Offset = 3A090h)**

##### **All ports**

The total number of frames received on a port that were dropped (zero PORT\_MASK) due to receive rate limiting on this port or due to transmit rate limiting on any destination port (not sent to all expected destination ports if transmit rate limiting).

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- had no CRC error, alignment error, or code error
- the receive rate was exceeded and the packet was dropped, or the transmit rate was exceeded to any destination port and the packet was dropped to one or more expected destination ports (indicates that the destinations were reduced due to rate limiting).

#### **12.3.1.4.6.18.1.19 ALE VLAN Ingress Check Drop (Offset = 3A094h)**

##### **All ports**

The total number of frames received on a port that were dropped (zero PORT\_MASK) due to VLAN ingress check failure.

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- had no CRC error, alignment error, or code error
- the VLAN ID ingress check failed (the receive port was not in the group)
- The address lookup did not return a match with the SUPER bit set.

#### **12.3.1.4.6.18.1.19.1 ALE DA=SA Drop (Offset = 3A098h)**

##### **All ports**

The total number of frames received on a port that were dropped (zero PORT\_MASK) due to destination address equal to source address.

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- had no CRC error, alignment error, or code error
- the destination address was equal to the source address
- the source address was not an entry in the table.

#### **12.3.1.4.6.18.1.19.2 Block Address Drop (Offset = 3A09Ch)**

The total number of frames received on a port that were dropped (zero PORT\_MASK) due to the destination or source address being blocked.

- was any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode, and
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- had no CRC error, alignment error, or code error, and
- the source or destination address matched a table entry with the block bit set.

#### **12.3.1.4.6.18.1.19.3 ALE Secure Drop (Offset = 3A0A0h)**

The total number of frames received on a port that were dropped (zero port\_mask) due to a secure violation (the source address is owned by a different receive port).

- was any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode, and
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)

- had no CRC error, alignment error, or code error, and
- the source address is an entry in the table with the SECURE bit set and a port number for a different receive port.

#### **12.3.1.4.6.18.1.19.4 ALE Authentication Drop (Offset = 3A0A4h)**

The total number of frames received on a port that were dropped (zero port\_mask) due to authentication failure.

- was any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode, and
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)
- had no CRC error, alignment error, or code error, and
- CPSW\_ALE\_CONTROL[1] ENABLE\_AUTH\_MODE is set to 1h, and
- the source address is not equal to the destination address, and
- the source address is not a table entry, and
- the destination address is not a table entry with the SUPER bit set.

#### **12.3.1.4.6.18.1.19.5 ALE Unknown Unicast (Offset = 3A0A8h)**

##### **All ports**

The total number of frames received on a port that had a unicast destination address with an unknown source address.

- was any data frame with a unicast destination address
- the source address was not a table entry
- was of length 64 to RX\_MAXLEN bytes inclusive
- had no CRC error, alignment error, or code error

Note: The ALE Unknown Unicast Bytecount statistic is the number of bytes contained in the ALE Unknown Unicast frames.

#### **12.3.1.4.6.18.1.19.6 ALE Unknown Unicast Bytecount (Offset = 3A0ACh)**

The total number of bytes received on a port that had a unicast destination address with an unknown source address.

#### **12.3.1.4.6.18.1.19.7 ALE Unknown Multicast (Offset = 3A0B0h)**

The total number of frames received on a port that had a multicast destination address with an unknown source address. The frame is defined to be:

- was any data frame with a unicast destination address
- the source address was not a table entry, and
- was of length 64 to RX\_MAXLEN bytes inclusive
- had no CRC error, alignment error or code error

Note: The ALE Unknown Multicast Bytecount statistic is the number of bytes contained in the ALE Unknown Multicast frames.

#### **12.3.1.4.6.18.1.19.8 ALE Unknown Multicast Bytecount (Offset = 3A0B4h)**

The total number of bytes received on a port that had a multicast destination address with an unknown source address.

#### **12.3.1.4.6.18.1.19.9 ALE Unknown Broadcast (Offset = 3A0B8h)**

The total number of frames received on a port that had a broadcast destination address with an unknown source address. The frame is defined to be:

- was any data frame with a unicast destination address
- the source address was not a table entry, and
- was of length 64 to RX\_MAXLEN bytes inclusive
- had no CRC error, alignment error or code error

Note: The ALE Unknown Broadcast Bytecount statistic is the number of bytes contained in the ALE Unknown Broadcast frames.

#### **12.3.1.4.6.18.1.19.10 ALE Unknown Broadcast Bytecount (Offset = 3A0BCh)**

The total number of bytes received on a port that had a broadcast destination address with an unknown source address.

#### **12.3.1.4.6.18.1.19.11 ALE Policer/Classifier Match (Offset = 3A0C0h)**

##### **All ports**

The total number of frames received on a port that matched a policer. The frame is defined to be:

- was any data frame
- matched a condition on a policer,
- was of length 64 to RX\_MAXLEN bytes inclusive
- had no CRC error, alignment error, or code error

#### **12.3.1.4.6.18.2 ALE Policer Match Red (Offset = 3A0C4h)**

The total number of frames received on a port that had matched a policer and the condition was red. The frame is defined to be:

- was any data frame
- matched a condition on a policer,
- was of length 64 to RX\_MAXLEN bytes inclusive
- had no CRC error, alignment error, or code error

#### **12.3.1.4.6.18.3 ALE Policer Match Yellow (Offset = 3A0C8h)**

The total number of frames received on a port that had matched a policer and the condition was red. The frame is defined to be:

- was any data frame
- matched a condition on a policer,
- was of length 64 to RX\_MAXLEN bytes inclusive
- had no CRC error, alignment error, or code error

#### **12.3.1.4.6.18.4 IET Receive Assembly Error (Offset = 3A140h)**

The total number of preemptable received frames with IET assembly errors.

- any frame received
- was any size, and
- was a non-initial fragment that mismatched the frame count or fragment count (went to the assembly error state in the IET receive state machine)

#### **12.3.1.4.6.18.5 IET Receive Assembly OK (Offset = 3A144h)**

The total number of correctly received and re-assembled preemptable frames.

- any preemptable frame received
- was any size, and
- was correctly received and re-assembled without error

#### **12.3.1.4.6.18.6 IET Receive SMD Error (Offset = 3A148h)**

The total number of received frames rejected due to an unknown SMD value or received frames rejected with an SMD-C when no frame is in progress.

- any frame received
- was any size, and
- was rejected because of an unknown SMD value or SMD-C with no frame in progress.

Note: If IET\_ENABLE is not set, this statistic counts any received frame with any non express SMD.

#### **12.3.1.4.6.18.7 IET Receive Fragment Count (Offset = 3A14Ch)**

The total number of received non-initial fragments that did not have an assembly error. The IET stat CPSW\_STATN\_RXFRAGMENTS\_k is derived by adding the Receive Assembly Error count to this value.

- any frame received
- was any size, and
- was a non-initial fragment that did not contain an assembly error

#### **12.3.1.4.6.18.8 Rx Cut Thru with No Delay**

The total number of frames received on the port and subsequently sent cut-thru to all internal destination port FIFOs with no delay. Such a frame:

- was any data or MAC control frame destined for any unicast, broadcast or multicast address, and
- was any size greater than or equal to 128 bytes, and
- was sent cut-thru by the receive port to all destination ports without delay.

#### **12.3.1.4.6.18.9 Rx Cut Thru with Delay**

The total number of frames received on the port and subsequently sent cut-thru to all destination ports with some amount of delay. Such a frame:

- was any data or MAC control frame destined for any unicast, broadcast or multicast address, and
- was any size greater than or equal to 128 bytes, and
- was sent cut-thru by the receive port to all destination ports with some amount of delay.

#### **12.3.1.4.6.18.10 Rx Cut Thru Store-and-Forward**

The total number of frames received on the port were attempted to be sent cut-thru to all destination ports but were held off due to configuration or traffic conditions. Such a frame:

- was any data or MAC control frame destined for any unicast, broadcast or multicast address, and
- was any size greater than or equal to 128 bytes, and
- was attempted to be sent cut-thru by the receive port to all destination ports but was sent store-and-forward.

#### **12.3.1.4.6.18.11 Tx-only Statistics Descriptions**

The maximum and minimum transmit frame size is software controllable.

##### **12.3.1.4.6.18.11.1 Good Tx Frames (Offset = 3A034h)**

###### **All ports**

The total number of good frames received on the port. A good frame is defined to be:

- Any data or MAC control frame which matched a unicast, broadcast or multicast address, or matched due to promiscuous mode
- Any length
- Had no late or excessive collisions, no carrier loss and no underrun

---

###### **Note**

A nonzero CPSW\_STATN\_TXDEFERREDFRAMES\_k value should be subtracted from this value to obtain the actual good frames value (the good frames statistic also increments on a transmitted CRC error).

---

##### **12.3.1.4.6.18.11.2 Broadcast Tx Frames (Offset = 3A038h)**

###### **All ports**

The total number of good broadcast frames transmitted on the port. A good broadcast frame is defined to be:

- Any data or MAC control frame which was destined for only address FF.FF.FF.FF.FF.FF

- Any length
- Had no late or excessive collisions, no carrier loss and no underrun

**12.3.1.4.6.18.11.3 Multicast Tx Frames (Offset = 3A03Ch)****All ports**

The total number of good multicast frames transmitted on the port. A good multicast frame is defined to be:

- Any data or MAC control frame which was destined for any multicast address other than FF.FF.FF.FF.FF.FF
- Any length
- Had no late or excessive collisions, no carrier loss and no underrun

**12.3.1.4.6.18.11.4 Pause Tx Frames (Offset = 3A040h)****Ethernet port N where N = 1 to 2**

This statistic indicates the number of IEEE 802.3X pause frames transmitted by the port.

Pause frames cannot contain a CRC error because they are created in the transmitting MAC, so these error conditions have no effect upon the statistic. Pause frames sent by software will not be included in this count.

Since pause frames are only transmitted in full duplex, carrier loss and collisions have no effect upon this statistic.

Transmitted pause frames are always 64-byte multicast frames so will appear in the *Tx Multicast Frames* and *64octet Frames* statistics.

**12.3.1.4.6.18.11.5 Deferred Tx Frames (Offset = 3A044h)****Ethernet port N where N = 1 to 2**

The total number of frames transmitted on the port that first experienced deferment. Such a frame:

- Was any data or MAC control frame destined for any unicast, broadcast or multicast address
- Was any size
- Had no carrier loss and no underrun
- Experienced no collisions before being successfully transmitted
- Found the medium busy when transmission was first attempted, so had to wait.

CRC errors have no effect upon this statistic.

**12.3.1.4.6.18.11.6 Collisions (Offset = 3A048h)****Ethernet port N where N = 1 to 2**

This statistic records the total number of times that the port experienced a collision. Collisions occur under two circumstances.

1. When a transmit data or MAC control frame:

- Was destined for any unicast, broadcast or multicast address
- Was any size
- Had no carrier loss and no underrun
- Experienced a collision. A jam sequence is sent for every non-late collision, so this statistic will increment on each occasion if a frame experiences multiple collisions (and increments on late collisions)

CRC errors have no effect upon this statistic.

2. When the port is in half-duplex mode, flow control is active, and a frame reception begins.

**12.3.1.4.6.18.11.7 Single Collision Tx Frames (Offset = 3A04Ch)****Ethernet port N where N = 1 to 2**

The total number of frames transmitted on the port that experienced exactly one collision. Such a frame:

- Was any data or MAC control frame destined for any unicast, broadcast or multicast address
- Was any size

- Had no carrier loss and no underrun
- Experienced one collision before successful transmission. The collision was not late.

CRC errors have no effect upon this statistic.

#### **12.3.1.4.6.18.11.8 Multiple Collision Tx Frames (Offset = 3A050h)**

##### **Ethernet port N where N = 1 to 2**

The total number of frames transmitted on the port that experienced multiple collisions. Such a frame:

- Was any data or MAC control frame destined for any unicast, broadcast or multicast address
- Was any size
- Had no carrier loss and no underrun
- Experienced 2 to 15 collisions before being successfully transmitted. None of the collisions were late.

CRC errors have no effect upon this statistic.

#### **12.3.1.4.6.18.11.9 Excessive Collisions (Offset = 3A054h)**

##### **Ethernet port N where N = 1 to 2**

The total number of frames for which transmission was abandoned due to excessive collisions. Such a frame:

- Was any data or MAC control frame destined for any unicast, broadcast or multicast address
- Was any size
- Had no carrier loss and no underrun
- Experienced 16 collisions before abandoning all attempts at transmitting the frame. None of the collisions were late.

CRC errors have no effect upon this statistic.

#### **12.3.1.4.6.18.11.10 Late Collisions (Offset = 3A058h)**

##### **Ethernet port N where N = 1 to 2**

The total number of frames on the port for which transmission was abandoned because they experienced a late collision. Such a frame:

- Was any data or MAC control frame destined for any unicast, broadcast or multicast address
- Was any size
- Experienced a collision later than 512 bit-times into the transmission. There may have been up to 15 previous (non-late) collisions which had previously required the transmission to be re-attempted. The *Late Collisions* statistic dominates over the single-, multiple-, and excessive- collision statistics. If a late collision occurs, the frame will not be counted in any of these other three statistics.

CRC errors have no effect upon this statistic.

#### **12.3.1.4.6.18.11.11 Carrier Sense Errors (Offset = 3A060h)**

##### **Ethernet port N where N = 1 to 2**

The total number of frames on the port that experienced carrier loss. Such a frame:

- Was any data or MAC control frame destined for any unicast, broadcast or multicast address
- Was any size
- The carrier sense condition was lost or never asserted when transmitting the frame (the frame is not retransmitted). This is a transmit only statistic. Carrier Sense is a don't care for received frames. Transmit frames with carrier sense errors are sent until completion and are not aborted.

CRC errors have no effect upon this statistic.

#### **12.3.1.4.6.18.11.12 Tx Octets (Offset = 3A064h)**

##### **All ports**

The total number of bytes in all good frames transmitted on the port. A good frame is defined to be:

- Any data or MAC control frame which was destined for any unicast, broadcast or multicast address
- Was any size
- Had no late or excessive collisions, no carrier loss and no underrun.

#### **12.3.1.4.6.18.11.13 Transmit Priority 0-7 (Offset = 3A180h to 3A1A8h)**

The total number of frames transmitted on the port from transmit FIFO priority 0-7. Collision retries do not affect this statistic. Pause frames do not affect this statistic.

- Any frame transmitted from priority 0-7, and
- Was less than or equal to CPSW\_TX\_PRI0\_MAXLEN\_REG to CPSW\_TX\_PRI7\_MAXLEN\_REG
- Collision retries are not counted in this statistic.
- Pause frames are not counted in this statistic.
- Carrier sense errors do not affect this statistic.

Note: The Transmit Priority 0-7 Bytecount statistic is the number of bytes contained in the frames of the Transmit Priority 0-7 statistic.

#### **12.3.1.4.6.18.11.14 Transmit Priority 0-7 Drop (Offset = 3A1C0h to 3A1E8)**

The total number of transmit frames on the port that overran the transmit FIFO priority 0-7 and were dropped. This count includes frames dropped due to CPSW\_TX\_PRI0\_MAXLEN\_REG to CPSW\_TX\_PRI7\_MAXLEN\_REG.

- Any frame destined to be transmitted from priority 0-7, and
- Was any size, and
- Was dropped due to priority 0-7 FIFO overrun (Start of packet overrun).
- Was dropped due to frame size larger than CPSW\_TX\_PRI0\_MAXLEN\_REG to CPSW\_TX\_PRI7\_MAXLEN\_REG.

Note: The Transmit Priority 0-7 Drop Bytecount statistic is the number of bytes contained in the frames of the Transmit Priority 0-7 Drop statistic.

#### **12.3.1.4.6.18.11.15 Tx Memory Protect Errors (Offset = 3A17Ch)**

##### **All ports**

The total number of transmit frames on the port that had a memory protect CRC error on egress:

- Any frame destined to be transmitted,
- Was any size
- Had a memory protect CRC error on egress.

---

##### **Note**

1. Frames to the host with memory protect errors are dropped via TXST\_DROP. Ethernet frames will have at least one byte of the generated port type CRC inverted on egress.
  2. This statistic is 8-bits wide only and will not rollover but will limit at 0xFF.
  3. A non-zero value in this statistic will issue a STAT\_PEND0 interrupt for the associated port.
- 

#### **12.3.1.4.6.18.11.16 IET Transmit Merge Hold Count (Offset = 3A150h)**

The total number of preemptable frames that were preempted and reassembled by the assertion of MAC\_HOLD in the CPSW\_PN\_IET\_CONTROL\_REG\_k register or were preempted by Enhanced Scheduled Traffic (EST). The IET statistic can be derived and maintained by software.

- Any frame destined to be transmitted on the preemptable port, and
- was any size, and
- was preempted by the assertion of MAC\_HOLD.
- was preempted by Enhanced Scheduled Traffic (EST).

#### **12.3.1.4.6.18.11.17 IET Transmit Merge Fragment Count (Offset = 3A14Ch)**

The total number of non-initial preemptable transmit fragments on preemptable transmit.

- Any frame destined to be transmitted on the preemptable port, and
- Was any size, and
- was a non-initial fragment.

#### **12.3.1.4.6.18.11.18 Tx CRC Errors**

The total number of frames transmitted on the port with a CRC error. Such a frame:

- was any data frame destined for any unicast, broadcast or multicast address, and
- was any size, and
- was sent cut-thru by the receive port and was received with a CRC error, or
- was a transmitted frame that also had a memory protect error (counted also in CPSW\_STATN\_TX\_MEMORY\_PROTECT\_ERROR\_k).

---

#### **Note**

For port0 this statistics location (CPSW\_STAT0\_TXDROP) counts the number of drops to the host due to a memory protect error, or due to a cut-thru packet having an error on reception but was forwarded with the error. The Ethernet port receive error could be long, CRC, jabber, or code. For Ethernet ports, the receive error could be the same but the packet is transmitted with at least one byte of the actual outgoing packet CRC inverted to indicate the error.

---

#### **Note**

A nonzero CPSW\_STATN\_TXDEFERREDFRAMES\_k value should be subtracted from the CPSW\_STATN\_TXGOODFRAMES\_k value to obtain the actual good frames value (the good frames statistic also increments on a transmitted CRC error).

---

#### **12.3.1.4.6.18.11.19 Tx Cut Thru**

The total number of cut-thru frames transmitted on the port with or without delay. Such a frame:

- was any data frame destined for any unicast, broadcast or multicast address, and
- was any size greater than or equal to 128 bytes, and
- was sent cut-thru by the receive port.
- was transmitted cut-thru with or without delay.

#### **12.3.1.4.6.18.11.20 Tx Cut Thru Store-and-Forward**

The total number of cut-thru frames transmitted store and forward. Such a frame:

- was any data frame destined for any unicast, broadcast or multicast address, and
- was any size greater than or equal to 128 bytes, and
- was sent cut-thru by the receive port.
- was transmitted store-and-forward due to traffic congestion.

#### **12.3.1.4.6.18.12 Rx- and Tx (Shared) Statistics Descriptions**

#### **12.3.1.4.6.18.12.1 Rx + Tx 64 Octet Frames (Offset = 3A068h)**

##### **All ports**

The total number of 64-byte frames received and transmitted on the port. Such a frame is defined to be:

- Any data or MAC control frame which was destined for any unicast, broadcast or multicast address
- Did not experience late collisions, excessive collisions, or carrier sense error
- Was exactly 64 bytes long. (If the frame was being transmitted and experienced carrier loss that resulted in a frame of this size being transmitted, then the frame will be recorded in this statistic).

CRC errors, code/align errors and overruns do not affect the recording of frames in this statistic.

#### **12.3.1.4.6.18.12.2 Rx + Tx 65–127 Octet Frames (Offset = 3A06Ch)**

##### **All ports**

The total number of frames of size 65 to 127 bytes received and transmitted on the port. Such a frame is defined to be:

- Any data or MAC control frame which was destined for any unicast, broadcast or multicast address
- Did not experience late collisions, excessive collisions, or carrier sense error
- Was 65 to 127 bytes long

CRC errors, code/align errors, underruns and overruns do not affect the recording of frames in this statistic.

#### **12.3.1.4.6.18.12.3 Rx + Tx 128–255 Octet Frames (Offset = 3A070h)**

##### **All ports**

The total number of frames of size 128 to 255 bytes received and transmitted on the port. Such a frame is defined to be:

- Any data or MAC control frame which was destined for any unicast, broadcast or multicast address
- Did not experience late collisions, excessive collisions, or carrier sense error
- Was 128 to 255 bytes long

CRC errors, code/align errors, underruns and overruns do not affect the recording of frames in this statistic.

#### **12.3.1.4.6.18.12.4 Rx + Tx 256–511 Octet Frames (Offset = 3A074h)**

##### **All ports**

The total number of frames of size 256 to 511 bytes received and transmitted on the port. Such a frame is defined to be:

- Any data or MAC control frame which was destined for any unicast, broadcast or multicast address
- Did not experience late collisions, excessive collisions, or carrier sense error
- Was 256 to 511 bytes long

CRC errors, code/align errors, underruns and overruns do not affect the recording of frames in this statistic.

#### **12.3.1.4.6.18.12.5 Rx + Tx 512–1023 Octet Frames (Offset = 3A078h)**

##### **All ports**

The total number of frames of size 512 to 1023 bytes received and transmitted on the port. Such a frame is defined to be:

- Any data or MAC control frame which was destined for any unicast, broadcast or multicast address
- Did not experience late collisions, excessive collisions, or carrier sense error
- Was 512 to 1023 bytes long

CRC errors, code/align errors, underruns and overruns do not affect the recording of frames in this statistic.

#### **12.3.1.4.6.18.12.6 Rx + Tx 1024\_Up Octet Frames (Offset = 3A07Ch)**

##### **All ports**

The total number of frames of size 1024 to RX\_MAXLEN bytes for receive or 1024 up for transmit on the port. Such a frame is defined to be:

- Any data or MAC control frame which was destined for any unicast, broadcast or multicast address
- Did not experience late collisions, excessive collisions, or carrier sense error
- Was 1024 to RX\_MAXLEN bytes long on receive, or any size on transmit

CRC errors, code/align errors, underruns and overruns do not affect the recording of frames in this statistic.

### 12.3.1.4.6.18.12.7 Net Octets (Offset = 3A080h)

#### All ports

The total number of bytes of frame data received and transmitted on the port. Each frame counted:

- was any data or MAC control frame destined for any unicast, broadcast or multicast address (address match does not matter)
- Any length (including less than 64 bytes and greater than RX\_MAXLEN bytes)

Also counted in this statistic is:

- Every byte transmitted before a carrier-loss was experienced
- Every byte transmitted before each collision was experienced, (that is, multiple retries are counted each time)
- Every byte received if the port is in half-duplex mode until a jam sequence was transmitted to initiate flow control. (The jam sequence was not counted to prevent double-counting)

Error conditions such as alignment errors, CRC errors, code errors, overruns and underruns do not affect the recording of bytes by this statistic.

The objective of this statistic is to give a reasonable indication of Ethernet utilization.

#### 12.3.1.4.6.18.13

**Table 12-166. Rx Statistics Summary**

| Rx Statistic               |                   |                          | Frame Type         |                                  |                     |               |             | Frame Size (bytes)                         |     |                  |      |            |   |   |   | Event                    |                  |                        |             |                   |   |
|----------------------------|-------------------|--------------------------|--------------------|----------------------------------|---------------------|---------------|-------------|--------------------------------------------|-----|------------------|------|------------|---|---|---|--------------------------|------------------|------------------------|-------------|-------------------|---|
|                            | Fra<br>me/<br>Oct | Rx/<br>Tx                | MAC<br>control     |                                  | Data <sup>(5)</sup> |               |             | <64 64 65-1 128- 256- 512- 1024 >rx_maxlen |     |                  |      |            |   |   |   | Flo<br>w<br>Coll.<br>(8) | CRC<br>Erro<br>r | Alig<br>n/<br>Cod<br>e | Ove<br>rrun | Add<br>r.<br>Disc |   |
|                            |                   |                          | Pause<br>fram<br>e | Non<br>-pau<br>se <sup>(4)</sup> | Multi<br>cast       | Broad<br>cast | Uni<br>cast | 27                                         | 255 | 511              | 1023 | -rx_maxlen |   |   |   |                          |                  |                        |             |                   |   |
| Good Rx Frames             | F                 | Rx                       | (y  <sup>(1)</sup> | y                                | y                   | y             | y           | n                                          | (y  | y                | y    | y          | y | y | y | n                        | - <sup>(2)</sup> | n                      | n           | -                 | n |
| Broadcast Rx Frames        | F                 | Rx                       | (%  <sup>(6)</sup> | %                                | n                   | y             | n           | n                                          | (y  | y                | y    | y          | y | y | y | n                        | -                | n                      | n           | -                 | n |
| Multicast Rx Frames        | F                 | Rx                       | (%                 | %                                | y                   | n             | n           | n                                          | (y  | y                | y    | y          | y | y | y | n                        | -                | n                      | n           | -                 | n |
| Pause Rx Frames            | F                 | Rx                       | y                  | n                                | n                   | n             | n           | n                                          | (y  | y                | y    | y          | y | y | y | n                        | -                | n                      | n           | -                 | - |
| Rx CRC Errors              | F                 | Rx                       | (y                 | y                                | y                   | y             | y           | n                                          | (y  | y                | y    | y          | y | y | y | n                        | -                | y                      | n           | -                 | n |
| Rx Align/Code Errors       | F                 | Rx                       | (y                 | y                                | y                   | y             | y           | n                                          | (y  | y                | y    | y          | y | y | y | n                        | -                | -                      | y           | -                 | n |
| Oversized Rx Frames        | F                 | Rx                       | (y                 | y                                | y                   | y             | y           | n                                          | n   | n                | n    | n          | n | n | n | y                        | -                | n                      | n           | -                 | n |
| Rx Jabbers                 | F                 | Rx                       | (y                 | y                                | y                   | y             | y           | n                                          | n   | n                | n    | n          | n | n | n | y                        | -                | (y                     | y)          | -                 | n |
| Undersized Rx Frames       | F                 | Rx                       | n                  | n                                | (y                  | y             | y           | y                                          | y   | y                | n    | n          | n | n | n | n                        | -                | n                      | n           | -                 | n |
| Rx Fragments               | F                 | Rx                       | n                  | n                                | (y                  | y             | y           | y                                          | y   | y <sup>(7)</sup> | n    | n          | n | n | n | n                        | -                | (y                     | y)          | -                 | - |
| Rx Overruns <sup>(9)</sup> | F                 | Rx                       | (y                 | y                                | y                   | y             | y           | y                                          | (y  | y                | y    | y          | y | y | y | y                        | -                | -                      | -           | y                 | n |
| 64octet Frames             | F                 | Rx+<br>Tx <sup>(3)</sup> | (y                 | y                                | y                   | y             | y           | y                                          | n   | y                | n    | n          | n | n | n | n                        | -                | -                      | -           | -                 | n |
| 65-127octet Frames         | F                 | Rx+<br>Tx                | (y                 | y                                | y                   | y             | y           | y                                          | n   | n                | y    | n          | n | n | n | n                        | -                | -                      | -           | -                 | n |
| 128-255octet Frames        | F                 | Rx+<br>Tx                | (y                 | y                                | y                   | y             | y           | y                                          | n   | n                | n    | y          | n | n | n | n                        | -                | -                      | -           | -                 | n |

**Table 12-166. Rx Statistics Summary (continued)**

| Rx Statistic            |                   |           | Frame Type                        |                                       |                                   |                                   | Frame Size (bytes)                |                                   |                                   |                                   |                                   |                                   |                                   | Event                             |                                   |              |                      |              |                      |
|-------------------------|-------------------|-----------|-----------------------------------|---------------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|--------------|----------------------|--------------|----------------------|
|                         | Fra<br>me/<br>Oct | Rx/<br>Tx | MAC<br>control                    |                                       | Data <sup>(5)</sup>               |                                   |                                   |                                   | Frame Size (bytes)                |                                   |                                   |                                   |                                   |                                   |                                   | Event        |                      |              |                      |
|                         |                   |           | Pause<br>frame                    | Non-<br>pause<br>frame <sup>(4)</sup> | Multi-<br>cast                    | Broad-<br>cast                    | Uni-<br>cast                      | <64                               | 64                                | 65-<br>27                         | 128-<br>255                       | 256-<br>511                       | 512-<br>1023                      | >rx_<br>max<br>len                | Flow<br>Coll.<br>(8)              | CRC<br>Error | Align/<br>n/<br>Code | Ove-<br>rrun | Add-<br>r./<br>Disc. |
| 256-511octet<br>Frames  | F                 | Rx+<br>Tx | (y <br>y <br>y <br>y <br>y <br>y) | n                                     | n                                 | n                                 | n                                 | y                                 | n                                 | n                                 | n                                 | n                                 | n                                 | -                                 | -                                 | -            | -                    | n            |                      |
| 512-1023octet<br>Frames | F                 | Rx+<br>Tx | (y <br>y <br>y <br>y <br>y <br>y) | n                                     | n                                 | n                                 | n                                 | n                                 | y                                 | n                                 | n                                 | n                                 | n                                 | -                                 | -                                 | -            | -                    | n            |                      |
| 1024-UPoctet<br>Frames  | F                 | Rx+<br>Tx | (y <br>y <br>y <br>y <br>y <br>y) | n                                     | n                                 | n                                 | n                                 | n                                 | n                                 | n                                 | y                                 | n                                 | -                                 | -                                 | -                                 | -            | -                    | n            |                      |
| Rx Octets               | O                 | Rx        | (y <br>y <br>y <br>y <br>y <br>y) | n                                     | (y <br>y <br>y <br>y <br>y <br>y) | n                                 | (y <br>y <br>y <br>y <br>y <br>y) | n                                 | -                                 | n                                 | n                                 | n                                 | n                                 | -                                 | n                                 | n            | -                    | n            |                      |
| Net Octets              | O                 | Rx+<br>Tx | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y)     | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | (y <br>y <br>y <br>y <br>y <br>y) | -            | -                    | -            | -                    |

- (1) "AND" is assumed horizontally across the table between all conditions which form the statistic (marked y or n) except where (y|y), meaning "OR" is indicated. Parentheses are significant.
- (2) "-" indicates conditions which are ignored in the formations of the statistic.
- (3) Statistics marked "Rx+Tx" are formed by summing the Rx and Tx statistics, each of which is formed independently.
- (4) The non-pause column refers to all MAC control frames (for example, frames with length/type=88.08) with opcodes other than 0x0001. The pauseframe column refers to MAC frames with the opcode=0x0001.
- (5) The multicast, broadcast and unicast columns in the table refer to non-MAC Control/non-pause frames (i.e. data frames).
- (6) "%" If either a MAC control frame or pause frame has a multicast or broadcast destination address then the appropriate statistics will be updated.
- (7) "y^" Frame fragments are not counted if less than 8 bytes.
- (8) Flow coll. are half-duplex collisions forced by the MAC to achieve flow-control. A collision will be forced during the first 8 bytes so should not show in frame fragments. Some of the '-'s in this column might in reality be 'n's.
- (9) The rx\_overruns stat is for RX\_MOF\_OVERRUNS and RX\_SOF\_OVERRUNS added together.

**Table 12-167. Tx Statistics Summary**

| Tx<br>Statistic <sup>(9)</sup>     |                   |           | Frame Type                        |                                   |                                   |                                   | Frame Size (bytes)                |                                   |                                   |                                   |                                   |                                   |                                   | Event                             |                                   |                      |           |                   |           |            |                  |   |   |   |
|------------------------------------|-------------------|-----------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|----------------------|-----------|-------------------|-----------|------------|------------------|---|---|---|
|                                    | Fra<br>me/<br>Oct | Tx/<br>Rx | MAC<br>control <sup>(4)</sup>     |                                   | Data                              |                                   |                                   |                                   | Frame Size (bytes)                |                                   |                                   |                                   |                                   |                                   |                                   | Event                |           |                   |           |            |                  |   |   |   |
|                                    |                   |           | Pause<br>frame                    | AN<br>se-<br>MA<br>C<br>U         | Multi-<br>cast                    | Broad-<br>cast                    | Uni-<br>cast                      | 64                                | 65-<br>127                        | 128-<br>-25                       | 256-<br>-51                       | 512-<br>-10                       | 102-<br>-4-1                      | >15                               | CR<br>C<br>Err<br>or              | Flow<br>Coll.<br>(8) | Lat-<br>e | No<br>Car<br>rier | Qu<br>eue | Def<br>err | Un<br>der<br>run |   |   |   |
| Good Tx<br>Frames                  | F                 | Tx        | (y <br>y <br>y <br>y <br>y <br>y) | -                    | -         | -                 | n         | n          | n                | - | - | n |
| Broadcast<br>Tx Frames             | F                 | Tx        | n                                 | (% <br>5)                         | n                                 | y                                 | n                                 | (y <br>y <br>y <br>y <br>y <br>y) | -                                 | -                    | -         | n                 | n         | n          | -                | - | n |   |
| Multicast Tx<br>Frames             | F                 | Tx        | (y <br>y <br>y <br>y <br>y <br>y) | (% <br>y)                         | n                                 | n                                 | n                                 | (y <br>y <br>y <br>y <br>y <br>y) | -                                 | -                    | -         | n                 | n         | n          | -                | - | n |   |
| Pause Tx<br>Frames                 | F                 | Tx        | y                                 | n                                 | n                                 | n                                 | n                                 | y                                 | n                                 | n                                 | n                                 | n                                 | n                                 | n                                 | -                                 | -                    | -         | -                 | -         | -          | -                | - | - | - |
| Collisions                         | F                 | Tx        | n                                 | (y <br>y <br>y <br>y <br>y <br>y) | -                                 | (+<br>6)             | +         | +                 | +         | +          | n                | - | - | - |
| Single<br>Collision Tx<br>Frames   | F                 | Tx        | n                                 | (y <br>y <br>y <br>y <br>y <br>y) | -                                 | -                    | y         | n                 | n         | n          | n                | - | - | - |
| Multiple<br>Collision Tx<br>Frames | F                 | Tx        | n                                 | (y <br>y <br>y <br>y <br>y <br>y) | -                                 | -                    | n         | y                 | n         | n          | n                | - | - | - |
| Excessive<br>Collisions            | F                 | Tx        | n                                 | (y <br>y <br>y <br>y <br>y <br>y) | -                                 | -                                 | n                    | n         | y                 | n         | n          | -                | - | - |   |

**Table 12-167. Tx Statistics Summary (continued)**

| Tx<br>Statistic <sup>(9)</sup> | Frame Type       |                       |                       |                     | Frame Size (bytes)    |                       |                 |    |            |     |     |     |     |     | Event                |                         |   |                   |    |          |                   |           |            |                  |   |
|--------------------------------|------------------|-----------------------|-----------------------|---------------------|-----------------------|-----------------------|-----------------|----|------------|-----|-----|-----|-----|-----|----------------------|-------------------------|---|-------------------|----|----------|-------------------|-----------|------------|------------------|---|
|                                | Fra<br>me/<br>Rx | MAC<br>control<br>(4) |                       |                     | Data                  |                       |                 |    |            |     |     |     |     |     | Collision Type       |                         |   |                   |    |          |                   |           |            |                  |   |
|                                |                  | Oct<br>+Tx            | Pau<br>se-<br>MA<br>C | An<br>y-<br>CP<br>U | Mul<br>ti<br>cas<br>t | Bro<br>ad<br>cas<br>t | Uni<br>cas<br>t | 64 | 65-<br>127 | 128 | 256 | 512 | 102 | >15 | CR<br>C<br>Err<br>or | Flo<br>w <sup>(8)</sup> | 1 | 2-1<br>5          | 16 | Lat<br>e | No<br>Car<br>rier | Qu<br>eue | Def<br>err | Un<br>der<br>run |   |
| Late Collisions                | F                | Tx                    | n                     | (y)                 | y                     | y                     | y               | y  | n          | (y) | y   | y   | y   | y   | y                    | -                       | - | -                 | -  | -        | y                 | -         | -          | -                |   |
| Deferred Tx Frames             | F                | Tx                    | n                     | (y)                 | y                     | y                     | y               | y  | (y)        | y   | y   | y   | y   | y   | y                    | -                       | - | n                 | n  | n        | n                 | n         | -          | y                | n |
| Carrier Sense Errors           | F                | Tx                    | (y)                   | y                   | y                     | y                     | y               | y  | (y)        | y   | y   | y   | y   | y   | y                    | -                       | - | -                 | -  | -        | -                 | y         | -          | -                | - |
| 64octet Frames                 | F                | Rx+<br>Tx<br>(3)      | (y)                   | y                   | y                     | y                     | y               | y  | y          | n   | n   | n   | n   | n   | n                    | -                       | - | -                 | n  | n        | n                 | -         | -          | -                | - |
| 65-127octet Frames             | F                | Rx+<br>Tx             | (y)                   | y                   | y                     | y                     | y               | y  | n          | y   | n   | n   | n   | n   | n                    | -                       | - | -                 | n  | n        | n                 | -         | -          | -                | - |
| 128-255octet Frames            | F                | Rx+<br>Tx             | (y)                   | y                   | y                     | y                     | y               | y  | n          | n   | y   | n   | n   | n   | n                    | -                       | - | -                 | n  | n        | n                 | -         | -          | -                | - |
| 256-511octet Frames            | F                | Rx+<br>Tx             | (y)                   | y                   | y                     | y                     | y               | y  | n          | n   | n   | y   | n   | n   | n                    | -                       | - | -                 | n  | n        | n                 | -         | -          | -                | - |
| 512-1023octet Frames           | F                | Rx+<br>Tx             | (y)                   | y                   | y                     | y                     | y               | y  | n          | n   | n   | n   | y   | n   | n                    | -                       | - | -                 | n  | n        | n                 | -         | -          | -                | - |
| 1024-UPoctet Frames            | F                | Rx+<br>Tx             | (y)                   | y                   | y                     | y                     | y               | y  | n          | n   | n   | n   | n   | y   | y                    | -                       | - | -                 | n  | n        | n                 | -         | -          | -                | - |
| Tx Octets                      | O                | Tx                    | (y)                   | y                   | y                     | y                     | y               | y  | (y)        | y   | y   | y   | y   | y   | y                    | -                       | - | -                 | n  | n        | n                 | -         | -          | n                |   |
| Net Octets                     | O                | Rx+<br>Tx             | (y)                   | y                   | y                     | y                     | y               | y  | (y)        | y   | y   | y   | y   | y   | y                    | -                       | - | \$ <sup>(7)</sup> | \$ | \$       | \$                | \$        | -          | -                | - |

(1) "AND" is assumed horizontally across the table between all conditions which form the statistic (marked y or n) except where (y|y), meaning "OR" is indicated. Parentheses are significant.

(2) "-" indicates conditions which are ignored in the formations of the statistic.

(3) Statistics marked "Rx+Tx" are formed by summing the Rx and Tx statistics, each of which is formed independently.

(4) Pause (MAC) frames are issued in the MAC as perfect (no CRC error) 64 byte frames in full duplex only, so they cannot collide.

(5) "%" If a CPU sourced MAC control frame has a multicast or broadcast destination address then the appropriate statistics will be updated.

(6) "+" indicates collisions which are "summed" (i.e. every collision is counted in the Collisions statistic). Jam sequences used for halfduplex flow control are also counted.

(7) "\$" Every byte written on the wire during each retry attempt is also counted in addition to frames which experience no collisions or carrier loss.

(8) The flow collision type is for half-duplex collisions forced by the MAC to achieve flow control. Some of the '-'s in this column might in reality be 'n's. To prevent double-counting, Net Octets are unaffected by the jam sequence – the 'received' bytes, however, are counted. (See Table 12-166.)

(9) When the transmit Tx FIFO is drained due to the MAC being disabled or link being lost, then the frames being purged will not appear in the Tx statistics.

#### 12.3.1.4.7 Common Platform Time Sync (CPTS)

The Common Platform Time Sync (CPTS) module is used to facilitate host control of time sync operations. It enables compliance with the IEEE 1588-2008 standard for a precision clock synchronization protocol.

Main features of CPTS module are:

- Supports the selection of multiple external clock sources

- Software control of time sync events via interrupt or polling
- Supports up to 8 hardware timestamp push inputs
- Supports timestamp counter compare output (CPTS\_COMP)
- Supports timestamp counter bit output (CPTS\_SYNC)
- Supports a configurable number of timestamp Generator bit outputs (CPTS\_GENFn).
- Supports Ethernet Enhanced Scheduled Traffic Operations (CPTS\_ESTFn).
- 32-bit and 64-bit timestamp modes with PPM and nudge adjustment.

#### 12.3.1.4.7.1 CPSW0 CPTS Integration

This section describes CPTS module integration in the CPSW0 module, including information about clocks, resets, and hardware requests.

Figure 12-136 shows CPTS integration in the device CPSW0 module.



**Figure 12-136. CPSW0 CPTS Integration**

CPTS IEEE 1588 clock (RCLK) is selected through the CTRLMMR\_CPTS\_CLKSEL register.

**Note**

For more information about CPTS clocks and resets, see *CPWS0 Clocks in CPSW0 Integration*.

#### 12.3.1.4.7.2 CPTS Architecture

Figure 12-137 shows the architecture of the CPTS module inside the CPSW Ethernet Subsystem. Time stamp values for every packet transmitted or received on external port of the CPSW are recorded. At the same time, each packet is decoded to determine if it is a valid time sync event. If so, an event is loaded into the Event FIFO for processing containing the recorded time stamp value when the packet was transmitted or received.

In addition, both hardware (HWn\_TS\_PUSH) and software (TS\_PUSH) can be used to read the current time stamp value though the Event FIFO. The reference clock used for the time stamp (CPTS\_RFT\_CLK) can be derived from several sources.



Figure 12-137. CPTS Block Diagram

#### Note

See [Section 12.3.1.4.7.1, CPSW0 CPTS Integration](#) for CPTS integration in the device CPSW0 module.

#### 12.3.1.4.7.3 CPTS Initialization

The CPTS module should be configured as follows:

1. Reset the CPTS module.
2. Write the CPTS\_CLKSEL value in the CTRLMMR\_CPTS\_CLKSEL register with the desired reference clock selection. This value is allowed to be written only when the CPTS\_EN bit in the CPSW\_CPTS\_CONTROL\_REG register is cleared to zero.
3. Set the CPTS\_EN bit in the CPSW\_CPTS\_CONTROL\_REG register.
4. If using interrupts and not polling, enable the interrupt by setting the TS\_PEND\_EN bit in the CPSW\_CPTS\_INT\_ENABLE\_REG register.

#### 12.3.1.4.7.4 32-bit Time Stamp Value

The time stamp value is a 32-bit value that increments on each CPTS\_RFT\_CLK rising edge when CPTS\_EN bit is set to 1h. When CPTS\_EN bit is cleared to 0h, the time stamp value is reset to 0h.

If more than 32-bits of time stamp are required by the application, the host software must maintain the necessary number of upper bits. The upper time stamp value should be incremented by the host when the rollover event is detected.

For test purposes, the time stamp can be written via the time stamp load function (CPSW\_CPTS\_TS\_LOAD\_VAL\_REG / CPSW\_CPTS\_TS\_LOAD\_HIGH\_VAL\_REG and CPSW\_CPTS\_TS\_LOAD\_EN\_REG registers).

#### 12.3.1.4.7.5 64-bit Time Stamp Value

The time stamp value is a 64-bit value that increments on each CPTS\_RFT\_CLK rising edge when CPTS\_EN bit is set to 1h. When CPTS\_EN bit is cleared to 0h, the time stamp value is reset to 0h.

64-bit mode is selected when CPSW\_CPTS\_CONTROL\_REG[5] MODE bit set to 1h.

For test purposes, the time stamp value can be written via the time stamp load function (CPSW\_CPTS\_TS\_LOAD\_EN\_REG, CPSW\_CPTS\_TS\_LOAD\_VAL\_REG, and CPSW\_CPTS\_TS\_LOAD\_HIGH\_VAL\_REG registers). The CPSW\_CPTS\_TS\_ADD\_VAL\_REG feature is included to allow 1ns timestamp operations with an CPTS\_RFT\_CLK rate less than 1Ghz. [Table 12-168](#) shows the CPTS\_RFT\_CLK and CPSW\_CPTS\_TS\_ADD\_VAL\_REG values for 1ns operations.

**Table 12-168. ADD\_VAL feature**

| CPTS_RFT_CLK (MHz) | CPSW_CPTS_TS_ADD_VAL_REG[2-0] ADD_VAL |
|--------------------|---------------------------------------|
| 1 GHz              | 0                                     |
| 500 MHz            | 1                                     |
| 333.33 MHz         | 2                                     |
| 250 MHz            | 3                                     |
| 200 MHz            | 4                                     |
| 166.66 MHz         | 5                                     |
| 142.85714 MHz      | 6                                     |
| 125 MHz            | 7                                     |

#### 12.3.1.4.7.6 64-Bit Timestamp Nudge

The 64-bit TIME\_STAMP value can be adjusted by writing the CPSW\_CPTS\_TS\_NUDGE\_VAL\_REG[7-0] TS\_NUDGE\_VAL bit field value which is a two's complement value. A value of FFh will subtract 1 clock cycle from the next incremented 64-bit time stamp value (CPSW\_CPTS\_EVENT\_0\_REG[31-0] TIME\_STAMP and CPSW\_CPTS\_EVENT\_3\_REG[31-0] TIME\_STAMP value). A nudge value of 1h will add 1 clock cycle to the next incremented TIME\_STAMP[63-0] value. For example, if the current TIME\_STAMP value is F06h, and CPSW\_CPTS\_TS\_ADD\_VAL\_REG[2-0] ADD\_VAL = 3h, the next incremented timestamp value would be F0Ah without a nudge and F0Ah +/- [7-0] TS\_NUDGE\_VAL with a nudge. The [7-0] TS\_NUDGE\_VAL value is cleared to zero when the nudge has occurred.

#### 12.3.1.4.7.7 64-bit Timestamp PPM

The 64-bit TIME\_STAMP can be adjusted by parts per million or by parts per hour. Writing a non-zero value to the CPSW\_CPTS\_TS\_PPM\_LOW\_VAL\_REG[31-0] TS\_PPM\_LOW\_VAL (Time stamp PPM Low value) and CPSW\_CPTS\_TS\_PPM\_HIGH\_VAL\_REG[9-0] TS\_PPM\_HIGH\_VAL (Time stamp PPM High value) enables PPM operations. The adjustment is up or down depending on the [7] TS\_PPM\_DIR bit in the CPSW\_CPTS\_CONTROL\_REG register. The TIME\_STAMP value is increased by the PPM value when [7] TS\_PPM\_DIR bit is cleared. The TIME\_STAMP value is decreased by the PPM value when [7] TS\_PPM\_DIR bit is set.

#### Parts Per Million example:

To adjust for 100 parts per million the configured value for TS\_PPM[41-0] (through CPSW\_CPTS\_TS\_PPM\_LOW\_VAL\_REG[31-0] TS\_PPM\_LOW\_VAL and CPSW\_CPTS\_TS\_PPM\_HIGH\_VAL\_REG[9-0] TS\_PPM\_HIGH\_VAL) is:

$1,000,000/100 = 10,000$ (decimal)

#### Parts Per Hour example:

To adjust for 1 part per hour at 1 GHz CPTS\_RFT\_CLK the configured value for TS\_PPM[41:0] (through CPSW\_CPTS\_TS\_PPM\_LOW\_VAL\_REG[31:0] TS\_PPM\_LOW\_VAL and CPSW\_CPTS\_TS\_PPM\_HIGH\_VAL\_REG[9:0] TS\_PPM\_HIGH\_VAL) is:  
 $(1,000,000,000\text{Hz}/1\text{pph}) * (3600 \text{seconds}/\text{hour}) = 34630B8A000$  (hex)

#### 12.3.1.4.7.8 Event FIFO

All time sync events are pushed onto the Event FIFO. There are 32 locations in the event FIFO with no overrun indication supported. Software must service the event FIFO in a timely manner to prevent FIFO overrun.

#### 12.3.1.4.7.9 Timestamp Compare Output

CPTS features one Time Stamp Compare (CPTS\_COMP) output. The CPTS\_COMP function is a software oriented feature that is intended to be replaced going forward by the hardware oriented GENF function. CPTS\_COMP is not compatible with timestamp PPM or a non-zero CPSW\_CPTS\_TS\_ADD\_VAL\_REG[2:0] ADD\_VAL value.

##### 12.3.1.4.7.9.1 Non-Toggle Mode: 32-bit

The CPTS\_COMP output is asserted for CPSW\_CPTS\_TS\_COMP\_LEN\_REG[31:0] TS\_COMP\_LENGTH periods when the CPSW\_CPTS\_EVENT\_0\_REG[31:0] TIME\_STAMP value (lower 32-bits) compares with the CPSW\_CPTS\_TS\_COMP\_VAL\_REG[31:0] TS\_COMP\_VAL and the length value is non-zero. The CPTS\_COMP rising edge occurs three CPTS\_RFT\_CLK clock periods after the values compare. A timestamp compare event is pushed into the event FIFO when CPTS\_COMP is asserted. The polarity of the CPTS\_COMP output is determined by the CPSW\_CPTS\_CONTROL\_REG[2] TS\_COMP\_POLARITY bit. The output is asserted low when the polarity bit is 0h.

##### 12.3.1.4.7.9.2 Non-Toggle Mode: 64-bit

64-bit mode operation is identical to 32-bit mode except that all 64-bits of the TIME\_STAMP are used (CPSW\_CPTS\_EVENT\_0\_REG and CPSW\_CPTS\_EVENT\_3\_REG). In 32-bit mode only the lower 32-bits (CPSW\_CPTS\_EVENT\_0\_REG) are used.

##### 12.3.1.4.7.9.3 Toggle Mode: 32-bit

The CPTS\_COMP output is asserted (CPSW\_CPTS\_TS\_COMP\_LEN\_REG[31:0] TS\_COMP\_LENGTH) for CPTS\_RFT\_CLK clock periods when the TIME\_STAMP[31:0] value compares with the CPSW\_CPTS\_TS\_COMP\_VAL\_REG and the length value is non-zero. The CPTS\_COMP toggles thereafter on CPSW\_CPTS\_TS\_COMP\_VAL\_REG[31:0] TS\_COMP\_LENGTH for CPTS\_RFT\_CLK periods. The length high or low can be adjusted by writing the CPSW\_CPTS\_TS\_COMP\_NUDGE\_REG[7:0] NUDGE bit field value which is a two's complement value. A value of FFh will subtract one CPTS\_RFT\_CLK period from the CPSW\_CPTS\_TS\_COMP\_VAL\_REG[31:0] TS\_COMP\_LENGTH value. A value of 0x01h will add one CPTS\_RFT\_CLK period to the CPSW\_CPTS\_TS\_COMP\_LEN\_REG[31:0] TS\_COMP\_LENGTH value. Only a single high or low time is adjusted (nudged) and the CPSW\_CPTS\_TS\_COMP\_NUDGE\_REG[7:0] NUDGE value is cleared to zero when the nudge has occurred. The CPTS\_COMP output is asserted low when the CPSW\_CPTS\_CONTROL\_REG[2] TS\_COMP\_POLARITY bit is 0h. No compare events and no CPTS\_EVNT interrupts are generated in toggle mode. The CPSW\_CPTS\_CONTROL\_REG[6] TS\_COMP\_TOG bit must be set for toggle mode (value 1h). Note this bit must be set before writing a non-zero value to CPSW\_CPTS\_TS\_COMP\_VAL\_REG register.

##### 12.3.1.4.7.9.4 Toggle Mode: 64-bit

64-bit mode operation is identical to 32-bit mode except that all 64-bits of the TIMESTAMP are used (CPSW\_CPTS\_EVENT\_0\_REG and CPSW\_CPTS\_EVENT\_3\_REG). In 32-bit mode only the lower 32-bits (CPSW\_CPTS\_EVENT\_0\_REG) are used.



**Figure 12-138. CPTS\_COMP Output in Toggle and Non-Toggle Mode**

#### 12.3.1.4.7.10 Timestamp Sync Output

The CPTS\_SYNC output is a selected bit of the [31-0]TIME\_STAMP counter value. One of bits 17-31 can be selected in CPSW\_CPTS\_CONTROL\_REG[31-28] TS\_SYNC\_SEL. The CPTS\_SYNC output is disabled when CPSW\_CPTS\_CONTROL\_REG[31-28] TS\_SYNC\_SEL is zero.

If the selected counter bit is 1 at the time when TS\_SYNC\_SEL value is written then a rising edge will not occur on the CPTS\_SYNC output. A rising edge will occur on the CPTS\_SYNC output upon the next transition to 1 of the selected counter bit. The TS\_SYNC\_SEL value must be written to zero before changing to a different non-zero value. No events are generated due to the CPTS\_SYNC operation. The CPTS\_SYNC output is two CPTS\_RFT\_CLK periods after the actual count value.

#### 12.3.1.4.7.11 Timestamp GENFn Output

The CPTS\_GENFn outputs have a programmable cycle (frequency) with a PPM feature and software nudge feature. The CPTS\_GENFn output cycle is CPSW\_GENF0\_LENGTH\_REG\_L[31-0] CPTS\_RFT\_CLK periods (which is different than CPTS\_COMP operation). [Figure 12-139](#) represents the CPTS\_GENFn output signal.

The CPTS\_GENFn output cycle is CPSW\_GENF0\_LENGTH\_REG\_L[31-0] CPTS\_RFT\_CLK periods beginning when the 64-bit TIME\_STAMP value compares with the 64-bit GENFn\_COMP value (CPSW\_GENF0\_COMP\_LOW\_REG\_L and CPSW\_GENF0\_COMP\_HIGH\_REG\_L registers) and the length value is non-zero. The CPTS\_GENFn output cycle repeats thereafter every CPSW\_GENF0\_LENGTH\_REG\_L[31-0] CPTS\_RFT\_CLK periods. The upper 32-bit word should be written first for 64-bit values. The length should be zero while the comparison value and other configuration parameters are being configured. The length should be written non-zero to enable operations last. The first cycle after comparison is active high when the CPSW\_CPTS\_CONTROL\_REG[2] TS\_COMP\_POLARITY bit is low. No compare events and no CPTS\_EVNT interrupts are generated.



**Figure 12-139. CPTS\_GENFn Output Signal Diagram**

#### 12.3.1.4.7.11.1 GENFn Nudge

The cycle length can be adjusted by writing the CPSW\_CPTS\_TS\_COMP\_NUDGE\_REG[7-0] NUDGE register value which is a two's complement value. A value of FFh will subtract 1 CPTS\_RFT\_CLK from the CPSW\_GENF0\_LENGTH\_REG\_L[31-0] value. A value of 1h will add 1 CPTS\_RFT\_CLK to the CPSW\_GENF0\_LENGTH\_REG\_L[31-0] value. The CPSW\_CPTS\_TS\_COMP\_NUDGE\_REG[7-0] NUDGE value is cleared to zero when the nudge has occurred.

#### 12.3.1.4.7.11.2 GENFn PPM

The CPTS\_GENFn output cycle can be adjusted by parts per million or by parts per hour. Writing a non-zero value to CPSW\_GENF0\_PPM\_LOW\_REG\_L/ CPSW\_GENF0\_PPM\_HIGH\_REG\_L enables PPM operations. The PPM counter continually loads and decrements to zero and then loads again. A single CPTS\_RFT\_CLK adjustment is made when the PPM counter decrements to zero. The adjustment is up or down depending on the CPSW\_GENF0\_TS\_GENF\_CONTROL\_REG[0] PPM\_DIR bit. When PPM\_DIR bit is set a single CPTS\_RFT\_CLK time is subtracted from the generate function counter which has the effect of increasing the generate function frequency by the PPM amount. When PPM\_DIR bit is cleared a single CPTS\_RFT\_CLK time is added to the generate function counter which has the effect of decreasing the generate function frequency by the PPM amount.

##### Parts Per Million example:

To adjust for 100 parts per million the configured value for GENF\_PPM[41-0] (through CPSW\_GENF0\_PPM\_LOW\_REG\_L and CPSW\_GENF0\_PPM\_HIGH\_REG\_L) is:  
 $1,000,000/100 = 10,000$ (decimal)

##### Parts Per Hour example:

To adjust for 1 part per hour at 1 GHz CPTS\_RFT\_CLK the configured value for GENF\_PPM[41-0] (through CPSW\_GENF0\_PPM\_LOW\_REG\_L and CPSW\_GENF0\_PPM\_HIGH\_REG\_L) is:  
 $(1,000,000,000\text{Hz}/1\text{pph}) * (3600\text{ seconds/hour}) = 34630B8A000$  (hex)

#### 12.3.1.4.7.12 Timestamp ESTFn

Each Ethernet port has a dedicated ESTFn generator which operates identically to the GENFn function.

#### 12.3.1.4.7.13 Time Sync Events

Time Sync events are 96-bit values that are pushed onto the event FIFO and read by software in 32-bit reads. Four 32-bit registers, CPSW\_CPTS\_EVENT\_0\_REG through CPSW\_CPTS\_EVENT\_3\_REG hold the data of a time sync event. There are eight types of sync events:

- Time Stamp Push Event

- Time Stamp Counter Rollover Event (32-bit mode only)
- Time Stamp Counter Half-rollover Event (32-bit mode only)
- Hardware Time Stamp Push Event
- Ethernet Receive Event
- Ethernet Transmit Event
- Time Stamp Compare Event
- Host Transmit Event

#### **12.3.1.4.7.13.1 Time Stamp Push Event**

Software can obtain the current time stamp value (at the time of the write) by initiating a time stamp push event. The push event is initiated by setting the [0]TS\_PUSH bit of the CPSW\_CPTS\_TS\_PUSH\_REG register. The time stamp value is returned in the event, along with a time stamp push event code. The upper 32-bits (CPSW\_CPTS\_EVENT\_3\_REG register) of the timestamp are zero in 32-bit mode.

#### **12.3.1.4.7.13.2 Time Stamp Counter Rollover Event (32-bit mode only)**

The CPTS module contains a 32-bit time stamp value (CPSW\_CPTS\_EVENT\_0\_REG). The counter upper bits are maintained by host software. The rollover event indicates to software that the time stamp counter has rolled over from 0xFFFF FFFF to 0x0000 0000 and the software-maintained upper count value should be incremented. This event occurs only in 32-bit mode.

#### **12.3.1.4.7.13.3 Time Stamp Counter Half-rollover Event (32-bit mode only)**

The CPTS includes a time stamp counter half-rollover event. The half-rollover event indicates to software that the time stamp value (CPSW\_CPTS\_EVENT\_0\_REG[31-0] TIME\_STAMP) has incremented from 0x7FFF FFFF to 0x8000 0000. The half-rollover event is included to enable software to correct a misaligned event condition. This event occurs only in 32-bit mode.

The half-rollover event is included to enable software to determine the correct time for each event that contains a valid time stamp value, such as an Ethernet event. If an Ethernet event occurs around a counter rollover (full rollover), the rollover event could possibly be loaded into the event FIFO before the Ethernet event, even though the Ethernet event time was actually taken before the rollover. [Figure 12-140](#) shows a misalignment condition. This misaligned event condition arises because an Ethernet event time stamp occurs at the beginning of a packet and time passes before the packet is determined to be a valid synchronization packet. The misaligned event condition occurs if the rollover occurs in the middle, after the packet time stamp has been taken, but before the packet has been determined to be a valid time sync packet.

Host software must detect and correct for misaligned event conditions. For every event time stamp after a rollover and before a half-rollover, software must examine the time stamp most significant bit. If bit 31 of the time stamp value is low (0x0000 0000 through 0x7FFF FFFF), then the event time stamp was taken after the rollover and no correction is required. If the value is high (0x8000 0000 through 0xFFFF FFFF), the time stamp value was taken before the rollover and a misalignment is detected. The misaligned case indicates to software that it must subtract one from the upper count value stored in software to calculate the correct time for the misaligned event. The misaligned event occurs only on the rollover boundary and not on the half-rollover boundary. Software only needs to check for misalignment from a rollover event to a half-rollover event.

When a rollover occurs, software increments the software time stamp upper value. The misaligned case indicates to software that the misaligned event time stamp has a valid upper value that is pre-increment, so one must be subtracted from the upper value to allow software to calculate the correct time for the misaligned event.



cpsw-014

**Figure 12-140. Event FIFO Misalignment Condition**

#### 12.3.1.4.7.13.4 Hardware Time Stamp Push Event

There are four hardware time stamp inputs ( CPTS\_HW[1:4]\_TS\_PUSH events) that can cause hardware time stamp push events to be loaded into the Event FIFO. Each time stamp input is mapped in the device as shown in *CPTS Integration*. The event is loaded into the event FIFO on the rising edge of the timer, and the PORT\_NUMBER field in the CPSW\_CPTS\_EVENT\_1\_REG register indicates the hardware push input that caused the event (encoded).

The hardware time stamp inputs are asynchronous and are low frequency signals. The CPTS logic synchronizes and performs a rising edge detect on the incoming asynchronous input.

Each hardware time stamp input must be asserted for at least 10 periods of the selected CPTS\_RFT\_CLK clock. Each input can be enabled or disabled by setting the respective bits in the CPSW\_CPTS\_CONTROL\_REG register.

Hardware time stamps are intended to be an extremely low frequency signals, such that the event FIFO does not overrun. Software must keep up with the event FIFO and ensure that there is no overrun, or events will be lost.

#### 12.3.1.4.7.13.5 Ethernet Port Events

Packets transmitted or received on each Ethernet port can generate Ethernet Transmit Events or Ethernet Receive Events, respectively. The CPTS hardware will decode each packet to determine if it is a valid CPTS time sync event.

According to the IEEE 802.3 Ethernet standard, each Ethernet frame contains a 2-octet EtherType field to indicate which protocol is encapsulated in the PayLoad field, as shown in Figure 12-141. For standard time sync packets, this will contain the EtherType for the Precision Time Protocol (IEEE 1588), which is defined as 0x88F7. The CPTS hardware will compare this field to the TS\_LTYPE1 field in the CPSW\_PN\_TS\_SEQ\_LTYPE\_REG or the TS\_LTYPE2 field in CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register (depending on which enable bit was set), which should also be programmed to 88F7h.

When a virtual LAN is used, an additional 4-octet 802.1Q tag is inserted in the Ethernet frame before the EtherType field, as shown in Figure 12-141. To indicate to the CPTS hardware that a virtual LAN is in use, the TS\_TX\_VLAN\_LTYPE1\_EN (or TS\_TX\_VLAN\_LTYPE2\_EN) enable bit must be set in the

CPSW\_PN\_TS\_CTL\_REG register. The EtherType for the 802.1Q tag is defined as 0x8100, and the CPTS hardware will compare this value to the TS\_VLAN\_LTYPE1 (or TS\_VLAN\_LTYPE2 depending on which enable bit was set) field in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register, which should also be programmed to 0x8100.

When two stacked VLANs are used, two additional 4-octet 801.Q tags are inserted in the Ethernet frame before the EtherType field, as shown in [Figure 12-141](#). In this case, both TS\_VLAN\_LTYPE1 and TS\_VLAN\_LTYPE2 must be enabled. The outer tag must match the value of the TS\_VLAN\_LTYPE1 field, and the inner tag must match the value of the TS\_VLAN\_LTYPE2 field.



**Figure 12-141. Partial Ethernet-II Frames Showing Register Mapping of EtherTypes for a Simple Frame (1), a Single 1Q Tag Added (2), and Two 1Q Tags Added (3)**

#### 12.3.1.4.7.13.5.1 Ethernet Port Receive Event

This section describes Ethernet port receive events. Ethernet port generates time synchronization events for valid received time sync packets. For every packet received on the Ethernet port, a timestamp will be captured by the receive module inside the CPTS for the corresponding port. The time stamp will be captured by the receive module regardless of whether or not the packet is a time synchronization packet to make sure that the time stamp is captured as soon as possible. The packet is sampled on both the rising and falling edges of the CPTS\_RFT\_CLK, and the time stamp will be captured once the start of frame delimiter for the receive packet is detected.

After the time stamp has been captured, the receive interface will begin parsing the packet to determine if it is a valid Ethernet time synchronization packet. The CPSW decoder determines if the packet is a valid Ethernet receive time synchronization event. The receive interface for the port will use the following criteria to determine if the packet is a valid Annex D, Annex E, or Annex F time synchronization Ethernet receive event:

#### Annex D (IPv4)

1. Receive annex D time sync is enabled (TS\_RX\_ANNEX\_D\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register).

2. One of the sequences below is true.
  - a. The first packet LTYPE matches 0x0800
  - b. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x0800
  - c. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x0800
  - d. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches 0x0800
3. Byte 14 (the byte after the LTYPE) contains 0x45 (IPv4).

---

#### Note

The byte numbering assumes that there are no VLANs. The byte number is intended to show the relative order of the bytes.

4. Byte 20 contains 0bXXX00000 (5 lower bits zero) and Byte 21 contains 0x00 (fragment offset zero)
5. Byte 22 contains 0x01 (HOP Limit = 1) if the TS\_TTL\_NONZERO bit in the switch CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0h, or byte 22 contains any value if CPSW\_PN\_TS\_CTL\_LTYPE2\_REG is set to 1h. Byte 22 is the TTL/HOP field.
6. Byte 23 contains 0x11 (Next Header UDP Fixed).
7. The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0h and Bytes 30 through 33 contain:
  - a. Decimal 224.0.1.129 and the TS\_129 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - b. Decimal 224.0.1.130 and the TS\_130 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - c. Decimal 224.0.1.131 and the TS\_131 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - d. Decimal 224.0.1.132 and the TS\_132 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - e. Decimal 224.0.0.107 and the TS\_107 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set

-OR-

The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set and Bytes 30 through 33 contain any values.

8. Bytes 36 and 37 contain:
  - a. Decimal 0x01 and 0x3F respectively and the TS\_319 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set -OR-
  - b. Decimal 0x01 and 0x40 respectively and the TS\_320 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set.
9. The PTP message begins in byte 42.
10. The packet message type is enabled in the TS\_MSG\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL\_REG register.
11. The packet was received without error (not long/short/mac\_ctl/CRC/code/align).

#### Annex E (IPv6)

1. Receive annex E time sync is enabled (TS\_RX\_ANNEX\_E\_EN bit is set in the switch CPSW\_PN\_TS\_CTL\_REG register).
2. One of the sequences below is true.
  - a. The first packet LTYPE matches 0x86dd.
  - b. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x86dd

- c. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x86dd
- d. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches 0x86dd
- 3. Byte 14 (the byte after the LTYPE) contains 0x6X (IPv6).
- 4. Byte 20 contains 0x11 (UDP Fixed Next Header).
- 5. Byte 21 contains 0x01 (Hop Limit = 1) if the TS\_TTL\_NONZERO bit in the switch CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0h, or byte 21 contains any value if TS\_TTL\_NONZERO is set to 1h. Byte 21 is the TTL/HOP field.
- 6. The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0 and Bytes 38 through 53 contain:
  - a. FF0M:0:0:0:0:0:0181 and the TS\_129 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - b. FF0M:0:0:0:0:0:0182 and the TS\_130 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - c. FF0M:0:0:0:0:0:0183 and the TS\_131 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - d. FF0M:0:0:0:0:0:0184 and the TS\_132 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - e. FF0M:0:0:0:0:0:006B and the TS\_107 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set

---

**Note**

All values above are 16-bit hex numbers where M is enabled in the TS\_MCAST\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL2\_REG register.

---

-OR-

The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set to 1h and Bytes 38 through 53 contain any value.

- 7. Bytes 56 and 57 contain (UDP Header in bytes 54 through 61):
  - a. Decimal 0x01 and 0x3F respectively and the TS\_319 bit in the CPSW\_PN\_TS\_CTL2\_REG register is set, or
  - b. Decimal 0x01 and 0x40 respectively and the TS\_320 bit in the CPSW\_PN\_TS\_CTL2\_REG register is set.
- 8. The PTP message begins in byte 62.
- 9. The packet message type is enabled in the MSG\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL2\_REG register.
- 10. The packet was received without error (not long/short/mac\_ctl/CRC/code/align).

**Annex F (IEEE 802.3)**

- 1. Receive Annex F time sync is enabled (TS\_RX\_ANNEX\_F\_EN is set in the switch CPSW\_PN\_TS\_CTL\_REG register).
- 2. One of the sequences below is true:
  - a. The first packet LTYPE matches TS\_LTYPE1 in the CPSW\_PN\_TS\_SEQ\_LTYPE\_REG/CPSW\_PN\_TS\_SEQ\_LTYPE\_REG register. LTYPE 1 should be used when only one time sync LTYPE is to be enabled.
  - b. The first packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register and LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register.
  - c. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_LTYPE1 in the CPSW\_PN\_TS\_SEQ\_LTYPE\_REG register
  - d. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet

- LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register and TS\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register.
- e. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_LTYPE1 in the CPSW\_PN\_TS\_SEQ\_LTYPE\_REG register.
  - f. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register and TS\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register.
  - g. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches TS\_LTYPE1 in the CPSW\_PN\_TS\_SEQ\_LTYPE\_REG register.
  - h. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_RX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register and TS\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register
3. The PTP message begins in the byte after the LTYPE.
  4. The packet message type is enabled in the TS\_MSG\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL\_REG register.
  5. The packet was received without error (not long/short/mac\_ctl/CRC/code/align).

If all of the criteria described above are met for either Annex D, Annex E, or Annex F, and the packet is determined to be a valid time synchronization packet, then the RX interface will push an Ethernet receive event into the event FIFO.

#### 12.3.1.4.7.13.5.2 Ethernet Port Transmit Event

This section describes Ethernet port transmit events. For every packet transmitted on the Ethernet ports, the port transmit interface will begin parsing the packet to determine if it is a valid Ethernet time synchronization packet. The CPTS transmit interface for the port will use to the following criteria to determine if the packet is a valid time synchronization Ethernet transmit event. The CPSW decoder determines if the packet is a valid ethernet receive time synchronization event. To be a valid Ethernet transmit time synchronization event, the conditions listed below must be true for either Annex D, Annex E, or Annex F:

#### Annex D (IPv4)

1. Transmit time sync is enabled (TS\_TX\_ANNEX\_D\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register).
2. One of the sequences below is true.
  - a. The first packet LTYPE matches 0x0800
  - b. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x0800
  - c. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x0800
  - d. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches 0x0800
3. Byte 14 (the byte after the LTYPE) contains 0x45 (IPv4).

---

**Note**

The byte numbering assumes that there are no VLANs. The byte number is intended to show the relative order of the bytes.

4. Byte 20 contains 0bXXX00000 (5 lower bits zero) and Byte 21 contains 0x00 (fragment offset zero)
5. Byte 22 contains 0x01 (HOP Limit = 1) if the TS\_TTL\_NONZERO bit in the switch CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0h, or byte 22 contains any value if TS\_TTL\_NONZERO is set to 1h. Byte 22 is the TTL/HOP field.
6. Byte 23 contains 0x11 (Next Header UDP Fixed).
7. The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0h and Bytes 30 through 33 contain:
  - a. Decimal 224.0.1.129 and the TS\_129 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - b. Decimal 224.0.1.130 and the TS\_130 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - c. Decimal 224.0.1.131 and the TS\_131 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - d. Decimal 224.0.1.132 and the TS\_132 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - e. Decimal 224.0.0.107 and the TS\_107 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - f. The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set and Bytes 30 through 33 contain any values.
8. Bytes 36 and 37 contain:
  - a. Decimal 0x01 and 0x3F respectively and the TS\_319 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - b. Decimal 0x01 and 0x40 respectively and the TS\_320 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set.
9. The PTP message begins in byte 42.
10. The packet message type is enabled in the TS\_MSG\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL\_REG register.
11. The packet was sent by host port 0.

**Annex E (IPv6)**

1. Transmit annex E time sync is enabled (TS\_TX\_ANNEX\_E\_EN bit is set in the switch CPSW\_PN\_TS\_CTL\_REG register).
2. One of the sequences below is true.
  - a. The first packet LTYPE matches 0x86dd.
  - b. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x86dd
  - c. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches 0x86dd
  - d. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches 0x86dd
3. Byte 14 (the byte after the LTYPE) contains 0x6X (IPv6).
4. Byte 20 contains 0x11 (UDP Fixed Next Header).
5. Byte 21 contains 0x01 (Hop Limit = 1) if the TS\_TTL\_NONZERO bit in the switch CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0h, or byte 21 contains any value if TS\_TTL\_NONZERO is set to 1h. Byte 21 is the TTL/HOP field..
6. The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is cleared to 0 and Bytes 38 through 53 contain:
  - a. FF0M:0:0:0:0:0:0181 and the TS\_129 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - b. FF0M:0:0:0:0:0:0182 and the TS\_130 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - c. FF0M:0:0:0:0:0:0183 and the TS\_131 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or

- d. FF0M:0:0:0:0:0:0:0184 and the TS\_132 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
- e. FF0M:0:0:0:0:0:0:006B and the TS\_107 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set

---

**Note**

All values above are 16-bit hex numbers where M is enabled in the TS\_MCAST\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL2\_REG register.

---

-OR-

The TS\_UNI\_EN bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set to 1h and Bytes 38 through 53 contain any value.

7. Bytes 56 and 57 contain (UDP Header in bytes 54 through 61):
  - a. Decimal 0x01 and 0x3F respectively and the TS\_319 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set, or
  - b. Decimal 0x01 and 0x40 respectively and the TS\_320 bit in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register is set.
8. The PTP message begins in byte 62.
9. The packet message type is enabled in the TS\_MSG\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL\_REG register.
10. The packet was sent by host port 0.

**Annex F (IEEE 802.3)**

1. Transmit time sync is enabled (TS\_TX\_ANNEX\_F\_EN is set in the switch CPSW\_PN\_TS\_CTL\_REG register).
2. One of the sequences below is true:
  - a. The first packet LTYPE matches TS\_LTYPE1 in the CPSW\_PN\_TS\_SEQ\_LTYPE\_REG register. LTYPE 1 should be used when only one time sync LTYPE is to be enabled.
  - b. The first packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register and TS\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register.
  - c. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register.
  - d. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_LTYPE1 in the CPSW\_PN\_TS\_SEQ\_LTYPE\_REG register.
  - e. The first packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register.
  - f. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register and TS\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register.
  - g. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register.
  - h. The first packet LTYPE matches TS\_VLAN\_LTYPE1 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE1\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the second packet LTYPE matches TS\_VLAN\_LTYPE2 in the CPSW\_PN\_TS\_VLAN\_LTYPE\_REG register and TS\_TX\_VLAN\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register and the third packet LTYPE matches TS\_LTYPE2 in the CPSW\_PN\_TS\_CTL\_LTYPE2\_REG register and TS\_LTYPE2\_EN is set in the CPSW\_PN\_TS\_CTL\_REG register

3. The packet message type is enabled in the TS\_MSG\_TYPE\_EN field in the CPSW\_PN\_TS\_CTL\_REG register.
4. The packet was sent by host port 0.

If all of the criteria described above are met, and the packet is determined to be a valid time synchronization packet, then the time stamp for the transmit event will not be generated until the start of frame delimiter of the packet is actually transmitted. The start of frame delimiter will be sampled on every rising and falling edge of the CPTS\_RFT\_CLK. Once the packet is transmitted, then the TX interface will push an Ethernet transmit event into the event FIFO.

#### 12.3.1.4.7.13.5.3

**Table 12-169. Values of Message Type Field**

| Message Type          | Value (hex) |
|-----------------------|-------------|
| Sync                  | 0           |
| Delay_Req             | 1           |
| Pdelay_Req            | 2           |
| Pdelay_Resp           | 3           |
| Reserved              | 4:7         |
| Follow_Up             | 8           |
| Delay_Resp            | 9           |
| Pdelay_Resp_Follow_Up | A           |
| Announce              | B           |
| Signaling             | C           |
| Management            | D           |
| Reserved              | E:F         |

Once a transmitted or received packet is determined to be a valid time sync packet, the Ethernet Transmit Event or Ethernet Receive Event is loaded onto the Event FIFO.

The CPSW\_CPTS\_EVENT\_1\_REG register contains the Message Type and Sequence ID values from the original time sync packet. The CPSW\_CPTS\_EVENT\_0\_REG (and CPSW\_CPTS\_EVENT\_3\_REG) register contains the time stamp value when the packet arrived at the corresponding port.

#### 12.3.1.4.7.14 Timestamp Compare Event

---

##### Note

Timestamp compare events are generated for non-toggle mode only.

---

The CPTS can generate an event for a time stamp comparison in 32-bit or 64-bit mode.

##### 12.3.1.4.7.14.1 32-Bit Mode

The CPTS\_COMP output is also asserted when the event is generated. The event is generated when the 32-bit time stamp value (CPSW\_CPTS\_EVENT\_0\_REG) compares with the CPSW\_CPTS\_TS\_COMP\_VAL\_REG register and the CPSW\_CPTS\_TS\_COMP\_LEN\_REG value is non-zero. The CPSW\_CPTS\_TS\_COMP\_LEN\_REG value should be written by software after the CPSW\_CPTS\_TS\_COMP\_VAL\_REG register is written and should be zero when the comparison value is written.

##### 12.3.1.4.7.14.2 64-Bit Mode

The CPTS\_COMP output is also asserted when the event is generated. The event is generated when the 64-bit time stamp value (CPSW\_CPTS\_EVENT\_0\_REG and CPSW\_CPTS\_EVENT\_3\_REG) compares with the CPSW\_CPTS\_TS\_COMP\_VAL\_REG and CPSW\_CPTS\_TS\_COMP\_HIGH\_VAL\_REG registers and the CPSW\_CPTS\_TS\_COMP\_LEN\_REG value is non-zero. The CPSW\_CPTS\_TS\_COMP\_LEN\_REG value

should be written by software after the CPSW\_CPTS\_TS\_COMP\_VAL\_REG register is written and should be zero when the comparison value is written.

#### **12.3.1.4.7.15 Host Transmit Event**

The host can send a packet to be transmitted on an Ethernet port that will generate a time synchronization event. The host sets the TSTAMP\_EN bit and sends the DOMAIN, MESSAGE\_TYPE, and SEQUENCE\_ID in the additional control information that resides in the protocol specific section of the descriptor that is transmitted to the CPSW\_2G. An event is then generated and placed on the event FIFO once the packet is transmitted. Host events allow the user to timestamp exactly when a software generated packet exits the device.

#### **12.3.1.4.7.16 CPTS Interrupt Handling**

When an event is push onto the Event FIFO, an interrupt can be generated to indicate to software that a time sync event occurred. The following steps should be taken to process time sync events using interrupts:

1. Enable the TS\_PEND interrupt by setting the TS\_PEND\_EN bit of the CPSW\_CPTS\_INT\_ENABLE\_REG register.
2. Upon interrupt, read the CPSW\_CPTS\_EVENT\_0\_REG through CPSW\_CPTS\_EVENT\_3\_REG registers values.
3. Set the CPSW\_CPTS\_EVENT\_POP\_REG[0] EVENT\_POP bit to 1h to pop the previously read value off of the event FIFO.
4. Process the interrupt as required by the application software.

Software has the option of processing more than a single event from the event FIFO in the interrupt service routine in the following way:

1. Enable the TS\_PEND interrupt by setting the TS\_PEND\_EN bit of the CPSW\_CPTS\_INT\_ENABLE\_REG
2. Upon interrupt, enter the CPTS service routine.
3. Read the CPSW\_CPTS\_EVENT\_0\_REG through CPSW\_CPTS\_EVENT\_3\_REG registers values.
4. Set the CPSW\_CPTS\_EVENT\_POP\_REG[0] EVENT\_POP bit to 1h to pop the previously read value off of the event FIFO.
5. Wait for an amount of time greater than four CPTS\_RFT\_CLK periods plus four CPPI\_ICLK periods.
6. Read the TS\_PEND\_RAW bit in the CPSW\_CPTS\_INTSTAT\_RAW\_REG register to determine if another valid event is in the event FIFO. If bit TS\_PEND\_RAW is asserted, go to step 3. If bit TS\_PEND\_RAW is not asserted proceed with step 7.
7. Process the interrupt(s) as required by the application software.

Software also has the option of disabling the interrupt and polling the TS\_PEND\_RAW bit of the CPSW\_CPTS\_INTSTAT\_RAW\_REG register to determine if a valid event is on the event FIFO.

#### **12.3.1.4.8 CPPI Streaming Packet Interface**

The receive streaming interface on port 0 of the CPSW is responsible for receiving packet for Ethernet egress data from the packet streaming switch in the . The CPPI receive port is equivalent to an Ethernet port with the difference being that the data is provided to the CPSW in the 128-bit streaming interface data format instead RGMII data format.

In addition to the packet data, the receive streaming interface also can provide additional control information that resides in the information words of the descriptor that was transmitted to the CPSW.

The tables below show the information that may be passed along with which descriptor information word to put it in.

##### **12.3.1.4.8.1 Port 0 CPPI Transmit Packet Streaming Interface (CPSW\_3G Egress)**

The CPSW2G has a single transmit packet streaming interface. All Ethernet packet data destined for the host (Port 0) is transferred on the transmit packet streaming interface. The transmit packet streaming interface is equivalent to an Ethernet MAC output with the difference being that 128-bit streaming interface data is output. Egress packet data is packed on the 128-bit data bus with all words having 16-bytes except possibly the last packet data word which is the word previous to the EOP word. INFO Word 0–3 is transferred on SOP. The

EOP word contains the packet status 0–3 (data type 24) which includes the timestamp and checksum data. Packets are not dropped on the transmit streaming interface due to pushback, but packets may be dropped in the associated priority FIFO.

INFO Word 0–3 and Status Data Word 0–3 (on EOP) are the only non-payload data word types that are transferred. Long packets are truncated at the CPSW\_PN\_RX\_MAXLEN\_REG\_k[13-0] RX\_MAXLEN byte value of the ingress port (only the CPSW\_PN\_RX\_MAXLEN\_REG\_k number of bytes are kept if long packets are transferred due to CPSW\_PN\_MAC\_CONTROL\_REG\_k register copy error frames set - RX\_CEF\_EN). MAC control frames are only transferred if the receiving Ethernet port has the CPSW\_PN\_MAC\_CONTROL\_REG\_k[24] RX\_CMF\_EN bit set.

The error encoding on the TXST\_PKT\_ERR[3:0] output is shown in [Table 12-170](#):

**Table 12-170. Error Encoding on the TXST\_PKT\_ERR[3:0] Output**

| TXST_PKT_ERR[3:0] | Description                                                                               |
|-------------------|-------------------------------------------------------------------------------------------|
| 0000              | No Error                                                                                  |
| 0001              | CRC Error                                                                                 |
| 0010              | Code or alignment error                                                                   |
| 0011              | Short (no code/align/crc error)                                                           |
| 0100              | FragCRC (short with crc error)                                                            |
| 0101              | Frag Code/Align (short with code/align error)                                             |
| 0110              | Long                                                                                      |
| 0111              | Jabber CRC (long with crc error)                                                          |
| 1000              | Jabber Code/Align (long with code/align error)                                            |
| 1001              | Mac control packet (CPSW_PN_MAC_CONTROL_REG_k[24] RX_CMF_EN set on ingress Ethernet port) |
| 1010              | Mac control CRC                                                                           |
| 1011              | Mac control Code/Align                                                                    |
| 1100              | Mac control short/frag (short MAC control frame with CRC/Code/Align)                      |
| 1101              | Mac control long/jabber (long MAC control frame with CRC/Code/Align)                      |
| 1110              | Reserved                                                                                  |
| 1111              | Reserved                                                                                  |

The CPPI Port 0 transmit packet streaming interface has a single output thread. If a packet transmission has begun then the entire packet will be transmitted before the next packet is sent (packet data from multiple packets are not interleaved on the transmit streaming interface). The default egress flow is the port number minus 1, concatenated with the 3-bit Port 0 transmit FIFO hardware switch priority. For example, a packet that was received on port 4 with a Port 0 transmit FIFO hardware switch priority of 5 would be sent on flow 29 (decimal) or flow 0b0011101 (binary). Priority remapping on ingress and Port 0 transmit egress effects the output flow.

INFO Words are a contiguous block of four 32-bit data words aligned on a 32-bit word boundary.

**Figure 12-142. TX INFO Word 0 Format**

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

| Bit   | Field    | Description                                                                             |
|-------|----------|-----------------------------------------------------------------------------------------|
| 31-27 | PKT_TYPE | Always set to 0b00111.<br>Host PD (Packet Descriptor) Word 2. Packet Type: bits[31-27]. |

| Bit   | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26-24 | RESERVED | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 23    | PASS_CRC | This bit is cleared to zero (no CRC passed) when the P0_TX_CRC_REMOVE bit in the CPSW_CONTROL_REG register is set (and the egress packet has no errors). When the remove bit is cleared to zero then this bit is cleared and no CRC is passed with the output packet. The packet length includes the CRC if it is present.                                                                                                                                                                                                                |
| 22    | CRC_TYPE | The packet CRC type. The type of CRC passed is determined by CRC_TYPE field in the CPSW_PN_MAC_CONTROL_REG_k register (not by the type of CRC the packet had on Ethernet port ingress).<br>Host PD Word 1. Protocol Specific Flags: bits[27-24].<br>0h: Ethernet CRC<br>1h: Castagnoli CRC                                                                                                                                                                                                                                                |
| 21-8  | RESERVED | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7-0   | FLOW_ID  | This is the packet output transmit streaming interface flow. The default flow ID can be overridden by ALE classification (Thread mapping).<br>The switch default flow is the 3-bit "From Port" value concatenated with the 3-bit "Switch Priority" {From_Port[2:0], Switch_Priority[2:0]} as shown below:<br>Host PD (Packet Descriptor) Word 1. Flow ID: bits[13-0].<br>0h: The packet was received on Ethernet port 1<br>Switch Priority – The actual hardware switch priority that the packet was stored in on the CPPI transmit FIFO. |

**Figure 12-143. TX INFO Word 1 Format**

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

| Bit                                                                                     | Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20                                                                                   | FIXED_PS_SIZE | Fixed packet size: 0x4                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19-14                                                                                   | RESERVED      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13-0<br>(Host PD<br>(Packet<br>Descriptor)<br>Word 1. Packet<br>Length:<br>bits[ 21-0]) | PKT_LENGTH    | Specifies the number of bytes in the entire packet. Offset bytes are not included. Valid only on SOP. The packet length must be greater than zero. The packet data will be truncated to the packet length if the packet length is shorter than the sum of the packet buffer descriptor buffer lengths. A host error occurs if the packet length is greater than the sum of the packet buffer descriptor buffer lengths. |

**Figure 12-144. TX INFO Word 2 Format**

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

**Figure 12-145. TX INFO Word 3 Format**

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

**Figure 12-145. TX INFO Word 3 Format (continued)**

0

| Bit   | Field    | Description                                                                                                                                                                                                                                                                                                                      |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | RESERVED | Reserved.                                                                                                                                                                                                                                                                                                                        |
| 23-16 | SRC_ID   | The packet SRC_ID value comes from the PORT1/PORT2 field in the CPSW_P0_SRC_ID_A_REG register.<br>(src_tag) PD (Packet Descriptor) Word 3. Source Tag Low bits[23-16] if RFLOW[a]_RFC.rx_src_tag_lo_sel = 0x4 or<br>(src_tag) PD (Packet Descriptor) Word 3. Source Tag High bits[31-24] if RFLOW[a]_RFC.rx_src_tag_hi_sel = 0x4 |
| 15-0  | RESERVED | Reserved.                                                                                                                                                                                                                                                                                                                        |

**Note**

TX Status Data Word [0..3] are mapped to Host Packet Descriptor Protocol Specific Words if RFLOW[a]\_RFA.rx\_psinfo\_present = 1 and RFLOW[a]\_RFA.rx\_ps\_location = 0

**Figure 12-146. TX Status Data Word 0 Format**

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

| Bit  | Field           | Description                                         |
|------|-----------------|-----------------------------------------------------|
| 31-0 | TIMESTAMP[31:0] | Contains the lower 32-bits of the time stamp value. |

**Figure 12-147. TX Status Data Word 1 Format**

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

| Bit  | Field            | Description                                         |
|------|------------------|-----------------------------------------------------|
| 31-0 | TIMESTAMP[63:32] | Contains the upper 32-bits of the time stamp value. |

**Figure 12-148. TX Status Data Word 2 Format**

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

| Bit   | Field      | Description                             |
|-------|------------|-----------------------------------------|
| 31-21 | RESERVED   | Reserved.                               |
| 20    | IPV4_VALID | An IPV4 TCP or UDP Packet was detected. |
| 19    | IPV6_VALID | An IPV6 TCP or UDP Packet was detected. |

| Bit  | Field          | Description                                                                                                                                           |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18   | TCP_UDP_N      | Valid only when either the IPV4_VALID or IPV6_VALID bits are set.<br>0h: Indicates UDP packet was detected.<br>1h: Indicates TCP packet was detected. |
| 17   | FRAGMENT       | Indicates that an IP fragment was detected. Valid only when either the IPV4_VALID or IPV6_VALID bits are set.                                         |
| 16   | CHECKSUM_ERROR | Valid only when either the IPV4_VALID or IPV6_VALID bits are set.                                                                                     |
| 15-0 | CHECKSUM_ADD   | This is the value that was summed during the checksum computation. This value is FFFFh for IPV4/6 UDP/TCP packets with no checksum error.             |

**Figure 12-149. TX Status Data Word 3 Format**

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

| Bit  | Field    | Description |
|------|----------|-------------|
| 31-0 | RESERVED | Reserved.   |

#### 12.3.1.4.8.2 Port 0 CPPI Receive Packet Streaming Interface (CPSW\_3G Ingress)

Info Word 0/1/2/3 (INFO1 and INFO3 are ignored) are transferred on SOP. If a timestamp word (Extended Packet Info Word 0/1/2/3) is to be transferred it must be after SOP and before any packet data is transferred. Any following non-data type words will be dropped. The EOP word must be payload data.

Input receive packets cannot be aborted by the host. The INFO Word bit descriptions and Extended Packet INFO Word bit descriptions are shown below. The PASS\_CRC bit indicates that the CRC is passed with the packet data. Packets that have a passed CRC that is an error CRC will be output on the Ethernet port with at least one CRC byte inverted to indicate the error if P0\_RX\_PASS\_CRC\_ERR bit is set, otherwise they are dropped. The packet is a directed packet when any of the TO\_PORT bits are nonzero. A packet may be directed only to a single port. The packet will be sent to the port number indicated. For directed packets the lookup process is skipped to determine the destination. However, in vlan aware mode (when VLAN\_AWARE bit in the CPSW\_CONTROL\_REG register is set to 1h) the lookup is performed to determine untagged egress. Packets longer than the value in CPSW\_P0\_RX\_MAXLEN\_REG[13-0] RX\_MAXLEN bit field are dropped. Packets shorter than 60-Bytes are padded to 64-Bytes (after adding pad and CRC) if P0\_RX\_PAD bit in the CPSW\_CONTROL\_REG register is set and if PASS\_CRC is clear, otherwise they are dropped. This means that packets shorter than 64-Bytes are dropped if the PASS\_CRC info bit is set regardless of P0\_RX\_PAD bit (packets are padded only if they are short and do not have CRC).

A RX INFO word is a contiguous block of four 32-bit data words aligned on a 32-bit word boundary.

#### Note

RX Control Data Words [0..2] are mapped to Host Packet Descriptor Protocol Specific Words if (TCHAN[a].TCFG.tx\_filt\_pswords = 0) and (Host PD Word 1.Protocol Specific Region Location.bit[28] = 0h) and (Host PD Word 1.Protocol Specific Valid Word Count.bits[22-27] = 4h)

**Figure 12-150. RX INFO Word 0 Format**

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

**Figure 12-150. RX INFO Word 0 Format (continued)**

| RESERVED                                                                                           |          |                                                                                                                                                                                              |
|----------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                | Field    | Description                                                                                                                                                                                  |
| 31-24                                                                                              | RESERVED | Reserved.                                                                                                                                                                                    |
| 23                                                                                                 | PASS_CRC | The PASS_CRC bit indicates that the CRC is passed with the packet data.<br>0h: CRC is not passed with packet (CRC_TYPE is don't care)<br>1h: CRC of type CRC_TYPE is passed with the packet. |
| 22<br>(Host PD<br>(Packet<br>Descriptor)<br>Word 1.<br>Protocol<br>Specific Flags:<br>bits[27-24]) | CRC_TYPE | CRC Type<br>0h: Ethernet CRC<br>1h: Castagnoli CRC                                                                                                                                           |
| 21-0                                                                                               | RESERVED | Reserved.                                                                                                                                                                                    |

**Figure 12-151. RX INFO Word 2 Format**

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

| Bit                                                                                  | Field    | Description                                                                                                                                                                                                                                                                                                              |
|--------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-21                                                                                | RESERVED | Reserved.                                                                                                                                                                                                                                                                                                                |
| 20-16<br>(Host PD<br>(Packet<br>Descriptor)<br>Word 3. Dest<br>Tag Low<br>bits[8-0]) | TO_PORT  | Port number to send the directed packet to. This field is set by the host. This field is valid on SOP. Directed packets go to the directed port, but an ALE lookup is performed to determine untagged egress in VLAN_AWARE mode.<br>0h: Not directed<br>1h: Send the packet to port 1.<br>2h: Send the packet to port 2. |
| 15-0                                                                                 | RESERVED | Reserved.                                                                                                                                                                                                                                                                                                                |

**Figure 12-152. RX Control Data Word 1 Format**

|                          |          |    |        |    |    |    |    |          |    |    |    |    |    |    |    |
|--------------------------|----------|----|--------|----|----|----|----|----------|----|----|----|----|----|----|----|
| 31                       | 30       | 29 | 28     | 27 | 26 | 25 | 24 | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TIMES<br>TAMP<br>-<br>EN | RESERVED |    | DOMAIN |    |    |    |    | MSG_TYPE |    |    |    |    |    |    |    |
| 15                       | 14       | 13 | 12     | 11 | 10 | 9  | 8  | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SEQUENCE_ID              |          |    |        |    |    |    |    |          |    |    |    |    |    |    |    |

| Bit   | Field        | Description                                                                                                                                                                                |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | TIMESTAMP_EN | When set, this bit indicates that the packet will generate a timesync event on Ethernet egress (if the CPTS is configured properly) with the associated DOMAIN, MSG_TYPE, and SEQUENCE_ID. |
| 30-28 | RESERVED     | Reserved.                                                                                                                                                                                  |
| 27-20 | DOMAIN       | Timesync domain.                                                                                                                                                                           |
| 19-16 | MSG_TYPE     | Timesync message type.                                                                                                                                                                     |

| Bit  | Field       | Description           |
|------|-------------|-----------------------|
| 15-0 | SEQUENCE_ID | Timesync sequence ID. |

**Figure 12-153. RX Control Data Word 2 Format**

|                      |              |                    |    |    |    |    |    |                     |    |    |    |    |    |    |    |
|----------------------|--------------|--------------------|----|----|----|----|----|---------------------|----|----|----|----|----|----|----|
| 31                   | 30           | 29                 | 28 | 27 | 26 | 25 | 24 | 23                  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CHECKSUM_RESULT      |              |                    |    |    |    |    |    | CHECKSUM_START_BYTE |    |    |    |    |    |    |    |
| 15                   | 14           | 13                 | 12 | 11 | 10 | 9  | 8  | 7                   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| CHEC<br>KSUM<br>_INV | RESE<br>RVED | CHECKSUM_BYTECOUNT |    |    |    |    |    |                     |    |    |    |    |    |    |    |

| Bit   | Field               | Description                                                                                                                                                                                       |
|-------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | CHECKSUM_RESULT     | This is the packet byte number where the checksum result will be placed in the egress packet. The first packet byte which is the first byte of the destination address is Byte 1 (not byte zero). |
| 23-16 | CHECKSUM_START_BYTE | This is the packet byte number to start the checksum calculation on. The first packet byte is Byte 1.                                                                                             |
| 15    | CHECKSUM_INV        | When set, a zero checksum value will be inverted and sent as FFFFh.                                                                                                                               |
| 14    | RESERVED            | Reserved.                                                                                                                                                                                         |
| 13-0  | CHECKSUM_BYTECOUNT  | This is the number of bytes to calculate the checksum on. The outgoing Ethernet packet will have a checksum inserted when this value is non-zero.                                                 |

Other INFO words are not taken into account.

#### 12.3.1.4.8.3 Cut-Thru

An Ethernet port received packet can be sent cut-thru to all destination ports when the following is true:

- The CPSW\_CONTROL\_REG[19] CUT\_THRU\_ENABLE bit is set, and
- The receive port is full duplex, and
- The Ethernet receive port speed is non-zero, and
- The packet was received on an express priority, and
- The Ethernet receive port has the remapped received packet priority enabled via the CPSW\_PN\_CUT\_THRU\_REG\_K[15-8] RX\_PRI\_CUT\_THRU\_EN field, and
- All Ethernet destination ports have the remapped packet priority enabled via the CPSW\_PN\_CUT\_THRU\_REG\_K[7-0] TX\_PRI\_CUT\_THRU\_EN field, and
- All Ethernet destination ports are full duplex, and
- All Ethernet destination ports are express priorities, and
- All Ethernet destination ports have a non-zero CPSW\_PN\_SPEED\_REG\_K[3-0] SPEED, and
- All Ethernet destination ports are equal to or slower in speed than the Ethernet receive port, and
- The host port is not in the destination port list unless the CPSW\_P0\_CONTROL\_REG[19] CUT\_MODE\_ETH bit is set.

Whether or not a packet actually egresses cut-thru (with or without delay) on an Ethernet destination port depends on traffic congestion on that port. Cut-thru is compatible with Interspersed Express Traffic (IET) and Enhanced Scheduled Traffic (EST).

#### 12.3.1.4.8.3.1 Host Port Cut-Thru Operations

Packets received (CPSW ingress) on the host port are sent store-and-forward to all Ethernet destination ports. Setting the CPSW\_P0\_CONTROL\_REG[19] CUT\_MODE\_ETH bit enables Ethernet received packets to be sent cut-thru to a destination port mask that includes the host port. The packet can egress cut-thru on Ethernet ports, but the packet will not actually egress cut-thru on the host port. Setting CPSW\_P0\_CONTROL\_REG[19] CUT\_MODE\_ETH can cause head of line blocking on the host priority if multiple Ethernet ports are sending to the same host port priority. The head of line blocking issue is worsened if there are differing Ethernet port

speeds. Clearing the CPSW\_P0\_CONTROL\_REG[19] CUT\_MODE\_ETH bit causes packets with the host port in the destination mask to egress store-and-forward on all egress ports.

#### **12.3.1.4.8.3.2 Cut-Thru Error Packets**

Any received packets with errors sent cut-thru from an Ethernet receive port to any Ethernet transmit port(s) will egress with at least one byte of the generated outgoing packet CRC inverted to indicate the error. This is due to the fact that cut-thru operations begin before the end of packet when the receive port determines that the packet had an error (long/code/align/CRC).

Any packet also sent cut-thru with the host included in the destination port mask will be dropped to the host (TXST\_PKT\_DROP) with the packet error indicated on TXST\_PKT\_ERR[3:0].

Any long/Jabber/Code/Align/CRC errored Ethernet received packet that is not actually sent cut-thru by the receive port will be dropped unless CPSW\_PN\_MAC\_CONTROL\_REG\_k[22] RX\_CEF\_EN is set (which if set will cause the packet to be sent to the host port with the error indicated on TXST\_PKT\_ERR[3:0]. If a long/Jabber/Code/Align/CRC errored Ethernet received packet is sent cut-thru by the received port then a set CPSW\_PN\_MAC\_CONTROL\_REG\_k[22] RX\_CEF\_EN will not cause the errored packet to be sent to the host port since the packet has already been transferred to the destination ports.

The following cut-thru notes are valid:

- Any Ethernet received packet and that is sent cut-thru to any destination port will not be dropped at any destination port due to priority maximum lengths (CPSW\_TX\_PRlx\_MAXLEN).
- Any Ethernet received packet that is decoded as a timesync packet will be sent store-and-forward to all destination ports.
- Cut-Thru is full duplex only.
- Cut-Thru is not compatible with any form of flow control.
- Cut-Thru should not be enabled for any receive port that is in ALE bypass mode.

#### **12.3.1.4.8.4 Port Speed**

Cut-thru operations require that the Ethernet port speeds be known. Port speed can be set manually by software or be automatically determined by the hardware. A zero port speed causes the port to be disabled for cut-thru operations, but does not disable the port. The port speed values are as follows:

- 0000 – Port speed operations disabled (not a port disable)
- 0001 – 10Mbps
- 0010 – 100Mbps
- 0011 – 1G
- 0100 – 2.5G
- 0101 – 5G
- 0110 – 10G
- 0111 through 1111 Reserved

When the CPSW\_PN\_SPEED\_REG\_k[8] AUTO\_SPEED\_EN bit is cleared, the port speed is written by software. When the CPSW\_PN\_SPEED\_REG\_k[8] AUTO\_SPEED\_EN bit is set, the port speed is automatically detected by the hardware.

#### **12.3.1.4.8.5 CPPI Checksum Offload**

The CPPI host port can be enabled to perform checksum offload on host port packet ingress and egress. UDP (User Datagram Protocol) and TCP (Transmission Control Protocol) over IPV4 and IPV6 are supported. For the purposes of checksum description, the first packet byte (the first byte of the destination address) is byte 1 (not byte 0). That is, a 64 byte packet goes from byte 1 to byte 64. For all packet types, the S\_CN\_SWITCH bit in the CPSW\_CONTROL\_REG register must be set for the Outer VLAN L type to be supported.

##### **12.3.1.4.8.5.1 CPPI Transmit Checksum Offload**

IPV4 and IPV6 UDP and TCP packets that are received on any Ethernet port and destined for port 0 egress are checked for correct checksum as described below. The byte counts below are shown for packets with no

VLAN's. The byte counts vary with one or two packet VLAN's. Packets received on an Ethernet port with errors are not checked for a correct checksum if they are passed to the host.

#### 12.3.1.4.8.5.1.1 IPV4 UDP

- Byte 15 Upper Nibble = 4 for IPV4
- Byte 15 Lower Nibble = IHL - Nibble with number of 32-bit words in IPV4 header (5 to 15 supported).
- Bytes 20-21 = fragment[15-0] – Bit 13 is the MF bit and bits [12-0] are the Fragment offset. A packet is a fragment if the MF bit is set or if the fragment offset is non-zero. The first packet fragment has MF=1 with a zero offset. Middle fragments have MF=1 with a nonzero offset. The last packet fragment has MF=0 with a nonzero offset. Non-fragmented packets have MF=0 and a zero offset. A count is output for packet fragments but no errors are reported. First fragments have the UDP header included in the count. Middle and last fragments have only data included in the count (there is no UDP header).
- Byte 24 = 0x11 for UDP protocol.
- Received packet UDP checksum of zero means that there is no IPV4 checksum sent with the packet so no error will be issued.
- Received packet UDP checksum of 0xFFFF means that the checksum was calculated to be 0xFFFF or 0x0000 but was sent in the transmitted packet as 0xFFFF by the sending originating entity.

#### 12.3.1.4.8.5.1.2 IPV4 TCP

- Byte 15 Upper Nibble = 4 for IPV4
- Byte 15 Lower Nibble = IHL - Nibble with number of 32-bit words in IPV4 header (5 to 15 supported).
- Bytes 20-21 = fragment[15-0] – Bit 13 is the MF bit and bits [12-0] are the Fragment offset. A packet is a fragment if the MF bit is set or if the fragment offset is non-zero. The first packet fragment has MF=1 with a zero offset. Middle fragments have MF=1 with a nonzero offset. The last packet fragment has MF=0 with a nonzero offset. Non-fragmented packets have MF=0 and a zero offset. A count is output for packet fragments but no errors are reported. First fragments have the UDP header included in the count. Middle and last fragments have only data included in the count (there is no TCP header).
- Byte 24 = 0x06 for TCP protocol.

#### 12.3.1.4.8.5.1.3 IPV6 UDP

- Byte 15 upper nibble = 6 for IPV6.
- Byte 21 = 0x11 for UDP protocol as next header.
- Fragment extension headers are supported. First fragments have a fragment extension header (byte 21 = 0x2C) followed by a UDP header (byte 55 = 0x11). Middle and last fragments have a fragment extension header followed by data only (no UDP header). The first packet fragment has MF=1 with a zero offset. Middle fragments have MF=1 with a nonzero offset. The last packet fragment has MF=0 with a nonzero offset. Non-fragmented packets do not have a fragment extension header. A count is output for packet fragments but no errors are reported.
- Received packet UDP checksum of zero means that there is no IPV6 checksum sent with the packet so no error will be issued.
- Received packet UDP checksum of 0xFFFF means that the checksum was calculated to be 0xFFFF or 0x0000 but was sent in the transmitted packet as 0xFFFF by the sending originating entity.

#### 12.3.1.4.8.5.1.4 IPV6 TCP

- Byte 15 upper nibble = 6 for IPV6.
- Byte 21 = 0x06 for TCP protocol as next header.
- Fragment extension headers are supported. First fragments have a fragment extension header (byte 21 = 0x2C) followed by a UDP header (byte 55 = 0x06). Middle and last fragments have a fragment extension header followed by data only (no TCP header). The first packet fragment has MF=1 with a zero offset. Middle fragments have MF=1 with a nonzero offset. The last packet fragment has MF=0 with a nonzero offset. Non-fragmented packets do not have a fragment extension header. A count is output for packet fragments but no errors are reported.

#### **12.3.1.4.8.6 CPPI Receive Checksum Offload**

Packets sent from host port 0 (switch ingress) to any Ethernet port can have a checksum calculated and inserted into the Ethernet egress packet. The RX\_CHECKSUM\_EN bit in the CPSW\_P0\_CONTROL\_REG register must be set for receive checksum operation to be enabled. When bit RX\_CHECKSUM\_EN is enabled, Control Data Word 2 input on CPPI receive PSI interface determines how the checksum is calculated. The CHECKSUM\_RESULT field in Control Data Word 2 determines where the checksum is inserted. The checksum result location is adjusted by the egress port if a VLAN is to be inserted or removed on Ethernet port egress.

#### **12.3.1.4.8.7 Egress Packet Operations**

Each CPSW egress port (Ethernet and Host) is capable of performing egress packet processing operations (CPSW\_ALE\_EGRESSOP). IntraVLAN processing either adds, removes, or replaces VLAN information or does nothing. InterVLAN routing allows hardware routing between a limited number of VLANs - thereby allowing high-bandwidth or other routing operations to be offloaded from software to the CPSW (hardware). IntraVLAN processing and InterVLAN routing operations are mutually exclusive. In addition, the packet source and destination addresses can be swapped on egress to facilitate OAM or generic testing operations.

#### 12.3.1.4.9 MII Management Interface (MDIO)

The MII Management interface module implements the 802.3 serial management interface to interrogate and control external Ethernet PHY using a two-wire bus.

##### 12.3.1.4.9.1 MDIO Frame Formats

**Table 12-171** shows the address, **Table 12-172** shows the read format and **Table 12-173** shows the write format of the supported Clause 45 MII Management interface frames. Post-increment accesses are not supported.

**Table 12-171. MDIO Clause 45 Address Frame Format**

| Pre-amble  | Start Delimiter | Operation Code | PHY Address | MMD Number | Turnaround | Data                |
|------------|-----------------|----------------|-------------|------------|------------|---------------------|
| FFFF FFFFh | 00              | 00             | AAAAAA      | RRRRR      | 10         | AAAA.AAAA.AAAA.AAAA |

**Table 12-172. MDIO Clause 45 Read Frame Format**

| Pre-amble  | Start Delimiter | Operation Code | PHY Address | MMD Number | Turnaround | Data                |
|------------|-----------------|----------------|-------------|------------|------------|---------------------|
| FFFF FFFFh | 00              | 11             | AAAAAA      | RRRRR      | Z0         | DDDD.DDDD.DDDD.DDDD |

**Table 12-173. MDIO Clause 45 Write Frame Format**

| Pre-amble  | Start Delimiter | Operation Code | PHY Address | MMD Number | Turnaround | Data                |
|------------|-----------------|----------------|-------------|------------|------------|---------------------|
| FFFF FFFFh | 00              | 01             | AAAAAA      | RRRRR      | 10         | DDDD.DDDD.DDDD.DDDD |

The default or idle state of the two wire serial interface is a logic one. All tri-state drivers should be disabled and the PHY's pull-up resistor will pull the MDIO line to a logic 1. Prior to initiating any other transaction, the station management entity shall send a preamble sequence of 32 contiguous logic 1 bits on the MDIO line with 32 corresponding cycles on MDCLK to provide the PHY with a pattern that it can use to establish synchronization. A PHY shall observe a sequence of 32 contiguous logic one bits on MDIO with 32 corresponding MDCLK cycles before it responds to any other transaction. The MDIO CPSW\_MDIO\_USER\_ADDR0\_REG register must be written before a read or write operation is performed to set the address used in the operation. Each read or write operation has a preceding address frame.

#### Preamble

The start of a frame is indicated by a preamble, which consists of a sequence of 32 contiguous bits all of which are a 1. This sequence provides the PHY a pattern to use to establish synchronization. The preamble is required in clause 45 operation.

#### Start Delimiter

The preamble is followed by the start delimiter which is indicated by a 00 pattern.

#### Operation Code

The operation code for an address transaction is 00. The operation code for a read is 11, while the operation code for a write is a 01.

#### PHY Address

The PHY address is 5 bits allowing 32 unique values. The first bit transmitted is the MSB of the PHY address.

#### MMD Number

The MMD number is the 5 bits allowing 32 unique values. The first bit transmitted is the MSB.

#### Turnaround

An idle bit time during which no device actively drives the MDIO signal shall be inserted between the register address field and the data field of a read frame in order to avoid contention. During a read frame, the PHY shall

drive a zero bit onto MDIO for the first bit time following the idle bit and preceding the Data field. During a write frame, this field shall consist of a one bit followed by a zero bit.

### Address

The address field is 16 bits on address operations. The first bit transmitted is the MSB of the address word. Each read/write operation initiated has an automatic address operation initiated first that uses the MDIO CPSW\_MDIO\_USER\_ADDR0\_REG/ CPSW\_MDIO\_USER\_ADDR1\_REG register values as the 16-bit address.

### Data

The Data field is 16 bits on read and write operations. The first bit transmitted and received is the MSB of the data word.

#### 12.3.1.4.9.2 MDIO Functional Description

The MII Management I/F will remain idle until enabled by setting the ENABLE bit in the CPSW\_MDIO\_CONTROL\_REG register. The MII Management I/F will then continuously poll the link status from within the Generic Status Register of all possible 32 PHY addresses in turn recording the results in the MDIO CPSW\_MDIO\_LINK\_REG register. Individual PHY's can be enabled or disabled for polling the associated bit in the CPSW\_MDIO\_POLL\_EN\_REG register. The CPSW\_MDIO\_LINK\_REG and CPSW\_MDIO\_ALIVE\_REG register bit values are updated on the poll of each PHY. The LINKSEL bit in the CPSW\_MDIO\_USER\_PHY\_SEL\_REG\_k register determines the status input that is used. A change in the link status of the two PHYs being monitored will set the appropriate bit in the MDIO CPSW\_MDIO\_LINK\_INT\_RAW\_REG register and the MDIO CPSW\_MDIO\_LINK\_INT\_MASKED\_REG register, if enabled by the LINKINT\_ENABLE bit in the CPSW\_MDIO\_USER\_PHY\_SEL\_REG\_k register.

The MDIO CPSW\_MDIO\_ALIVE\_REG register is updated by the MII Management I/F module if the PHY acknowledged the read of the generic status register. In addition, any PHY register read transactions initiated by the host also cause the MDIO CPSW\_MDIO\_ALIVE\_REG register to be updated.

At any time, the host can define a transaction for the MII Management interface module to undertake using the DATA, PHYADR, REGADR, and WRITE fields in a CPSW\_MDIO\_USER\_ACCESS\_REG\_k register. When the host sets the GO bit in this register, the MII Management interface module will begin the transaction without any further intervention from the host. Upon completion, the MII Management interface will clear the GO bit and set the USERINTRAW field in the CPSW\_MDIO\_USER\_INT\_RAW\_REG register corresponding to the CPSW\_MDIO\_USER\_ACCESS\_REG\_k register being used. The corresponding bit in the CPSW\_MDIO\_USER\_INT\_MASKED\_REG register may also be set depending on the mask setting in the MDIO CPSW\_MDIO\_USER\_INT\_MASK\_SET\_REG and CPSW\_MDIO\_USER\_INT\_MASK\_CLEAR\_REG registers. A round-robin arbitration scheme is used to schedule transactions that may be queued by the host in different CPSW\_MDIO\_USER\_ACCESS\_REG\_k registers. The host should check the status of the GO bit in the MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k register before initiating a new transaction to ensure that the previous transaction has completed. The host can use the ACK bit in the MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k register to determine the status of a read transaction.

It is necessary for software to use the MII Management interface module to setup the auto-negotiation parameters of each PHY attached to a MAC port, retrieve the negotiation results, and setup the CPSW\_PN\_MAC\_CONTROL\_REG register in the corresponding MAC.

#### 12.3.1.5 CPSW0 Programming Guide

##### 12.3.1.5.1 Initialization and Configuration of CPSW Subsystem

To configure the CPSW Ethernet Subsystem for operation, the host must perform the following:

1. Select the Interface (RMII, or RGMII ) Mode. See the CTRLMMR\_ENET1\_CTRL and CTRLMMR\_ENET2\_CTRL[2-0] PORT\_MODE\_SEL fields.
2. Configure pads (pin muxing), as per the interface selected. Refer to *Pad Configuration Registers* and the device-specific Datasheet.
3. Enable the CPSW Ethernet Subsystem clocks. See *CPSW Integration*
4. Ensure that at least 2000 CPPI\_ICLK periods are run after reset is de-asserted.

5. Configure the CPSW\_CONTROL\_REG register
6. Configure the Ethernet Port Source Address registers (CPSW\_PN\_SA\_L\_REG\_k and CPSW\_PN\_SA\_H\_REG\_k)
7. Configure the CPSW statistic port enable register CPSW\_STAT\_PORT\_EN\_REG
8. Configure the ALE (Section 12.3.1.4.6.1, *Address Lookup Engine*)
9. Configure the MDIO (Section 12.3.1.5.3.1, *Initializing the MDIO Module*)
10. Configure Ethernet port, as per the desired mode of operations

#### 12.3.1.5.2 CPSW Reset

To reset the Ethernet port, the host must perform the following:

1. Set CMD\_IDLE bit to 1h in the Ethernet port control register: CPSW\_PN\_MAC\_CONTROL\_REG.
2. Wait for IDLE bit to be set to 1h, which is indicated in the Ethernet port status register: CPSW\_PN\_MAC\_STATUS\_REG.
3. Set SOFT\_RESET bit to 1h in the Ethernet port software reset register: CPSW\_PN\_MAC\_SOFT\_RESET\_REG.
4. Wait for SOFT\_RESET bit in the CPSW\_PN\_MAC\_SOFT\_RESET\_REG registers to be cleared to confirm reset completion.
5. Configure the Ethernet ports.
6. Re-configure registers reset to default value by CPSW\_PN\_MAC\_SOFT\_RESET\_REG.

#### 12.3.1.5.3 MDIO Software Interface

##### 12.3.1.5.3.1 Initializing the MDIO Module

The following steps are performed by the application software or device driver to initialize the MDIO device:

1. Configure the PREAMBLE and CLKDIV bits in the MDIO Control register (CPSW\_MDIO\_CONTROL\_REG).
2. Enable the MDIO module by setting the ENABLE bit in CPSW\_MDIO\_CONTROL\_REG.
3. The MDIO PHY alive status register (MDIO CPSW\_MDIO\_ALIVE\_REG) can be read in polling fashion until a PHY connected to the system responded, and the MDIO PHY link status register (MDIO CPSW\_MDIO\_LINK\_REG) can determine whether this PHY already has a link.
4. Set the appropriate PHY addresses in the MDIO user PHY select register (CPSW\_MDIO\_USER\_PHY\_SEL\_REG\_k, where k = 0 or 1), and set the LINKINT\_ENABLE bit to enable a link change event interrupt if desirable.
5. Set the appropriate LINKSEL bit in the CPSW\_MDIO\_USER\_PHY\_SEL\_REG\_k register (where k = 0 or 1).
6. Set the appropriate USERINTMASKSET bit field in the CPSW\_MDIO\_USER\_INT\_MASK\_SET\_REG register.
7. If an interrupt on general MDIO register access is desired, set the corresponding bit in the MDIO user command complete interrupt mask set register (MDIO CPSW\_MDIO\_USER\_INT\_MASK\_SET\_REG) to use the MDIO user access register (MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k, where k = 0 or 1).

##### 12.3.1.5.3.2 Writing Data To a PHY Register

The MDIO module includes a user access register (MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k, where k = 0 or 1) to directly access a specified PHY device. To write a PHY register, perform the following:

1. Check to ensure that the GO bit in the MDIO user access register (MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k) is cleared.
2. Write to the GO, WRITE, REGADR, PHYADR, and DATA bits in MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k corresponding to the PHY and PHY register SW wants to write.
3. The write operation to the PHY is scheduled and completed by the MDIO module. Completion of the write operation can be determined by polling the GO bit in MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k for a 0.
4. Completion of the operation sets the corresponding USERINTRAW bit (0 or 1) in the MDIO user command complete interrupt register (CPSW\_MDIO\_USER\_INT\_RAW\_REG) corresponding to MDIO CPSW\_MDIO\_USER\_ACCESS\_REG\_k used. If interrupts have been enabled on this bit using the MDIO user command complete interrupt mask set register (CPSW\_MDIO\_USER\_INT\_MASK\_SET\_REG), then the bit is also set in the MDIO user command complete interrupt register (CPSW\_MDIO\_USER\_INT\_MASKED\_REG) and an interrupt is triggered on the host processor.

#### 12.3.1.5.3.3 Reading Data From a PHY Register

The MDIO module includes a user access register (MDIO\_CPSW\_MDIO\_USER\_ACCESS\_REG\_k, where k = 0 or 1) to directly access a specified PHY device. To read a PHY register, perform the following:

1. Check to ensure that the GO bit in the MDIO user access register (CPSW\_MDIO\_USER\_ACCESS\_REG\_k, where k = 0 or 1) is cleared.
2. Write to the GO, REGADR, and PHYADR bits in the CPSW\_MDIO\_USER\_ACCESS\_REG\_k register corresponding to the PHY and PHY register SW wants to read.
3. The read data value is available in the DATA bit field in MDIO\_CPSW\_MDIO\_USER\_ACCESS\_REG\_k register after the module completes the read operation on the serial bus. Completion of the read operation can be determined by polling the GO and ACK bits in CPSW\_MDIO\_USER\_ACCESS\_REG\_k register. After the GO bit has cleared, the ACK bit is set on a successful read.
4. Completion of the operation sets the corresponding USERINTRAW bit (0 or 1) in the MDIO user command complete interrupt register (CPSW\_MDIO\_USER\_INT\_RAW\_REG) corresponding to MDIO\_CPSW\_MDIO\_USER\_ACCESS\_REG\_k used. If interrupts have been enabled on this bit using the MDIO user command complete interrupt mask set register (CPSW\_MDIO\_USER\_INT\_MASK\_SET\_REG), then the bit is also set in the MDIO user command complete interrupt register (CPSW\_MDIO\_USER\_INT\_MASKED\_REG) and an interrupt is triggered on the host processor.

### 12.3.2 Universal Serial Bus Subsystem (USBSS)

This section describes the Universal Serial Bus Subsystem (USBSS) in the device.

#### 12.3.2.1 USB Overview

USB (Universal Serial Bus) provides a low-cost connectivity solution for numerous consumer portable devices by implementing a mechanism for data transfer between USB devices.

The device instantiates two independent instances of a third-party USB subsystem (USB2SS) operating at up to USB2.0 speeds (480Mb/s), either of which can be independently configured to act as a USB Host or a USB Device. SuperSpeed (5.0 Gb/s) operation is not supported in either operational mode.

##### 12.3.2.1.1 USB Features

The USB 2.0 subsystem supports the following USB Features:

- Operational modes:
  - Supports USB 2.0 Host mode at High-Speed (HS, 480 Mbps), Full-Speed (FS, 12 Mbps), and Low-Speed (LS, 1.5 Mbps)
  - Supports USB 2.0 Device mode at High-Speed (HS, 480 Mbps), and Full-Speed (FS, 12 Mbps). Low-Speed is not supported in Device mode.
  - Supports all modes of transfers - Control, Bulk, Interrupt, and Isochronous.
- A DRD (Dual-Role-Device - Host or Device) USB controller with the following features:
  - Compatible to the xHCI 1.0 specification in Host mode
  - Compatible with the USB 2.0 specification in Device mode
  - Supports 15 IN (Receive), 15 OUT (Transmit) endpoints (EPs), and one EP0 endpoint which is bidirectional
  - Internal DMA controller
  - Descriptor caching and data pre-fetching ensures high performance
  - Dynamic FIFO memory allocation for all endpoints
- Operation flexibility
  - Same programming model for HS, FS, and LS operation
  - Each controller instance can provide either USB Host or USB Device functionality

##### 12.3.2.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

#### 12.3.2.2 USB Environment

##### 12.3.2.2.1 USB Pin List

The names of the pins used by the USB2SS with descriptions are shown in [Table 12-174](#) and [Table 12-175](#).

**Table 12-174. USB Signal Pins Description**

| Pin Name | I/O <sup>(1)</sup> | Description                                             |
|----------|--------------------|---------------------------------------------------------|
| USBn_DP  | I/O                | USB 2.0 and 1.1 Specification-compliant signal pins.    |
| USBn_DM  | I/O                | They are HS/FS/LS bidirectional differential data pins. |

(1) I = Input, O = Output, A = Analog

**Table 12-175. USB Control, Configuration, and Monitor Signal Pins**

| Pin Name                 | I/O <sup>(1)</sup> | Description                                                                                                                                                                    |
|--------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| USBn_DRVVBUS             | O                  | An active-high digital output signal for VBUS power supply. Used to enable an external charge pump to supply +5V power to the VBUS receptacle when operating in USB Host mode. |
| USBn_VBUS <sup>(2)</sup> | A/I                | An analog input for monitoring the voltage on VBUS.                                                                                                                            |

**Table 12-175. USB Control, Configuration, and Monitor Signal Pins (continued)**

| Pin Name | I/O <sup>(1)</sup> | Description                                                                |
|----------|--------------------|----------------------------------------------------------------------------|
| USBn_ID  | I                  | USB operational mode identifier. This functionality is supported via GPIO. |

(1) I = Input, O = Output, A = Analog

(2) This pin is not 5V tolerant. Refer to the device-specific datasheet for implementation requirements.

#### 12.3.2.2 Typical Pin Connections of Device


**Figure 12-154. USB Dual-Role Connections**

## USB Host Only



Figure 12-155. USB Host-Only Connections

## USB Device Only



Figure 12-156. USB Device-Only Connections

### 12.3.2.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

### 12.3.2.4 Use Cases

This is a standard USB 2.0 module, and is optimized for following applications and systems:

- Portable electronic devices
- High-bandwidth applications

It supports all typical USB connections, and Table 12-176 shows some examples.

**Table 12-176. Typical Use Cases In Terms of Connections**

| Connectors (Receptacle) | Signals to Use   | SS | HS/F S | LS (Host only) | Comments                                                            |
|-------------------------|------------------|----|--------|----------------|---------------------------------------------------------------------|
| USB 2.0 Micro-AB        | DP, DM, VBUS, ID | N  | Y      | Y              | Support Host or Device operation, depending on state of the ID pin. |
| USB 2.0 Type-A          | DP, DM, VBUS     | N  | Y      | Y              | Support HS/FS/LS Host                                               |
| USB 2.0 Type-B          | DP, DM, VBUS     | N  | Y      | Y              | Only used for USB2.0 Device (no LS)                                 |

#### 12.3.2.4.1 USB Operational Mode Determination

| USB[n]_ID Pin | USB[n]_VBUS Pin <sup>(1)</sup> | USB Role      |
|---------------|--------------------------------|---------------|
| FLOAT         | FLOAT or GROUND                | INDETERMINATE |
| GROUND        | UNUSED                         | HOST          |
| FLOAT         | RAIL VOLTAGE                   | DEVICE        |

(1) PHY VBUS pin voltage is dependent on the divider circuit used on the board. Refer to the device datasheet for VBUS implementation requirements.

#### 12.3.2.4.2 VBUS Voltage Sourcing Control

When either of the USB controllers assumes the role of a host, the controller is required to supply 5V to an attached device through its VBUS line. In order to achieve this task, the USB controller requires the use of external power logic (or a charge pump) capable of sourcing 5V power. The USB\_DRVVBUS pin is used as a control signal to enable/disable this external power logic to either source or disable power on the VBUS line. The control on the USB\_DRVVBUS is handled by the controller based on host software programming. The control should be transparent to the user so long as the proper hardware connection and software initialization are in place. The USB controller drives the USB\_DRVVBUS signal high when it assumes the role of a host while the controller is in session. When assuming the role of a device, the controller drives the USB\_DRVVBUS signal low disabling the external charge pump/power logic; hence, no power is driven on the VBUS line (in this case, power is expected to be provided by the external host).

Note that both USB controllers are self-powered and the device does not rely on the voltage on the VBUS line sourced by an external host for controller operation when assuming the role of a device. The voltage present on the VBUS line is used to identify the presence of a Host. The USB PHY continually monitors the voltage on the VBUS and reports the status to USB controller.

#### 12.3.2.4.3 VBUS Detection

VBUS detection is supported by the USB2SS via the USB\_VBUS pin, but **it is important that this pin not be connected directly to the connector 5V or any other 5V source**. Instead, an external circuit must be used to ensure that the recommended operating conditions of the pin are not exceeded. Refer to the device datasheet for requirements and example VBUS-sense circuitry.

The PHY includes session valid and VBUS valid comparators and provides corresponding status signals.

The Controller uses the session valid output from the PHY in device mode. One of the reasons is because the USB specification requires that the DP pull-up (implemented inside the PHY) must be enabled only after VBUS is turned on by host. This PHY output also in general indicates that a connection is active from host and it can also be used to detect disconnects.

The USB2SS wrapper also includes logic to detect a change on session valid and VBUS valid outputs from PHY.

#### 12.3.2.4.4 Pull-up/Pull-down Resistors

As the USB controllers are dual role controllers, capable of assuming a role of a host or device, the required pull-up/pull-down resistors cannot exist external to the device. These pull-up/pulldown resistors exist internal to the device, within the PHY to be more specific, and are enabled or disabled based on the role the controller assumes allowing for dynamic hardware configuration. When assuming the role of a host, the data lines are

pulled low by the PHY enabling the internal 15KΩ resistors. When assuming the role of a device the required 1.5KΩ pull-up resistor on the D+ line is enabled automatically to signify the USB capability to the external host as a FS device (HS operation is negotiated during reset bus condition). Low-Speed Device functionality is not supported.

## 12.4 Memory Interfaces

This section describes the memory interfaces in the device.

### 12.4.1 Flash Subsystem (FSS)

This section describes the Flash Subsystem (FSS) in the device.

#### 12.4.1.1 FSS Overview

The Flash Subsystem (FSS) provides access to external Flash devices via Octal Serial Peripheral Interface (OSPI).

The FSS includes one OSPI. For more information, see *Octal Serial Peripheral Interface (OSPI)*.

Figure 12-157 shows the FSS overview.



Figure 12-157. FSS Overview

#### 12.4.1.1.1 FSS Features

For more information, see [Section 12.4.2.1.1, OSPI Features](#).

#### 12.4.1.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

#### Note

Some features may not be available. See *Module Integration* for more information.

#### 12.4.1.2 FSS Environment

The FSS is hereinafter also referred to as FSS0.

##### 12.4.1.2.1 FSS Typical Application

Figure 12-158 shows typical FSS application.



**Figure 12-158. FSS Typical Application**

Table 12-177 describes the FSS I/O signals.

**Table 12-177. FSS I/O Signals**

| FSS0 Interface | I/O Signals                                                                |
|----------------|----------------------------------------------------------------------------|
| FSS0_OSPI0     | For more information about OSPI I/O signals, see <i>OSPI I/O Signals</i> . |

---

**Note**

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

---

#### 12.4.1.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.4.1.4 FSS Functional Description

##### 12.4.1.4.1 FSS Block Diagram

Figure 12-159 shows the FSS block diagram.



**Figure 12-159. FSS Block Diagram**

##### FSS Blocks:

- CBASS0: The CBASS0 interconnect allows FSS to communicate with the device modules and subsystems.
- Data Interface: It is 64-bit data/32-bit address multi issue data interface with coherent in-band bypass. It provides accessibility to the FSS0\_OSPI0.
- Config Interface: It is used for configuration of the memory mapped registers within the FSS.
- Interface Clock and Reset:
  - For more information, see *FSS0 Clocks and Resets*.
  - For more information, see *FSS0\_OSPI Clocks and Resets*.
- Interrupts: For more information, see *FSS0\_OSPI Hardware Requests*.
- Memory Mapped Registers: This block includes the FSS registers. The configuration of these registers defines which FSS features are used. For more information, see *FSS Registers*.
- FSS0\_OSPI0: For more information about OSPI, please see *Octal Serial Peripheral Interface (OSPI)*.
- FSS0\_OSPI0 I/O Pins: For more information, see *OSPI I/O Signals*.

##### 12.4.1.4.2 FSS Regions

###### 12.4.1.4.2.1 FSS Regions Boot Size Configuration

The boot size for FSS defaults to 64 MB but can be configured to be 128 MB. Selection of boot block which will be used is also configurable. For more information see *CTRLMMR\_FSS\_CTRL* register in *Control Module (CTRL\_MMR)*.

#### 12.4.1.4.3 FSS Memory Regions

Table 12-178 shows the FSS memory regions.

**Table 12-178. FSS Memory Regions**

| Address Range             | Size   | Description                      |
|---------------------------|--------|----------------------------------|
| 0x400000000 - 0x4FFFFFFF  | 4 GB   | External Memory Space (Region 0) |
| 0x060000000 - 0x067FFFFFF | 128 MB | Boot Space (Region 1)            |
| 0x500000000 - 0x5FFFFFFF  | 4 GB   | External Memory Space (Region 3) |

#### 12.4.1.5 FSS Programming Guide

##### 12.4.1.5.1 FSS Initialization Sequence

Initialization steps:

- Configure the main boot parameters for FSS (see Section 12.4.1.4.2.1):
  - Select the boot block to be used.
  - Select the size of the boot block to be used.
- Enable FSS in PSC.
- Configure the FSS0\_OSPI0.
- Enable the FSS0\_OSPI0 in PSC. For more information about OSPI configuration, please see *Octal Serial Peripheral Interface (OSPI)*.

##### 12.4.1.5.2 FSS Power Up/Down Sequence

There are two PSC controls for the FSS: for FSS0 itself and for FSS0\_OSPI0. The CPU enables the FSS0\_OSPI0 before using the FSS. Software should ensure the FSS0\_OSPI0 is enabled prior to FSS transactions.

Normal Power Down Sequence:

- Block any new transaction.
- Power down the FSS0\_OSPI0.
- In the event when the FSS0\_OSPI0 is powered down, the FSS can then be powered down.

### 12.4.2 Octal Serial Peripheral Interface (OSPI)

This section describes the Octal Serial Peripheral Interface (OSPI) module for the device.

#### 12.4.2.1 OSPI Overview

The Octal Serial Peripheral Interface (OSPI) module is a kind of Serial Peripheral Interface (SPI) module which allows single, dual, quad or octal read and write access to external flash devices.

The OSPI module is used to transfer data, either in a memory mapped direct mode (for example a processor wishing to execute code directly from external flash memory), or in an indirect mode where the module is set-up to silently perform some requested operation, signaling its completion via interrupts or status registers. For indirect operations, data is transferred between system memory and external flash memory via an internal SRAM which is loaded for writes and unloaded for reads by a device controller at low latency system speeds. Interrupts or status registers are used to identify the specific times at which this SRAM should be accessed using user programmable configuration registers.

shows the OSPI allocation across device domains.

Figure 12-160 shows the OSPI module overview.



**Figure 12-160. OSPI Overview**

#### 12.4.2.1.1 OSPI Features

The OSPI module has the following features:

- Support for single, dual, quad (QSPI mode) or octal I/O instructions.
- Supports dual Quad-SPI mode for fast boot applications.
- Memory mapped 'direct' mode of operation for performing flash data transfers and executing code from flash memory.
- Software triggered 'indirect' mode of operation for performing low latency and non-processor intensive flash data transfers.
- Local SRAM of configurable size to reduce advanced high-performance bus overhead and buffer flash data during indirect transfers.
- Set of software advanced peripheral bus accessible flash control registers to perform any flash command, including data transfers up to 8-bytes at a time.
- Additional addressable memory bank to accommodate more than 8-bytes at a time.
- Support for XIP, sometimes referred to as continuous mode.
- Support for DDR Mode and DTR protocol (including Octal DDR protocol with DQS for Octal-SPI devices)
- Programmable device sizes.
- Programmable write protected regions to block system writes from taking effect.
- Programmable delays between transactions.
- Legacy mode allowing software direct access to low level transmit and receive FIFOs, bypassing the higher layer processes.
- An independent reference clock to decouple bus clock from SPI clock – allows slow system clocks.
- Programmable baud rate generator to generate OSPI clocks.
- Features included to improve high speed read data capture mechanism.
- Option to use adapted clocks or DQS to further improve read data capturing.
- Programmable interrupt generation.
- Up to four external device selects - OSPI and QSPI devices can be mixed
- Programmable data decoder, enables continuous addressing mode for each of the connected devices and auto-detection of boundaries between devices.
- Supports BOOT mode.
- Bidirectional CRC on Multiple-SPI interface.
- Handling ECC errors for flash devices with embedded correction engine.
- Full integration with PHY module dedicated to more flexible and power efficient transfers.
- Supports RESET\_OUT[1-0] and ECC\_FAIL pins for external flash devices where ECC is checked on the flash.

#### 12.4.2.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

##### Note

Some features may not be available. See *Module Integration* for more information.

---

#### 12.4.2.2 OSPI Environment

The FSS0\_OSPI0 module is hereinafter referred to as OSPI module.

This section describes the OSPI external connections (environment).

The OSPI module is primarily intended for fast booting from Octal- and Quad-SPI flash memories. [Figure 12-161](#) shows a typical connection of the OSPI module to an external Octal-SPI flash memory.



**Figure 12-161. OSPI Connected to an External Octal-SPI Flash Memory**

[Table 12-179](#) lists and describes the FSS0\_OSPI I/O signals.

**Table 12-179. OSPI I/O Signals**

| Module Pin                     | Device Level Signal       | I/O <sup>(1)</sup> | Description                                                         | Module Pin<br>Reset Value <sup>(2)</sup> |
|--------------------------------|---------------------------|--------------------|---------------------------------------------------------------------|------------------------------------------|
| <b>FSS0_OSPI<sup>(4)</sup></b> |                           |                    |                                                                     |                                          |
| DQ0                            | OSPI <sup>(4)</sup> _D0   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 0                        | HiZ                                      |
| DQ1                            | OSPI <sup>(4)</sup> _D1   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 1                        | HiZ                                      |
| DQ2                            | OSPI <sup>(4)</sup> _D2   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 2                        | HiZ                                      |
| DQ3                            | OSPI <sup>(4)</sup> _D3   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 3                        | HiZ                                      |
| DQ4                            | OSPI <sup>(4)</sup> _D4   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 4                        | HiZ                                      |
| DQ5                            | OSPI <sup>(4)</sup> _D5   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 5                        | HiZ                                      |
| DQ6                            | OSPI <sup>(4)</sup> _D6   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 6                        | HiZ                                      |
| DQ7                            | OSPI <sup>(4)</sup> _D7   | IO                 | FSS0_OSPI <sup>(4)</sup> data input/output 7                        | HiZ                                      |
| N_SS_OUT0                      | OSPI <sup>(4)</sup> _CSn0 | O                  | FSS0_OSPI <sup>(4)</sup> external flash device chip select 0        | 0x1                                      |
| N_SS_OUT1                      | OSPI <sup>(4)</sup> _CSn1 | O                  | FSS0_OSPI <sup>(4)</sup> external flash device chip select 1        | 0x1                                      |
| N_SS_OUT2                      | OSPI <sup>(4)</sup> _CSn2 | O                  | FSS0_OSPI <sup>(4)</sup> external flash device chip select 2        | 0x1                                      |
| N_SS_OUT3                      | OSPI <sup>(4)</sup> _CSn3 | O                  | FSS0_OSPI <sup>(4)</sup> external flash device chip select 3        | 0x1                                      |
| OCLK                           | OSPI <sup>(4)</sup> _CLK  | O                  | FSS0_OSPI <sup>(4)</sup> clock output for the external flash device | 0x0                                      |
|                                | OSPI0_LBCLK0              | O                  | FSS0_OSPI <sup>(4)</sup> external loopback output                   | 0x0                                      |

Table 12-179. OSPI I/O Signals (continued)

| Module Pin | Device Level Signal             | I/O <sup>(1)</sup> | Description                                                           | Module Pin<br>Reset Value <sup>(2)</sup> |
|------------|---------------------------------|--------------------|-----------------------------------------------------------------------|------------------------------------------|
| DQS        | OSPI <sup>(4)</sup> _DQS        | I <sup>(3)</sup>   | FSS0_OSPI <sup>(4)</sup> data strobe / external loopback input        | Don't care                               |
| RESET_OUT0 | OSPI <sup>(4)</sup> _RESET_OUT0 | O                  | FSS0_OSPI <sup>(4)</sup> reset output 0 for the external flash device | 0x1                                      |
| RESET_OUT1 | OSPI <sup>(4)</sup> _RESET_OUT1 | O                  | FSS0_OSPI <sup>(4)</sup> reset output 1 for the external flash device | 0x1                                      |
| ECC_FAIL   | OSPI <sup>(4)</sup> _ECC_FAIL   | I                  | FSS0_OSPI <sup>(4)</sup> ECC status from the external flash device    | 0x1                                      |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) When used as an external loopback input, the DQS signal can alternatively be referred to as LBCLKI. The LBCLKI clock input signal is a looped back version of the LBCLKO clock output signal and facilitates easier timing closure at higher speeds. The loopback has to be at board level in order to support higher OSPI speeds. The source of the loopback clock is defined by CTRLMMR MCU\_OSPIn\_CLKSEL[4] LOOPCLK\_SEL bit in *Control Module (CTRL\_MMR)*.

(4) i represents an OSPI instance. See the device datasheet for available domains and OSPI instances.

Table 12-180 describes the OSPI I/O connectivity to external SPI devices.

Table 12-180. OSPI I/O Connectivity to External SPI Devices

| Module Pin | I/O <sup>(1)</sup> | Description                                                                              |                                                                                   |                                                                                   |                                                                                     |
|------------|--------------------|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
|            |                    | 4-pin <sup>(1)</sup> SPI - Single Read/Write (SIO)<br>(DATA_XFER_TYPE_E XT_MODE_FLD=0x0) | 4-pin <sup>(1)</sup> SPI - Dual Read/ Write<br>(DATA_XFER_TYPE_EXT_ MODE_FLD=0x1) | 6-pin <sup>(1)</sup> SPI - Quad Read/ Write<br>(DATA_XFER_TYPE_EXT_ MODE_FLD=0x2) | 11-pin <sup>(1)</sup> SPI - Octal Read/ Write<br>(DATA_XFER_TYPE_EXT_ MODE_FLD=0x3) |
| DQ0        | IO                 | Used as SPI data output                                                                  | Used as SPI data input 0<br>Used as SPI data output 0                             | Used as SPI data input 0<br>Used as SPI data output 0                             | Used as SPI data input 0<br>Used as SPI data output 0                               |
| DQ1        | IO                 | Used as SPI data input                                                                   | Used as SPI data input 1<br>Used as SPI data output 1                             | Used as SPI data input 1<br>Used as SPI data output 1                             | Used as SPI data input 1<br>Used as SPI data output 1                               |
| DQ2        | IO                 | Not used                                                                                 | Not used                                                                          | Used as SPI data input 2<br>Used as SPI data output 2                             | Used as SPI data input 2<br>Used as SPI data output 2                               |
| DQ3        | IO                 | Not used                                                                                 | Not used                                                                          | Used as SPI data input 3<br>Used as SPI data output 3                             | Used as SPI data input 3<br>Used as SPI data output 3                               |
| DQ4        | IO                 | Not used                                                                                 | Not used                                                                          | Not used                                                                          | Used as SPI data input 4<br>Used as SPI data output 4                               |
| DQ5        | IO                 | Not used                                                                                 | Not used                                                                          | Not used                                                                          | Used as SPI data input 5<br>Used as SPI data output 5                               |
| DQ6        | IO                 | Not used                                                                                 | Not used                                                                          | Not used                                                                          | Used as SPI data input 6<br>Used as SPI data output 6                               |
| DQ7        | IO                 | Not used                                                                                 | Not used                                                                          | Not used                                                                          | Used as SPI data input 7<br>Used as SPI data output 7                               |
| DQS        | I <sup>(2)</sup>   | Not used                                                                                 | Not used                                                                          | Not used                                                                          | Data strobe or loopback clock input                                                 |
| OCLK       | O                  | Output clock or loopback clock output. For more information, see Table 12-179.           |                                                                                   |                                                                                   |                                                                                     |
| N_SS_OUT0  | O                  | External SPI device chip-select 0                                                        |                                                                                   |                                                                                   |                                                                                     |
| N_SS_OUT1  | O                  | External SPI device chip-select 1                                                        |                                                                                   |                                                                                   |                                                                                     |
| N_SS_OUT2  | O                  | External SPI device chip-select 2                                                        |                                                                                   |                                                                                   |                                                                                     |
| N_SS_OUT3  | O                  | External SPI device chip-select 3                                                        |                                                                                   |                                                                                   |                                                                                     |
| RESET_OUT0 | O                  | External SPI device reset 0                                                              |                                                                                   |                                                                                   |                                                                                     |
| RESET_OUT1 | O                  | External SPI device reset 1                                                              |                                                                                   |                                                                                   |                                                                                     |
| ECC_FAIL   | I                  | External SPI device ECC failure indication                                               |                                                                                   |                                                                                   |                                                                                     |

(1) This is the pin count at the external SPI flash memory side.

(2) When used as an external loopback input, the DQS signal can alternatively be referred to as LBCLKI. The LBCLKI clock input signal is a looped back version of the LBCLKO clock output signal and facilitates easier timing closure at higher speeds. The loopback has to be at board level in order to support higher OSPI speeds. The source of the loopback clock is defined by CTRLMMR MCU\_OSPIn\_CLKSEL[4] LOOPCLK\_SEL bit in *Control Module (CTRL\_MMR)*.

---

**Note**

For OSPI0\_CLK, OSPI0\_LBCLK0, and OSPI0\_DQS signals to work properly, the RXACTIVE bit of the appropriate registers should be set to 0x1 because of retiming purposes.

---

**Note**

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

---

**12.4.2.3 Integration**

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.4.2.4 OSPI Functional Description

##### 12.4.2.4.1 OSPI Block Diagram

Figure 12-162 shows the OSPI module block diagram.



**Figure 12-162. OSPI Block Diagram**

The OSPI module is composed of three main blocks. The first one is the OSPI controller, the second one is the low level SPI protocol controller, and the third one is the integrated PHY.

The OSPI module has the following two target interfaces:

- Data target interface intended for data transfer.
- Configuration target interface intended for accessing the programmable set of registers.

##### 12.4.2.4.1.1 Data Target Interface

The data interface is used for data transfer to external flash devices in direct and indirect mode of operation. The data target controller validates incoming data accesses, responds to invalid requests, performs any required byte and halfword reordering, blocks writes that violate the programmed write protection rules (only for direct access) and forwards the transfer request to either the direct access controller (DAC) or the indirect access controller (INDAC).

The data interface bus is 32-bits wide. Therefore only byte, halfword and word accesses are permitted. When the controller is configured to work in SPI Octal DDR Mode or Octal DDR Protocol (where 2 bytes are collected within single SPI clock cycle what exceeds the size of 1 byte transfer request), 8 bit transfer size is not allowed.

##### Note

Cache line wrap accesses over the data target port should be word aligned.

Data target port doesn't support cache line wrap bursts of 128 bytes.

#### 12.4.2.4.1.2 Configuration Target Interface

The configuration interface is used to configure the OSPI module and perform software controlled flash accesses using the OSPI\_FLASH\_CMD\_CTRL\_REG register (for more information refer to [Section 12.4.2.4.11, Software Triggered Instruction Generator \(STIG\)](#)). Depending on the address it routes the incoming interconnect transfer to the Low level SPI protocol controller or to the ECC aggregator. The configuration port is also used to interact with the OSPI configuration and SRAM ECC registers.

---

##### Note

The configuration interface supports only 32-bit accesses. For single byte or halfword manipulations software should perform read-modify-write operations.

#### 12.4.2.4.1.3 OSPI Clock Domains

The OSPI module has two main clock sources for the Octal-SPI controller.

- For interface clocks
- For reference clock

The source for the interface clocks corresponds to the configuration and data buses. The data bus clock (OSPI\_HCLK) is the main system clock used to transfer data over the data bus between a controller on the system interconnect and the OSPI module. The data bus clock also drives the internal OSPI SRAM. The configuration bus clock (OSPI\_PCLK) is used to access the OSPI configuration register and perform basic configuration and for interrupt handling. The OSPI reference clock (OSPI\_RCLK) drives the SPI transmit and receive logic in the OSPI module. It is also used to generate the output SPI protocol clock (OSPI\_OCLK) and for oversampling of the input data. Using the reference clock (OSPI\_RCLK) allows the OSPI module to decouple the frequency of the SPI flash device from the device system clocks, thereby providing more flexible clocking solution.

---

##### Note

There is no particular clock ratio requirement between configuration (OSPI\_PCLK) and data bus (OSPI\_HCLK) clocks.

#### 12.4.2.4.2 OSPI Modes

---

##### Note

Some of the OSPI features described in this section may not be supported on this family of devices. For more information, see [OSPI Not Supported Features](#).

The OSPI module supports four SPI modes. These modes are defined through the OSPI\_CONFIG\_REG[1] SEL\_CLK\_POL\_FLD and OSPI\_CONFIG\_REG[2] SEL\_CLK\_PHASE\_FLD bits. The SEL\_CLK\_POL\_FLD bit defines the clock polarity and the SEL\_CLK\_PHASE\_FLD bit defines the data launch and data capture relation to the OSPI clock edges. [Table 12-181](#) gives a brief description of these modes.

**Table 12-181. OSPI Modes**

| SPI Mode | SEL_CLK_POL_FLD | SEL_CLK_PHASE_FLD | Description                           |
|----------|-----------------|-------------------|---------------------------------------|
| 0        | 0               | 0                 | Clock inactive state: low             |
|          |                 |                   | Data launch edge: clock falling edge  |
|          |                 |                   | Data capture edge: clock rising edge  |
| 1        | 0               | 1                 | Clock inactive state: low             |
|          |                 |                   | Data launch edge: clock rising edge   |
|          |                 |                   | Data capture edge: clock falling edge |

Table 12-181. OSPI Modes (continued)

| SPI Mode | SEL_CLK_POL_FLD | SEL_CLK_PHASE_FLD | Description                                                                                                |
|----------|-----------------|-------------------|------------------------------------------------------------------------------------------------------------|
| 2        | 1               | 0                 | Clock inactive state: high<br>Data launch edge: clock rising edge<br>Data capture edge: clock falling edge |
| 3        | 1               | 1                 | Clock inactive state: high<br>Data launch edge: clock falling edge<br>Data capture edge: clock rising edge |

Octal flash devices provide DQS signal which allows source synchronous capture, but for Quad flash devices the OSPI module has a loopback mode. In this loopback mode the clock, looped back at board level, is used for registering the input data, and the edge used is same as the launch edge, thus giving a full cycle path (for more information, see [Section 12.4.2.4.2.1, Read Data Capture](#)).

#### 12.4.2.4.2.1 Read Data Capture

Figure 12-163 shows the Read Data Capture Logic in the OSPI module.



Figure 12-163. Read Data Capture Logic

The PHY module includes a DLL which allows adjustment of the sampling edge with respect to the incoming data to achieve maximum frequency. There are three sources for the sampling signal:

- The reference clock
- Output SPI clock external loopback
- The DQS (only available in Octal Flash devices)

The loopback mode (only for Quad flash devices) can work in two cases. The first one is when OSPI\_CONFIG\_REG[2] SEL\_CLK\_PHASE\_FLD=0. When SEL\_CLK\_PHASE\_FLD=1 there aren't enough clock falling edges for the register pipeline to catch the last data driven, thus causing a functional failure. Additionally, since the capture edge is falling edge, it gives a full cycle input path only in SPI mode 0, that is when

SEL\_CLK\_POL\_FLD=0 and SEL\_CLK\_PHASE\_FLD=0. Thus SPI mode 0 is the first of two modes that support high MHz operation (greater than 50 MHz). The second mode is when SEL\_CLK\_PHASE\_FLD=1 and SEL\_CLK\_PHASE\_FLD=1 (SPI mode 3). In this case the missing clock falling edge is compensated inside the OSPI controller when using the incorporated PHY module by inverting the loopback clock.

The loopback mode is enabled by writing 0x0 to OSPI\_RD\_DATA\_CAPTURE\_REG[0] BYPASS\_FLD. The taps are selected by programming OSPI\_RD\_DATA\_CAPTURE\_REG[4-1] DELAY\_FLD field. The taps delay the read data capturing logic by the programmed number of OSPI\_RCLK cycles.

#### **12.4.2.4.2.1.1 Mechanisms of Data Capturing**

There are two mechanisms of data capturing in the OSPI module. They can be combined in some parts to ensure reliable sampling solution independent on the system requirements and the controller configuration. The mechanisms are as follows:

- Data capturing mechanism using taps
- Data capturing mechanism using PHY module.

#### **12.4.2.4.2.1.2 Data Capturing Mechanism Using Taps**

This section describes the data capturing mechanism where sampling point is adjusted for one of the reference clock edges inside divided OSPI clock.

After POR, the adapted loopback clock circuit and the OSPI\_RCLK delay register line both wake in a disabled state. The OSPI\_RD\_DATA\_CAPTURE\_REG register provides the control for the mechanism using taps.

OSPI\_RD\_DATA\_CAPTURE\_REG[5] SAMPLE\_EDGE\_SEL\_FLD bit selects the edge of the reference clock, on which data outputs from flash memory are sampled.

OSPI\_RD\_DATA\_CAPTURE\_REG[4-1] DELAY\_FLD bit field controls the additional number of read data capture cycles (this is the fast reference clock, running at least x4 of the device clock) that should be applied to the internal read data capture circuit. The large clock-to-out delay of the flash memory together with trace delays as well as other device delays may impose a maximum flash clock frequency which is less than the flash memory device itself can operate at. To compensate, software shall set this register to a value that guarantees robust data captures.

#### **12.4.2.4.2.1.3 Data Capturing Mechanism Using PHY Module**

PHY module is responsible for data capturing. More detailed description of all internal PHY sampling mechanisms is included in [Section 12.4.2.4.16.2, Read Data Capturing by the PHY Module](#).

#### **12.4.2.4.2.1.4 External Pull Down on DQS**

Per the OSPI protocol, the FLASH device drives DQS while CS is asserted. When CS is not asserted the FLASH device presents HiZ on DQS. When configured to use DQS, the controller uses the DQS as a clock, which samples the incoming data into a FIFO. Noise on the DQS when it is HiZ can cause spurious false triggering of the FIFO and filling it with invalid data. There is no way to clear this data except to reset the OSPI module.

To avoid this issue, it is recommended to add a pull down on the DQS line.

During device wakeup, before the IO ring is configured properly, the CS to the FLASH device is HiZ. Depending on the actual level of the CS line the FLASH device might drive the DQS High, Low or HiZ. A pull down on DQS forces the DQS input to Low, but the DQS might still be High or in the presence of noise there might be transitions between Low and High. This again can cause the same issue of capturing garbage data in the Controller FIFO.

To avoid this issue it is recommended to release the OSPI from reset only after the IO ring is configured properly.

#### 12.4.2.4.3 OSPI Power Management

---

##### Note

The OSPI module does not provide any hardware signal for busy or idle status. Software need to ensure that the OSPI module is idle before clocks can be shut off by reading the OSPI\_CONFIG\_REG[31] IDLE\_FLD bit.

---

OSPI\_PCLK and OSPI\_HCLK share the same clock stop request/acknowledge and clock enable/acknowledge interface.

#### 12.4.2.4.4 Auto HW Polling

The OSPI controller is capable of automatically testing the Flash device busy bit to guarantee no reads or writes are ignored by the flash when it is busy burning in programmed data.

At the end of a programming transaction, the Flash device goes into a burn-in state and becomes busy.

When Auto HW Polling is enabled, the OSPI controller keeps track of programming transactions and will initiate a Flash status read polling transactions automatically, until Flash indicates it is not busy, before any additional data read or programming operations are sent to the flash device. See OSPI\_WRITE\_COMPLETION\_CTRL\_REG register and the associated registers.

The OSPI controller requires that the OSPI\_WRITE\_COMPLETION\_CTRL\_REG[23-16] POLL\_COUNT\_FLD field should always be set with values greater or equal to 3 ( $\geq 3$ ).

#### 12.4.2.4.5 Flash Reset

OSPI provides Flash reset out ports. These ports are active low and controlled thru OSPI\_CONFIG\_REG register.

#### 12.4.2.4.6 OSPI Memory Regions

---

##### Note

For more information about the memory space, see *FSS Memory Regions*.

---

#### 12.4.2.4.7 OSPI Interrupt Requests

The OSPI module generates three interrupts. The ECC interrupts (FSS0\_OSPI\_0\_OSPI\_ECC\_CORR\_LVL\_INTR\_0 and FSS0\_OSPI\_0\_OSPI\_ECC\_UNCORR\_LVL\_INTR\_0) are generated by the OSPI ECC aggregator.

The other interrupt (FSS0\_OSPI\_0\_OSPI\_LVL\_INTR\_0) is generated by the OSPI module.

Table 12-182 lists the event flags and the corresponding mask bits of the sources which can cause interrupts.

**Table 12-182. OSPI Events**

| Event Flag                                               | Event Mask                                                  | Description                                        |
|----------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------|
| OSPI_IRQ_STATUS_REG[0]<br>MODE_M_FAIL_FLD                | OSPI_IRQ_MASK_REG[0]<br>MODE_M_FAIL_MASK_FLD                | Event Flag and Event Mask for the OSPI Interrupts. |
| OSPI_IRQ_STATUS_REG[1]<br>UNDERFLOW_DET_FLD              | OSPI_IRQ_MASK_REG[1]<br>UNDERFLOW_DET_MASK_FLD              |                                                    |
| OSPI_IRQ_STATUS_REG[2]<br>INDIRECT_OP_DONE_FLD           | OSPI_IRQ_MASK_REG[2]<br>INDIRECT_OP_DONE_MASK_FLD           |                                                    |
| OSPI_IRQ_STATUS_REG[3]<br>INDIRECT_READ_REJECT_FLD       | OSPI_IRQ_MASK_REG[3]<br>INDIRECT_READ_REJECT_MASK_FLD       |                                                    |
| OSPI_IRQ_STATUS_REG[4]<br>PROT_WR_ATTEMPT_FLD            | OSPI_IRQ_MASK_REG[4]<br>PROT_WR_ATTEMPT_MASK_FLD            |                                                    |
| OSPI_IRQ_STATUS_REG[5]<br>ILLEGAL_ACCESS_DET_FLD         | OSPI_IRQ_MASK_REG[5]<br>ILLEGAL_ACCESS_DET_MASK_FLD         |                                                    |
| OSPI_IRQ_STATUS_REG[6]<br>INDIRECT_XFER_LEVEL_BREACH_FLD | OSPI_IRQ_MASK_REG[6]<br>INDIRECT_XFER_LEVEL_BREACH_MASK_FLD |                                                    |
| OSPI_IRQ_STATUS_REG[7]<br>RECV_OVERFLOW_FLD              | OSPI_IRQ_MASK_REG[7]<br>RECV_OVERFLOW_MASK_FLD              |                                                    |
| OSPI_IRQ_STATUS_REG[8]<br>TX_FIFO_NOT_FULL_FLD           | OSPI_IRQ_MASK_REG[8]<br>TX_FIFO_NOT_FULL_MASK_FLD           |                                                    |
| OSPI_IRQ_STATUS_REG[9]<br>TX_FIFO_FULL_FLD               | OSPI_IRQ_MASK_REG[9]<br>TX_FIFO_FULL_MASK_FLD               |                                                    |
| OSPI_IRQ_STATUS_REG[10]<br>RX_FIFO_NOT_EMPTY_FLD         | OSPI_IRQ_MASK_REG[10]<br>RX_FIFO_NOT_EMPTY_MASK_FLD         |                                                    |
| OSPI_IRQ_STATUS_REG[11]<br>RX_FIFO_FULL_FLD              | OSPI_IRQ_MASK_REG[11]<br>RX_FIFO_FULL_MASK_FLD              |                                                    |
| OSPI_IRQ_STATUS_REG[12]<br>INDRD_SRAM_FULL_FLD           | OSPI_IRQ_MASK_REG[12]<br>INDRD_SRAM_FULL_MASK_FLD           |                                                    |
| OSPI_IRQ_STATUS_REG[13]<br>POLL_EXP_INT_FLD              | OSPI_IRQ_MASK_REG[13]<br>POLL_EXP_INT_MASK_FLD              |                                                    |
| OSPI_IRQ_STATUS_REG[14]<br>STIG_REQ_INT_FLD              | OSPI_IRQ_MASK_REG[14]<br>STIG_REQ_MASK_FLD                  |                                                    |
| OSPI_IRQ_STATUS_REG[16]<br>RX_CRC_DATA_ERR_FLD           | OSPI_IRQ_MASK_REG[16]<br>RX_CRC_DATA_ERR_MASK_FLD           |                                                    |
| OSPI_IRQ_STATUS_REG[17]<br>RX_CRC_DATA_VAL_FLD           | OSPI_IRQ_MASK_REG[17]<br>RX_CRC_DATA_VAL_MASK_FLD           |                                                    |
| OSPI_IRQ_STATUS_REG[18]<br>TX_CRC_CHUNK_BRK_FLD          | OSPI_IRQ_MASK_REG[18]<br>TX_CRC_CHUNK_BRK_MASK_FLD          |                                                    |
| OSPI_IRQ_STATUS_REG[19]<br>ECC_FAIL_FLD                  | OSPI_IRQ_MASK_REG[19]<br>ECC_FAIL_MASK_FLD                  |                                                    |

Table 12-182. OSPI Events (continued)

| Event Flag                               | Event Mask                                                                                               | Description                                       |
|------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| OSPI_ECC_SEC_STATUS_REG0[0]<br>SRAM_PEND | OSPI_ECC_SEC_ENABLE_SET_REG0[0]<br>SRAM_ENABLE_SET<br>OSPI_ECC_SEC_ENABLE_CLR_REG0[0]<br>SRAM_ENABLE_CLR | Event Flag and Event Mask for the ECC Interrupts. |
| OSPI_ECCDED_STATUS_REG0[0]<br>SRAM_PEND  | OSPI_ECCDED_ENABLE_SET_REG0[0]<br>SRAM_ENABLE_SET<br>OSPI_ECCDED_ENABLE_CLR_REG0[0]<br>SRAM_ENABLE_CLR   |                                                   |
| OSPI_ECC_AGGR_STATUS_SET[1-0]<br>PARITY  | OSPI_ECC_AGGR_ENABLE_SET[0]<br>PARITY                                                                    |                                                   |
| OSPI_ECC_AGGR_STATUS_SET[3-2]<br>TIMEOUT | OSPI_ECC_AGGR_ENABLE_SET[1]<br>TIMEOUT                                                                   |                                                   |
| OSPI_ECC_AGGR_STATUS_CLR[1-0]<br>PARITY  | OSPI_ECC_AGGR_ENABLE_CLR[0]<br>PARITY                                                                    |                                                   |
| OSPI_ECC_AGGR_STATUS_CLR[3-2]<br>TIMEOUT | OSPI_ECC_AGGR_ENABLE_CLR[1]<br>TIMEOUT                                                                   |                                                   |

#### 12.4.2.4.8 OSPI Data Interface

##### 12.4.2.4.8.1 Data Interface Address Remapping

The incoming data interface address, by default, maps directly to the address sent serially to the FLASH device. If the FLASH device has a 24-bit address, then the 24 LSB's of the data address is forwarded. A remap feature is available to remap all incoming data addresses to ADDRESS + N, where N is the value stored in the OSPI\_REMAP\_ADDR\_REG[31-0] VALUE\_FLD bit field. It is enabled via the OSPI\_CONFIG\_REG[16] ENB\_AHB\_ADDR\_REMAP\_FLD bit. This feature could be used when software needs to move boot code to another FLASH region.

##### 12.4.2.4.8.2 Write Protection

In order to protect the FLASH device, a software controlled write protection feature is supported. Any data write detected (by using DAC), pointing to an area of the FLASH that is protected, is not permitted.

A programmable region of the FLASH device, defined as a number of FLASH 'blocks' starting from a particular block number can be protected. Three programmable registers are provided. The first OSPI\_LOWER\_WR\_PROT\_REG register defines the FLASH block that is located at the bottom of the region to be protected. The second OSPI\_UPPER\_WR\_PROT\_REG register defines the FLASH block that is located at the top of the region to be protected. The third OSPI\_WR\_PROT\_CTRL\_REG register is a control register consisting of 2 bits. The OSPI\_WR\_PROT\_CTRL\_REG[0] INV\_FLD bit allows software to invert the region that is being protected, causing the programmed region to become the only areas of FLASH memory that is not protected from writes. The OSPI\_WR\_PROT\_CTRL\_REG[1] ENB\_FLD bit is the write protection enable bit. When this bit is set to 0, the FLASH device is unprotected.

For implementation, the data interface must map the incoming address into its associated FLASH block. A block can be between 1 and 65 KB, programmed via the OSPI\_DEV\_SIZE\_CONFIG\_REG register.

##### 12.4.2.4.8.3 Access Forwarding

For legal accesses, the data interface will forward all accesses to one of two access controllers - the direct access and the indirect access controllers. Assuming DAC has been enabled via the OSPI\_CONFIG\_REG[7] ENB\_DIR\_ACC\_CTRL\_FLD bit, then by default all accesses will be forwarded to this controller. Before any accesses can be forwarded to INDAC, it must first be configured by software. This process is fully explained in [Section 12.4.2.4.10, Indirect Controller \(INDAC\)](#). If DAC is disabled, any incoming access that cannot be

forwarded to INDAC will be completed immediately with an error. If DAC is enabled, the same access will be forwarded and serviced by DAC.

#### **12.4.2.4.9 OSPI Direct Access Controller (DAC)**

Direct access refers to the operation where data interface accesses directly trigger a read or write to FLASH memory. It is memory mapped and can be used to both access and directly execute code from external FLASH memory. Any incoming access that is not recognized as being within the programmable indirect trigger region is assumed to be a direct access and will be serviced by the DAC. Note that accesses that use DAC do not use the embedded SRAM. The data transfer stops when read or write burst is carried out. The amount of wait states applied will be dependent on the latency through the controller. Latency is kept to a minimum when the use of XIP read instructions are enabled (see OSPI\_CONFIG\_REG[18] ENTER\_XIP\_MODE\_IMM\_FLD and OSPI\_CONFIG\_REG[17] ENTER\_XIP\_MODE\_FLD bits).

#### **12.4.2.4.10 OSPI Indirect Access Controller (INDAC)**

##### **12.4.2.4.10.1 Indirect Read Controller**

The aim of the indirect mode of operation is to read significant numbers of bytes from FLASH memory without requiring a data interface access to trigger it. Instead indirect operations are controlled and triggered by software via specific control/configuration Indirect Read Transfer registers (OSPI\_INDIRECT\_READ\_XFER\_CTRL\_REG, OSPI\_INDIRECT\_READ\_XFER\_WATERMARK\_REG, OSPI\_INDIRECT\_READ\_XFER\_START\_REG, and OSPI\_INDIRECT\_READ\_XFER\_NUM\_BYTES\_REG). This block will communicate with an embedded low level SPI protocol state machine module to perform an efficient and optimized FLASH read burst, placing the read data into the local SRAM module ready for fast and low latency delivery to any external controller.

By default, the Indirect Read controller is disabled. Before enabling it, software must configure how much data is required and the start address. The start address and total number of bytes to be fetched is defined in OSPI\_INDIRECT\_READ\_XFER\_START\_REG and OSPI\_INDIRECT\_READ\_XFER\_NUM\_BYTES\_REG registers, respectively. Up to two indirect operations can be programmed at any one time. The second operation can be triggered while the first is in progress. Supporting two indirect operations allows a short turnaround time between the completion of one indirect operation and the start of the second. For more information refer to [Section 12.4.2.4.10.3, Indirect Access Queuing](#).

The total number of bytes to read in an indirect operation is not limited by the size of the SRAM. The size of SRAM will only limit the size of requests. In the case of SRAM overrun, the controller will back pressure FLASH reads until space becomes available in the SRAM. Back pressuring the reads on the SPI interface is handled by completing any current read burst, waiting until space in the SRAM becomes available and then issuing a new read burst at the address where the previous terminated burst ended.

An external controller will be able to fetch the data that the controller has read from external FLASH memory by issuing data interface reads to the OSPI module. The address of the incoming read access must be in the range of indirect trigger address programmed via the OSPI\_IND\_AHB\_ADDR\_TRIGGER\_REG register to indirect trigger address + 2\*\*<sup>(indirect trigger address range)</sup> - 1. Default value of the range is equal to 16 locations. This allows a 16-beat burst to be applied starting from the indirect trigger address. The smaller bursts are possible to handle effectively as well with this approach. Furthermore it is not strict requirement to push consecutive address sequence. Actual address just has to be in the indirect range to grant SRAM as source. Each valid Indirect Read will cause the internal SRAM to be popped, thereby decoupling the incoming read access address from the FLASH address – that is not direct mapped. Therefore the indirect trigger address does not have any relationship with the FLASH address. It is just to indicate that data should take the SRAM as source instead of the FLASH memory array after triggering of any valid Indirect Read. The FLASH address for Indirect Read is taken from the OSPI\_INDIRECT\_READ\_XFER\_START\_REG register. Assuming the requested data is present in the SRAM at the point the data interface access is received by the OSPI module, then the data will be fetched from the SRAM and the response to the read burst will be achieved with minimum latency. Once the data has been read from the SRAM, the OSPI module will free up the associated resource in the SRAM.

If a read access is received whose address is not within the range described above then that access will not be completed using the indirect controller. It will instead be serviced by the direct access controller.

If a read access is received whose address is within the range described above but the requested data is not immediately present in the SRAM then wait states will be applied until the data has been read from FLASH and pushed to the SRAM.

If a read burst is received whose access elements traverse the Indirect trigger range, then the accesses within the Indirect trigger range will be processed by the indirect controller and the rest will be taken by the direct access controller. This is likely to be a software configuration error.

The external controller is only permitted to issue 32-bit data interface reads until the last word of an indirect transfer. This helps keep the SRAM control logic less complex. On the final read, the external controller may issue a 16-bit (Halfword) or byte access to complete the transfer. It is also permitted for the external controller to always issue a 32-bit Word read on the last indirect access. The controller will pad the upper bits of the response with zero. The current expectation is that the SRAM will be kept fairly full while the read operation is carried out. The fill level of the SRAM is directly readable by software reading the OSPI\_SRAM\_FILL\_REG register.

An indirect operation may be cancelled at any time by setting 1 to OSPI\_INDIRECT\_READ\_XFER\_CTRL\_REG[1] CANCEL\_FLD bit.

Any bus controller should be allowed to initiate an indirect access. The OSPI module provide software access mechanism to the SRAM fill-level directly via configuration registers and then decide for itself when the data should be fetched from the local SRAM. The fill level watermark register (see OSPI\_INDIRECT\_READ\_XFER\_WATERMARK\_REG register) is provided. When the SRAM fill level passes this watermark, an interrupt is generated. If the watermark value is > 0, the watermark interrupt is also generated when the final byte of data has been read by the OSPI module and placed in the SRAM, even if the actual SRAM fill level has not risen above the watermark. This last feature is useful to avoid software tracking how much data has been read and resetting the watermark value for the last few bytes of an indirect read transfer.

Two further interrupt sources are provided to help understand the status of an indirect operation. Firstly, an interrupt is generated when an indirect operation has completed. Secondly, an interrupt is generated if an Indirect Read operation was requested but could not be accepted due to the fact 2 indirect operations have already been buffered by the OSPI module.

Setting the OSPI\_INDIRECT\_READ\_XFER\_CTRL\_REG[0] START\_FLD bit starts an indirect read operation. OSPI\_INDIRECT\_READ\_XFER\_CTRL\_REG[2] RD\_STATUS\_FLD bit is available to check the status.

#### **12.4.2.4.10.1.1 Indirect Read Transfer Process**

The following sequence can be followed:

1. Setup OSPI\_CONFIG\_REG register.
2. Setup the indirect transfer's FLASH start address in the OSPI\_INDIRECT\_READ\_XFER\_START\_REG register.
3. Setup the number of bytes to be transferred in the OSPI\_INDIRECT\_READ\_XFER\_NUM\_BYTES\_REG register.
4. Setup the indirect transfer's trigger address in the OSPI\_IND\_AHB\_ADDR\_TRIGGER\_REG register.
5. Setup the indirect transfer's trigger address range in the OSPI\_INDIRECT\_TRIGGER\_ADDR\_RANGE\_REG register.
6. If the watermark interrupt feature is to be used, set the OSPI\_INDIRECT\_READ\_XFER\_WATERMARK\_REG register which will cause an interrupt to be generated when the fill level increases beyond the watermark level. Setting the watermark can be useful indication to software when to read the next part of the indirect read transfer. Note that if the watermark is set to a value other than zero, the watermark interrupt will always trigger once the final byte of indirect transfer has been fetched and placed in the embedded SRAM, even if the watermark value is higher than the actual completed fill level.
7. Trigger Indirect Read access by setting the OSPI\_INDIRECT\_READ\_XFER\_CTRL\_REG[0] START\_FLD bit to 1.
8. If the watermark interrupt feature is to be used, wait for watermark interrupt. Else poll the SRAM fill level via the OSPI\_SRAM\_FILL\_REG register to decide when sufficient data is in the SRAM to trigger data fetches.

9. Read the expected amount of data from SRAM. If there is still more data to fetch in order to complete the indirect read transfer, then loop back to step 8. Otherwise continue to step 10.
10. The completion status of the Indirect Read operation can be polled via the OSPI\_INDIRECT\_READ\_XFER\_CTRL\_REG[5] IND\_OPS\_DONE\_STATUS\_FLD bit.
11. An Indirect Complete interrupt will be generated when the Indirect read operation has completed.

#### **12.4.2.4.10.2 Indirect Write Controller**

The aim of the indirect mode of operation is to perform bulk transfer of data from the processor into a FLASH memory in the most efficient manner. The fewest possible write cycles inside the FLASH device will be carried out for the indirect transfer, thus maximizing the life of the device. Indirect write operation can be thought of from a software perspective as the inverse of the indirect read. It is controlled and triggered by software via specific control/configuration Indirect Write Transfer registers (for more information see the following registers: OSPI\_INDIRECT\_WRITE\_XFER\_CTRL\_REG, OSPI\_INDIRECT\_WRITE\_XFER\_WATERMARK\_REG, OSPI\_INDIRECT\_WRITE\_XFER\_START\_REG, and OSPI\_INDIRECT\_WRITE\_XFER\_NUM\_BYTES\_REG). This block will await delivery of the write data via the external data interface controller, placing it in the local SRAM before communicating with the existing legacy SPI core to perform an efficient and optimized FLASH write burst.

By default, the indirect write controller is disabled. Before enabling it, the software must configure how much data is required and the start address. The start address and total number of bytes to be written is defined in OSPI\_INDIRECT\_WRITE\_XFER\_START\_REG and OSPI\_INDIRECT\_WRITE\_XFER\_NUM\_BYTES\_REG registers, respectively. Up to two indirect operations can be programmed at any one time. The second operation can be triggered while the first is in progress. Supporting two indirect operations allows a short turnaround time between the completion of one indirect operation and the start of the second. The Indirect write queuing is very similar to indirect read queuing. For more information refer to [Section 12.4.2.4.10.3, Indirect Access Queuing](#).

The total number of bytes to write in an indirect operation is not limited by the size of the SRAM. The size of SRAM will only limit the amount of data that can be accepted from the external controller. In the case of an SRAM overrun, the controller will back pressure the data interface with wait states. Note the fill level of the SRAM is readable via programmable OSPI\_SRAM\_FILL\_REG register and this can be used to avoid this situation.

An external controller will provide the write data and will transfer this to the OSPI module by issuing data interface writes. The address of the incoming write access must be in the range of Indirect trigger address programmed via the OSPI\_IND\_AHB\_ADDR\_TRIGGER\_REG register to Indirect trigger address + 2\*\*<sup>(Indirect trigger address range)</sup> - 1. Default value of the range is equal to 16 locations. This allows a 16-beat burst to be applied starting from the Indirect trigger address. The smaller bursts are possible to handle effectively as well with this approach. Furthermore it is not strict requirement to push consecutive address sequence. Actual address just has to be in the Indirect Range to grant SRAM as source. Each write will cause the internal SRAM to be pushed, thereby decoupling the incoming write access address from the FLASH address – that is not direct mapped. Therefore Indirect trigger address does not have any relationship with FLASH address. It is just to indicate that data should take SRAM as source instead of FLASH Memory array after triggering of any valid Indirect Write. The FLASH address for Indirect Write is taken from the OSPI\_INDIRECT\_WRITE\_XFER\_START\_REG register. Assuming the SRAM is not full at the point the data interface access is received by the OSPI module, then the data will be pushed to the SRAM with minimum latency.

If a write access is received whose address is not within the range described above then that access will not be completed using the indirect controller. It will instead be serviced by the direct access controller.

If a write access is received whose address is within the range described above but the SRAM is full then wait states will be applied until some or all of the data has been pushed from the SRAM to the FLASH.

If a write burst is received whose access elements traverse the Indirect trigger range, then the accesses within the Indirect trigger range will be processed by the indirect controller, and the rest will be taken by the direct access controller. This is likely to be a software configuration error.

The external controller is only permitted to issue 32-bit data interface writes until the last word of an indirect transfer. This helps keep the SRAM control logic less complex. On the final write, the external controller may issue a 32-bit word, 16-bit (halfword) or a byte access to complete the transfer. If the number of bytes to write is less than 4 on the last transfer, the controller is still permitted to issue a 32-bit transfer. In these cases, the extra bytes are discarded by the controller.

When the SRAM holds a number of bytes equal to or greater than the size of a FLASH page (which itself is programmed into the OSPI module, with a default of 256 bytes) or when the SRAM holds all remaining bytes of the currently executing indirect transfer, the OSPI module will initiate a write burst to the flash command generator.

An indirect operation may be cancelled at any time by setting 1 to the OSPI\_INDIRECT\_WRITE\_XFER\_CTRL\_REG[1] CANCEL\_FLD bit.

Any bus controller should be allowed to initiate an indirect access. The OSPI module provide software access mechanism to the SRAM fill-level directly via the configuration registers and then decide for itself when the data should be written to the local SRAM. The fill level watermark register (see OSPI\_INDIRECT\_WRITE\_XFER\_WATERMARK\_REG register) is provided. When the SRAM fill level falls below this watermark, an interrupt is generated.

Two further interrupt sources are provided to help understand the status of an indirect operation. Firstly, an interrupt is generated when an indirect operation has completed. Secondly, an interrupt is generated if an indirect write operation was requested but could not be accepted due to the fact 2 indirect operations have already been buffered by the OSPI module.

Setting the OSPI\_INDIRECT\_WRITE\_XFER\_CTRL\_REG[0] START\_FLD bit starts an indirect write operation. The OSPI\_INDIRECT\_WRITE\_XFER\_CTRL\_REG[2] WR\_STATUS\_FLD bit is available to check the status.

#### 12.4.2.4.10.2.1 Indirect Write Transfer Process

The following sequence can be followed:

1. Setup OSPI\_CONFIG\_REG register.
2. Setup the indirect transfer's FLASH start address in the OSPI\_INDIRECT\_WRITE\_XFER\_START\_REG register.
3. Setup the number of bytes to be transferred in the OSPI\_INDIRECT\_WRITE\_XFER\_NUM\_BYTES\_REG register.
4. Setup the indirect transfer's trigger address in the OSPI\_IND\_AHB\_ADDR\_TRIGGER\_REG register.
5. Setup the indirect transfer's trigger address range in the OSPI\_INDIRECT\_TRIGGER\_ADDR\_RANGE\_REG register.
6. It is functionally valid for software to simply write all the data to the SRAM in one block transfer. However, if the total number of bytes to write is greater than the size of the partitioned SRAM, then it is quite likely the SRAM will become full causing the OSPI to back-pressure the system data bus for a considerable time. This time is based on the FLASH data-rate and the page-write time of the device. To avoid sending all the write data in one block transfer, software can make use of the watermark interrupt to identify a convenient time to send data a page at a time to the SRAM module. Alternatively, software can poll the SRAM fill level register directly to identify how empty the SRAM is at any one time in order to make a judgment as to when the most practical time to send the next part of the transfer.
7. If the watermark interrupt feature is to be used, set the OSPI\_INDIRECT\_WRITE\_XFER\_WATERMARK\_REG register which will cause an interrupt to be generated when the fill level falls below the watermark. The watermark should be set to a number between zero and a page size. That is if the page size is 256 bytes, then setting the watermark to a value between 10 and 250 is reasonable and will cause the interrupt to trigger when the fill level drops below the programmed number. Setting the watermark can be useful to provide an indication to software when to write the next page of data to the SRAM.
8. Trigger Indirect Write access by setting OSPI\_INDIRECT\_WRITE\_XFER\_CTRL\_REG[0] START\_FLD bit.

9. If the remaining number of bytes still to be transferred into the SRAM for the current indirect transfer is greater than a FLASH page, then write 1 FLASH page worth of data to the SRAM. Otherwise send the remaining data from the indirect transfer to SRAM.
10. If all the data in the indirect transfer has now been sent to the SRAM, then go to 12 and await indirect complete status. Otherwise if there is more data still to be transferred then either:
  - If the watermark interrupt feature is being used, then wait for watermark interrupt.
  - Alternatively the SRAM fill level can be interrogated to identify a convenient time to send more data.
11. Loop back to 9.
12. Optional: The completion status of the Indirect write operation can be polled via OSPI\_INDIRECT\_WRITE\_XFER\_CTRL\_REG[5] IND\_OPS\_DONE\_STATUS\_FLD.
13. An Indirect Complete interrupt will be generated when the Indirect write operation has completed.

#### **12.4.2.4.10.3 Indirect Access Queuing**

Software is permitted to queue up to two indirect transfers for both the indirect write controller and the indirect read controller. Supporting two indirect operations allows a short turnaround time between the completion of one indirect operation and the start of the second. Any attempt to queue more than two operations will cause an interrupt to be generated. To take advantage of this feature, software should attempt to keep both indirect programming slots full at all times.

From the software perspective, indirect access queuing is achieved by triggering bit 0 of the indirect transfer control register (OSPI\_INDIRECT\_READ\_XFER\_CTRL\_REG[0] START\_FLD bit or OSPI\_INDIRECT\_WRITE\_XFER\_CTRL\_REG[0] START\_FLD bit) twice in short succession.

The indirect number of bytes register (OSPI\_INDIRECT\_READ\_XFER\_NUM\_BYTES\_REG or OSPI\_INDIRECT\_WRITE\_XFER\_NUM\_BYTES\_REG register) and the indirect FLASH start address register (OSPI\_INDIRECT\_READ\_XFER\_START\_REG or OSPI\_INDIRECT\_WRITE\_XFER\_START\_REG register) must be setup with the relevant transfer data before START\_FLD bit can be triggered for each transfer. Since these registers will change regularly, the hardware must keep sampled versions of these registers for the duration of the indirect transfer.

The internal register block will only issue an indirect start trigger to the key underlying datapath blocks one at a time. There are 2 independent datapath blocks in the indirect access controller that will receive and independently sample this information. The first is the datapath block on the data bus side of the SRAM. For indirect reads, this is a read interface, for indirect writes, it is a write interface. The second is the datapath block on the FLASH side of the SRAM. For indirect reads, this is a write interface, for indirect writes, it is a read interface. Both blocks will process the indirect transfers at different times. For example, for an indirect read operation, the datapath block on the FLASH side of the SRAM will be able to start processing the second queued transfer as soon as the last byte of the first transfer has been written to the SRAM. Before commencing the second transfer, this block must resample the OSPI\_INDIRECT\_READ\_XFER\_NUM\_BYTES\_REG and OSPI\_INDIRECT\_READ\_XFER\_START\_REG registers. Similarly, the datapath block on the bus side will resample the same registers locally when it has forwarded all the FLASH data associated with the first indirect transfer from the SRAM onto the data bus.

#### **12.4.2.4.10.4 Consecutive Writes and Reads Using Indirect Transfers**

It is permitted for software to trigger an indirect read operation while an indirect write operation is in progress. Similarly it is permitted to trigger an indirect write while an indirect read operation is in progress. Indirect write operations will take overall precedence.

#### **12.4.2.4.10.5 Accessing the SRAM**

The SRAM depth is separated in two segments. The lower segment is reserved for indirect read use. The upper segment is for indirect write use only. The size of each segment is programmable via the OSPI\_SRAM\_PARTITION\_CFG\_REG register. This feature allows to allocate how many bits of the SRAM address bus are allocated to indirect read. By default, this is set so that exactly half of the SRAM is portioned for use by the indirect read controller. To ensure the read data bus is not directly fed by the SRAM read data through combinatorial logic, an extra bank of holding registers is included in the indirect read data path. These registers act as an extra location to be added to the allocated number of SRAM locations for indirect read.

To illustrate how the SRAM (and the extra bank of holding registers) can be allocated between indirect read and write, the following example is provided. The depth of the SRAM in this example is configured to be 8 bits. This is equal to 256 locations.

- If the OSPI\_SRAM\_PARTITION\_CFG\_REG[7-0] ADDR\_FLD field is set to 0x00, then 256 locations are allocated to indirect writes and 1 location to indirect reads.
- If the OSPI\_SRAM\_PARTITION\_CFG\_REG[7-0] ADDR\_FLD field is set to 0x01, then 255 locations are allocated to indirect writes and 2 locations to indirect reads.
- If the OSPI\_SRAM\_PARTITION\_CFG\_REG[7-0] ADDR\_FLD field is set to 0x02, then 254 locations are allocated to indirect writes and 3 locations to indirect reads.
- And so on until.
- If the OSPI\_SRAM\_PARTITION\_CFG\_REG[7-0] ADDR\_FLD field is set to 0xFD, then 3 locations are allocated to indirect writes and 254 locations to indirect reads.
- If the OSPI\_SRAM\_PARTITION\_CFG\_REG[7-0] ADDR\_FLD field is set to 0xFE, then 2 locations are allocated to indirect writes and 255 locations to indirect reads.
- If the OSPI\_SRAM\_PARTITION\_CFG\_REG[7-0] ADDR\_FLD field is set to 0xFF, then 1 location is allocated to indirect writes and 256 locations to indirect reads.

---

#### Note

A value of 0xFF or 0x00 in the OSPI\_SRAM\_PARTITION\_CFG\_REG register should be avoided by software, as only the bottom 8 bits of the SRAM fill level are accessible through software (up to 255 limit) via the OSPI\_SRAM\_FILL\_REG register. If the fill level reaches 256 on either the indirect read or write side, it will appear when reading the Fill Level to be 0.

There are four SRAM sources that are arbitrated and muxed onto the single SRAM port. Up to three sources can access this port at any one time. The sources are described as follows:

- Indirect Write, Write source. This is located on the data bus side of the SRAM.
- Indirect Write, Read source. This is located on the FLASH side of the SRAM.
- Indirect Read, Write source. This is located on the FLASH side of the SRAM.
- Indirect Read, Read source. This is located on the data bus side of the SRAM.

A fixed priority arbitration scheme is implemented. [Table 12-183](#) shows priority allocated to these sources.

**Table 12-183. SRAM Access Priority**

| SRAM Access Priority |                                       |                                             |
|----------------------|---------------------------------------|---------------------------------------------|
| Indirect Write       | Write to SRAM (from System Data Bus)  | 3rd (exclusive with Data Bus Read Request)  |
|                      | Read from SRAM (from OSPI Module)     | 2nd                                         |
| Indirect Read        | Write to SRAM (from OSPI Module)      | 1st                                         |
|                      | Read from SRAM (from System Data Bus) | 3rd (exclusive with Data Bus Write Request) |

---

#### Note

With the exception of the write port during an Indirect Read operation (on the FLASH side of the SRAM), the logic driving all four sources must not assume single cycle completion. Writes to the SRAM during an indirect read must be allowed to complete immediately to avoid data loss. Therefore this port is given maximum priority.

---

#### 12.4.2.4.11 OSPI Software-Triggered Instruction Generator (STIG)

The DAC and INDAC are used to transfer data. In order to access the volatile and non-volatile configuration registers, the legacy SPI Status register, other status/protection registers as well as to perform ERASE functions, a separate software controller is required. The software triggered instruction generator (STIG) is controlled using the OSPI\_FLASH\_CMD\_CTRL\_REG register by setting

up the command to issue to the FLASH device. This is a generic controller and can be used to perform any instruction that the FLASH device supports from the extended SPI protocol. Configuring of instructions which are not compliant with the specification of the FLASH devices could cause unpredicted behavior of the controller. OSPI\_FLASH\_CMD\_CTRL\_REG[31-24] CMD\_OPCODE\_FLD bits should be set different than OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG[7-0] RD\_OPCODE\_NON\_XIP\_FLD and OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG[7-0] WR\_OPCODE\_FLD. The OSPI\_FLASH\_CMD\_CTRL\_REG[0] CMD\_EXEC\_FLD bit is used to trigger the command. The OSPI\_FLASH\_CMD\_CTRL\_REG[1] CMD\_EXEC\_STATUS\_FLD bit is used by software to poll the status of the command execution. For reads, when the command has been serviced (OSPI\_FLASH\_CMD\_CTRL\_REG[1] CMD\_EXEC\_STATUS\_FLD bit toggles from '1' to '0'), up to 8 bytes of read data will be placed in the OSPI\_FLASH\_RD\_DATA\_LOWER\_REG and OSPI\_FLASH\_RD\_DATA\_UPPER\_REG registers. For writes, the write data should be placed in the OSPI\_FLASH\_WR\_DATA\_LOWER\_REG and OSPI\_FLASH\_WR\_DATA\_UPPER\_REG registers.

The completion of the STIG request could be also checked by the corresponding interrupt. The occurrence of the interrupt indicates that the controller is ready for accepting a new STIG request. It is important to notice that completion of the STIG request is not equivalent to completion it on SPI side. For example, if STIG is configured to the command composed of data to transmit only, the data is taken from the corresponding STIG register fields and put into TX FIFO. Since all bytes to write are known, another STIG can be queued before serialization of the current one is completed.

There are some commands which require more data to read than 8 bytes (for example READ ID command). The additional STIG Memory Bank is implemented in order to accommodate these data if needed. The STIG Memory Bank (internal component of the controller) is controlled by the OSPI\_FLASH\_CMD\_CTRL\_REG[2] STIG\_MEM\_BANK\_EN\_FLD bit. If enabled, the number of bytes to read in the STIG is extended to 16 as defined in OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG[18-16] NB\_OF\_STIG\_READ\_BYTES\_FLD bit field. It should be noticed that there are very few commands (excluding Read Array ones which are not intended to handle effectively in STIG Mode but in Direct/Indirect Modes) which return more than 8 bytes to the controller. If the maximum number of bytes to Read using STIG in target application is less than 16, the depth of the STIG Memory Bank can be set smaller what will result in saving noticeable part of the area.

If number of bytes to Read in the STIG as defined in OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG[18-16] NB\_OF\_STIG\_READ\_BYTES\_FLD bit field exceeds the Memory Bank Depth, remaining data will overwrite the STIG Memory Bank locations starting from its first address. OSPI\_FLASH\_RD\_DATA\_LOWER\_REG and OSPI\_FLASH\_RD\_DATA\_UPPER\_REG keep the last 8 bytes read from the Flash Device by STIG when Memory Bank is enabled. Therefore, for example if the user wants to get just a single byte from the last eight bytes from long continuous read SPI data chain, there is no need to access the STIG Memory Bank since data can be taken from suitable Flash Command Read Data register. In order to access more data, STIG Memory Bank data request should be triggered. It is controlled by the OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG and works analogously for triggering STIG from the functional standpoint.

OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG[0] TRIGGER\_MEM\_BANK\_REQ\_FLD bit is used to trigger the command, bit OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG[1] MEM\_BANK\_REQ\_IN\_PROGRESS\_FLD is used by software to poll the status of the command execution. When MEM\_BANK\_REQ\_IN\_PROGRESS\_FLD bit toggles from "1" to "0", the byte of data (OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG[15-8] MEM\_BANK\_READ\_DATA\_FLD) from corresponding address (OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG[28-20] MEM\_BANK\_ADDR\_FLD bit field) is valid. The address should be set before triggering the STIG Memory Bank access. Each consecutive STIG access overwrites the previous one so that the data in the Bank always fit into byte index fetched by the last STIG access configured to use the Memory Bank (first incoming byte equals first address of the Memory Bank, second one equals the second address and so on).

#### 12.4.2.4.11.1 Servicing a STIG Request

A STIG request will cause the OSPI Flash controller to interrogate the OSPI\_FLASH\_CMD\_CTRL\_REG register to determine what and how many bytes it should send to the FLASH device. The OSPI\_FLASH\_CMD\_CTRL\_REG[31-24] CMD\_OPCODE\_FLD field of this register indicate the instruction to be sent and is always pushed first. If there is an address to send, then the address (the size

of which is also programmed in the same register) is sent next. The address itself is stored in the OSPI\_FLASH\_CMD\_ADDR\_REG register. If Mode bits are enabled by OSPI\_FLASH\_CMD\_CTRL\_REG[18] ENB\_MODE\_BIT\_FLD bit, OSPI\_MODE\_BIT\_CONFIG\_REG[7-0] MODE\_FLD bit field are being sent right after address. If OSPI\_FLASH\_CMD\_CTRL\_REG[18] ENB\_MODE\_BIT\_FLD and OSPI\_CONFIG\_REG[29] CRC\_ENABLE\_FLD are both enabled, STIG will replace XIP Mode bits (not applicable for CRC aware SPI interface) for automatically calculated address CRC byte. Therefore, to execute CRC aware STIGs (meaning the commands requiring sending address CRC byte), ENB\_MODE\_BIT\_FLD bit should always be set. If there are any dummy cycles to send (the size of which is also programmed in OSPI\_FLASH\_CMD\_CTRL\_REG register) then those are sent next. If there is data to write or read (the size of which is also programmed in OSPI\_FLASH\_CMD\_CTRL\_REG register) then for the case of writes, up to 8 bytes can be sent (as stored in the Flash Command Write Data registers, OSPI\_FLASH\_WR\_DATA\_LOWER\_REG and OSPI\_FLASH\_WR\_DATA\_UPPER\_REG registers) next. In the read case, when the read data has been collected from the FLASH device, the OSPI Flash Controller stores that in the Flash Command Read Data Registers (OSPI\_FLASH\_RD\_DATA\_LOWER\_REG and OSPI\_FLASH\_RD\_DATA\_UPPER\_REG registers). Up to 8 bytes can be get if OSPI\_FLASH\_CMD\_CTRL\_REG[2] STIG\_MEM\_BANK\_EN\_FLD bit is disabled or up to 512 when enabled. When the OSPI Flash controller starts to service a STIG request, it sets the OSPI\_FLASH\_CMD\_CTRL\_REG[1] CMD\_EXEC\_STATUS\_FLD bit to indicate a command execution is in progress. When the OSPI Flash controller is in the auto-polling state, servicing a STIG request is slightly different. Most of devices are largely inaccessible after a program operation until the device has completed that write. Some group of them has a possibility to suspend programming page. It can be controlled by the OSPI\_POLLING\_FLASH\_STATUS\_REG[8] DEVICE\_STATUS\_VALID\_FLD bit, which indicate active auto-polling phase. After requesting a STIG, the OSPI Flash Controller immediately issues appropriate OPCODE to Memory. During servicing a STIG (in auto-polling phase) the status bit of command execution remains steady and other parts of transfer such as ADDRESS or DUMMY BITS, and so forth, are disabled (to issued Program Suspend Command is needed OPCODE only). There is a programmable option to add delay between every repetitive poll operation (delay is defined by OSPI\_WRITE\_COMPLETION\_CTRL\_REG[31-24] POLL\_REP\_DELAY\_FLD bit field). This feature is implemented to free up SPI bandwidth if needed.

#### 12.4.2.4.12 OSPI Arbitration Between Direct / Indirect Access Controller and STIG

When multiple controllers are active simultaneously, a simple fixed-priority arbitration scheme is used to arbitrate between each interface and access the external FLASH. The fixed priority is defined as follows, highest priority first.

- The Indirect Access Write
- The Direct Access Write
- The STIG
- The Direct Access Read
- The Indirect Access Read

#### 12.4.2.4.13 OSPI Command Translation

Requests issued by the direct access controller, the indirect access controller or the STIG will be translated into a sequence of byte transfers to send downstream (before serialization to the FLASH device). These sequences depend on the requested transfer but an example of a typical 1-byte non sequential READ is shown below:

INSTRUCTION OPCODE -> ADDRESS -> Mode Byte -> Dummy Bytes -> 1 byte of don't care

For sequential accesses, an extra byte of data per read is pushed to the FLASH device on the back of the above sequence assuming it can be done so with no gap between each transferred byte.

When PHY mode is enabled and consequently no clock divider is configured, latency caused by multi domain synchronization may make an extra byte insufficient to avoid the transfer gap. To ensure the sequential access non-interrupted and keep the maximum performance of the controller, PHY Pipeline Mode is implemented. When enabled, number of don't care bytes is calculated based on the configuration.

The actual sequence sent to the FLASH device depends on the requested transfers, whether the transfer is non-sequential or sequential, whether the device has been configured in XIP mode and the state

of the main Device Instruction Type programmable registers (OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG and OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG).

For writes, the write enable latch (or WEL) within the FLASH device itself must be high before a write sequence can be issued. The OSPI Flash Controller will automatically issue the write enable latch command before triggering a write command via the direct or indirect access controllers (DAC/INDAC) – that is the user does not need to perform this operation. For increasing flexibility and performance user can turn off this feature by setting the OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG[8] WEL\_DIS\_FLD bit. The opcode for WREN is typically 0x06 and is common between devices.

When write requests from the direct or indirect access controllers are no longer being received and all outstanding requests have been sent, the FLASH device will automatically start the page program write cycle. Any incoming request at this time will be held in wait states until the cycle has completed. The OSPI Flash Controller will automatically poll the FLASH device legacy SPI status register to identify when the write cycle has completed. This is achieved by sending the RDSR opcode to the FLASH device and waiting until the device itself has indicated the write cycle has completed (until the Write in Progress bit has cleared to zero and the write enable latch bit has also cleared to zero or device is ready bit has set to one). The WREN and the RDSR device instructions are the only ones that are sent by the controller under the hood. For any other specific instruction that the user determines should be sent to the device (for example if the device needs to be unprotected before a write command is issued), these should be handled separately by issuing FLASH commands via the STIG.

There is an option to trigger HOLD or RESET feature on I/Os of the Flash Device. The HOLD one is generally common across the devices and takes an alternative function of DQ3 pin (applicable when device operates neither in Quad SPI mode nor DDR). The transfer can be hold and then resumed by dedicated software trigger field (OSPI\_CONFIG\_REG[4] HOLD\_PIN\_FLD). The devices which have the HOLD feature on DQ3 usually need another dedicated pin for hardware reset and ones without HOLD feature usually have alternative reset on DQ3 what makes the additional reset pin being redundant. The controller supports both variants and reset selection register field (OSPI\_CONFIG\_REG[6] RESET\_CFG\_FLD) allows the user to configure which hardware reset solution is implemented in the device under usage.

After configuration is done, it is possible to trigger HOLD or RESET features using I/Os (OSPI\_CONFIG\_REG[4] HOLD\_PIN\_FLD or OSPI\_CONFIG\_REG[5] RESET\_PIN\_FLD bits). After HOLD activation the controller is introduced into waiting state and any other operations should not be requested before de-asserting of HOLD configuration bit. The HOLD feature is useful when any SPI transaction needs to be prolonged in order to adjust it into specific point in time. Note that any HOLD trigger issued during active SPI transaction may be synchronized into reference clock domain at the time the SPI transfer turns to be finished. In this case, there is nothing to hold so the low level SPI logic will not activate HOLD on DQ3. To check if HOLD request suspended the transfer OSPI\_CONFIG\_REG[31] IDLE\_FLD bit can be polled for. If SPI is not in the IDLE state, the transfer was successfully suspended. It is important for the software to take care of resetting OSPI\_CONFIG\_REG[4] HOLD\_PIN\_FLD bit before newly triggered SPI transaction. In case HOLD request is set before the beginning of the transfer it will be HOLD right after it starts what may not always be a goal. The hardware RESET needs to be activated when CS is high (no valid transaction is present on SPI bus). It can be checked by polling of OSPI\_CONFIG\_REG[31]. If the controller is in the IDLE state and no other transfer requests are queued to perform, the hardware RESET can be triggered. The RESET feature is useful when any write, program or erase operation needs to be cancelled. No transfer request is permitted before driving the reset back to being inactive. Triggering HOLD or RESET on DQ3 at the time the device is configured to work in Quad SPI mode or DDR will overwrite transfer data on DQ3 with '0'. This behavior is considered as a software error so it is advisable for the system to make sure that the flash device was introduced to suitable SPI mode (that is by polling its configuration register) before triggering alternative DQ3 function. There are four independent reset outputs implemented to separate between multiple devices connected to the controller (up to 4 are supported). The decision which reset output is to be activated after triggering OSPI\_CONFIG\_REG[5] RESET\_PIN\_FLD bit is made based on OSPI\_CONFIG\_REG[9] PERIPH\_SEL\_DEC\_FLD and OSPI\_CONFIG\_REG[13-10] PERIPH\_CS\_LINES\_FLD bits. Reset output OSPI\_ECC\_VECTOR is to be directly driven into corresponding dedicated RESET pins of the devices with separated RESET pin and alternatively, Reset output OSPI\_ECC\_VECTOR is to be control

OSPI\_ECC\_VECTOR of the DQ3 RESET devices enabling separating of DQ3 Controller Outputs on SoC integration level.

The controller supports all combinations of CPHA and CPOL for Serial Clock. It allows the controller to support any SPI target devices not limited to Flash Memories. Multiple-SPI flash devices use just a subset of these combinations depending on the Transfer Mode as defined in [Table 12-184](#).

**Table 12-184. Flash SPI Modes**

| (SEL_CLK_POL_FLD, SEL_CLK_PHASE_FLD) | Edge Mode | Support |
|--------------------------------------|-----------|---------|
| 0x00 (SPI MODE 0)                    | SDR       | Yes     |
| 0x01 (SPI MODE 1)                    | SDR       | No      |
| 0x10 (SPI MODE 2)                    | SDR       | No      |
| 0x11 (SPI MODE 3)                    | SDR       | No      |
| 0x00 (SPI MODE 0)                    | DDR       | Yes     |
| 0x01 (SPI MODE 1)                    | DDR       | No      |
| 0x10 (SPI MODE 2)                    | DDR       | No      |
| 0x11 (SPI MODE 3)                    | DDR       | No      |

#### 12.4.2.4.14 Selecting the Flash Instruction Type

In order to send the correct READ and WRITE opcodes, software should initialize the OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG and the OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG registers. These registers include fields to setup the required instruction opcodes that is intended to be used to access the FLASH (default is basic READ and basic page program) as well as the instruction type, edge mode (DDR or SDR) and whether the instruction uses single, dual, quad or octal pins for address and data transfer. Providing this level of control to the user provides a future proofed generic solution. To ensure the controller can operate from a reset state, the registers will be reset to an opcode compatible with SIO devices what can be modified using BOOT feature.

Despite being applicable for both READs and WRITEs, the OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG[9-8] INSTR\_TYPE\_FLD field only appears once – it is not included in the OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG register. If software sets this to anything other than '0', then the address transfer type and the data transfer type bits of both OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG and OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG registers become don't care. It is made available to allow software to support the less common FLASH instructions where the opcode, address and data are sent on 2 or 4 lanes (the opcode from most instructions are sent serially to the FLASH device, even for dual/quad instructions).

There are devices capable to handling Read Operations in Dual Data Rate Mode (DDR) (it is also called Dual Transfer Rate Mode (DTR)). That means they can issue and capture the data on both rising and falling edges during working with dedicated command type. This enables the controller to maintain throughput at twice lower frequency of OSPI clock. The Device Read Instruction Register has DDR enable bit which informs Octal-SPI Flash Controller that opcode written into Read Opcode field is capable with DDR command type. The other field defined in OSPI\_RD\_DATA\_CAPTURE\_REG[19-16] DDR\_READ\_DELAY\_FLD which enables the controller to shift the transmitted data in DDR mode. By default, data are shifted by 1 clock cycle to ensure hold timing greater than 0 during DDR transactions. It may not be sufficient for high reference clock frequency in accordance with the high dividers.

[Table 12-185](#) shows how software should configure the OSPI module for selected specific READ and WRITE instruction supported by the abovementioned device.

**Table 12-185. READ and WRITE Instruction Configuration**

READ

**Table 12-185. READ and WRITE Instruction Configuration (continued)**

| OPCODE                                      | OPCODE sent over how many lanes / edge mode? | ADDRESS / DUMMY / MODE sent over how many lanes / edge mode? | DATA bytes sent over how many lanes / edge mode? | Instruction Type (OSPI_DEV_INS TR_RD_CONFIG _REG[9-8] INSTR_TYPE_FLD) | Address transfer type (OSPI_DEV_INST R_RD_CONFIG_R EG[13-12] ADDR_XFER_TY PE_STD_MODE_FLD) | Data transfer type (OSPI_DEV_INST R_RD_CONFIG_R EG[17-16] DATA_XFER_TYP E_EXT_MODE_FLD) | DDR bit enable (OSPI_DEV_INST R_RD_CONFIG_R EG[10] DDR_EN_FLD) |
|---------------------------------------------|----------------------------------------------|--------------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------|
| READ                                        | 1/SDR                                        | 1/SDR                                                        | 1/SDR                                            | 0                                                                     | 0                                                                                          | 0                                                                                       | 0                                                              |
| FAST_READ                                   | 1/SDR                                        | 1/SDR                                                        | 1/SDR                                            | 0                                                                     | 0                                                                                          | 0                                                                                       | 0                                                              |
| DTR_FAST_READ                               | 1/SDR                                        | 1/DDR                                                        | 1/DDR                                            | 0                                                                     | 0                                                                                          | 0                                                                                       | 1                                                              |
| DOFR (Dual O/p Fast Read)                   | 1/SDR                                        | 1/SDR                                                        | 2/SDR                                            | 0                                                                     | 0                                                                                          | 1                                                                                       | 0                                                              |
| DIOFR (Dual I/O Fast Read)                  | 1/SDR                                        | 2/SDR                                                        | 2/SDR                                            | 0                                                                     | 1                                                                                          | 1                                                                                       | 0                                                              |
| DDIOFR (DTR Dual I/O Fast Read)             | 1/SDR                                        | 2/DDR                                                        | 2/DDR                                            | 0                                                                     | 1                                                                                          | 1                                                                                       | 1                                                              |
| QOFR (Quad O/p Fast Read)                   | 1/SDR                                        | 1/SDR                                                        | 4/SDR                                            | 0                                                                     | 0                                                                                          | 2                                                                                       | 0                                                              |
| QIOFR (Quad I/O Fast Read)                  | 1/SDR                                        | 4/SDR                                                        | 4/SDR                                            | 0                                                                     | 2                                                                                          | 2                                                                                       | 0                                                              |
| DQIOFR (DTR Quad I/O Fast Read)             | 1/SDR                                        | 4/DDR                                                        | 4/DDR                                            | 0                                                                     | 2                                                                                          | 2                                                                                       | 1                                                              |
| OOFR (Octal O/p Fast Read)                  | 1/SDR                                        | 1/SDR                                                        | 8/SDR                                            | 0                                                                     | 0                                                                                          | 3                                                                                       | 0                                                              |
| OIOFR (Octal I/O Fast Read)                 | 1/SDR                                        | 8/SDR                                                        | 8/SDR                                            | 0                                                                     | 3                                                                                          | 3                                                                                       | 0                                                              |
| DOIOFR (DTR Octal O/p Fast Read)            | 1/SDR                                        | 1/DDR                                                        | 8/DDR                                            | 0                                                                     | 0                                                                                          | 3                                                                                       | 1                                                              |
| 4DOIOFR (4-byte DTR Octal I/O Fast Read)    | 1/SDR                                        | 8/DDR                                                        | 8/DDR                                            | 0                                                                     | 3                                                                                          | 3                                                                                       | 1                                                              |
| DCFR (Dual Command Fast Read)               | 2/SDR                                        | 2/SDR                                                        | 2/SDR                                            | 1                                                                     | Don't care                                                                                 | Don't care                                                                              | 0                                                              |
| DDCFR (DTR Dual Command Fast Read)          | 2/SDR                                        | 2/DDR                                                        | 2/DDR                                            | 1                                                                     | Don't care                                                                                 | Don't care                                                                              | 1                                                              |
| QCFR (Quad Command Fast Read)               | 4/SDR                                        | 4/SDR                                                        | 4/SDR                                            | 2                                                                     | Don't care                                                                                 | Don't care                                                                              | 0                                                              |
| DQCFR (DTR Quad Command Fast Read)          | 4/SDR                                        | 4/DDR                                                        | 4/DDR                                            | 2                                                                     | Don't care                                                                                 | Don't care                                                                              | 1                                                              |
| OCFR (Octal Command Fast Read)              | 8/SDR                                        | 8/SDR                                                        | 8/SDR                                            | 3                                                                     | Don't care                                                                                 | Don't care                                                                              | 0                                                              |
| 4DOCFR (4-byte DTR Octal Command Fast Read) | 8/SDR                                        | 8/DDR                                                        | 8/DDR                                            | 3                                                                     | Don't care                                                                                 | Don't care                                                                              | 1                                                              |

**WRITE**

**Table 12-185. READ and WRITE Instruction Configuration (continued)**

| OPCODE                                    | OPCODE sent over how many lanes? | ADDRESS / DUMMY / MODE sent over how many lanes? | DATA bytes sent over how many lanes? | Instruction Type (OSPI_DEV_INS TR_RD_CONFIG _REG[9-8] INSTR_TYPE_FLD) | Address transfer type (OSPI_DEV_INSTR_RD_CONFIG _REG[13-12] ADDR_XFER_TY PE_STD_MODE_FLD) | Data transfer type (OSPI_DEV_INSTR_WR_CONFIG_R EG[17-16] DATA_XFER_TYPE_EXT_MODE_FLD) |
|-------------------------------------------|----------------------------------|--------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| PP                                        | 1                                | 1                                                | 1                                    | 0                                                                     | 0                                                                                         | 0                                                                                     |
| DIFP (Dual Input Fast Program)            | 1                                | 1                                                | 2                                    | 0                                                                     | 0                                                                                         | 1                                                                                     |
| DIEFP (Dual Input Extended Fast Program)  | 1                                | 2                                                | 2                                    | 0                                                                     | 1                                                                                         | 1                                                                                     |
| QIFP (Quad Input Fast Program)            | 1                                | 1                                                | 4                                    | 0                                                                     | 0                                                                                         | 2                                                                                     |
| QIEFP (Quad Input Extended Fast Program)  | 1                                | 4                                                | 4                                    | 0                                                                     | 2                                                                                         | 2                                                                                     |
| OIFP (Octal Input Fast Program)           | 1                                | 1                                                | 8                                    | 0                                                                     | 0                                                                                         | 3                                                                                     |
| OIEFP (Octal Input Extended Fast Program) | 1                                | 8                                                | 8                                    | 0                                                                     | 3                                                                                         | 3                                                                                     |
| DCPP (Dual Command Fast Program)          | 2                                | 2                                                | 2                                    | 1                                                                     | Don't care                                                                                | Don't care                                                                            |
| QCPP (Quad Command Fast Program)          | 4                                | 4                                                | 4                                    | 2                                                                     | Don't care                                                                                | Don't care                                                                            |
| OCPP (Octal Command Fast Program)         | 8                                | 8                                                | 8                                    | 3                                                                     | Don't care                                                                                | Don't care                                                                            |

**Note**

This data are applicable for both 3-byte or 4-byte address variants of the commands if did not indicate otherwise.

**Note**

In DTR protocol all transfer phases (including opcode) take DDR edge mode independently on the command under execution. DTR protocol is to be enabled by OSPI\_CONFIG\_REG[24] ENABLE\_DTR\_PROTOCOL\_FLD bit. It has higher priority than DDR Mode enable bit from OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG[10] DDR\_EN\_FLD.

**12.4.2.4.15 OSPI Data Interface****12.4.2.4.16 OSPI PHY Module**

OSPI module fully integrates PHY module dedicated to more flexible and power efficient transfers.

The PHY module communicates with the OSPI Flash controller via the aforementioned PHY Interface and handles data transfer on low-level stage of design hierarchy. However, when the OSPI\_RCLK is configured to be equal to the SPI clock instead of alternative approach using clock divider, there is just one OSPI\_RCLK cycle (not 4 or more) within single SPI period or half period for DDR Mode (SPI Control Module works on reference

clock). Given that OSPI\_RCLK is the input clock for RX FIFO and the output one for TX FIFO, the PHY solution incurs more restrictive requirement for value of system clock in order to synchronize data without SPI transfer interruption. For example, when the controller operates in DDR 1 $\times$  octal Mode, 2 bytes of data (equivalent to one RX FIFO location) is gathered within just single OSPI\_RCLK cycle. The controller cannot predict next data access while operating in the Direct Mode (meaning its size or whether it is sequential to the previous one or not). As a result, if the OSPI\_HCLK is not significantly greater than OSPI\_RCLK, the SPI transfer has to be suspended until the Flash Command Generator forwards new data to TX FIFO.

An optional PHY Pipeline Mode is implemented to avoid the necessity of stable clocking of the system clock for the Direct Mode when the PHY mode is enabled and to keep maximum performance while ensuring correct operation of the OSPI controller with the PHY using low frequencies from all its domains. This mode is a trade-off between large software overhead when operating in the Indirect Mode and the described limitations present in the Direct Mode. For more information about PHY Pipeline Mode, see [Section 12.4.2.4.16.1, PHY Pipeline Mode](#).

When DDR 2 $\times$  Mode is granted based on configuration – SPI transfer is automatically performed using the PHY module even if the OSPI\_CONFIG\_REG[3] PHY\_MODE\_ENABLE\_FLD is de-asserted. SDR 2 $\times$  commands are handled with PHY module paths being bypassed. Nevertheless, dividers of 2, 4 or 6 for DDR and divider of 2 for SDR should not be configured based on controller requirements and these configurations are perceived as a software error.

---

**Note**

Please refer to the OSPI Controller PHY Tuning Algorithm Application Note for additional details related to the OSPI PHY Module and Tuning Algorithm,

---

#### **12.4.2.4.16.1 PHY Pipeline Mode**

This mode is used for Direct Read Mode of operation. If any other operations are intended to be executed, it is recommended to disable PHY Pipeline Mode and re-enable for subsequent Direct Reads in PHY mode. Since there is comprehensive software mechanism controlling Read data transfers in Indirect Mode, pipeline of data interface accesses is not effective for this mode. Enable PHY Pipeline feature when at least four 4-byte-sized data words are predicted to be read in sequentially. The Flash Command Generator pipelines and puts them into TX FIFO which causes CS to remain active because low level SPI protocol controller controls TX FIFO fill level. In order to correctly trigger Direct Read in Pipeline Mode TX FIFO must be empty. Therefore first polling of OSPI\_CONFIG\_REG[31] IDLE\_FLD bit needs to be done. The sequential data transfer will be interrupted when the data target select signal of the data interface is asserted to low. This information is also detected by Data Target Module which informs the Flash Command Generator that the next access is invalid and a TX FIFO locations can be flushed transparently for the system.

In PHY Pipeline Mode it is recommended for Data Controller not to introduce wait states in between consecutive occurrences of the data interface signal that indicates transfer has finished. It will ensure regular transfer rate on data side. Introducing wait states gradually slows data transfer rate down and may finally cause SPI transfer interruption because of TX FIFO data starvation. The system, however, may need to introduce some number of wait states after completion of sequential transfer (composed of 4-byte sized data words) for progressing the data. The dedicated buffer is implemented in Data Target Controller which collects all incoming data during wait states injection. In order to keep SPI transfer uninterrupted, number of wait states should be as little as possible. The higher the OSPI\_HCLK/ OSPI\_RCLK ratio the more wait states can be introduced without SPI transfer interruption. In case the system is able to launch a new transfer before wait states overflow, buffered data transfer to the host will continue. It compensates slowed down transfer by introducing wait states. In case the system is not able to launch a new transfer before wait states overflow, next incoming transfer is considered non-sequential and is executed after all pipelined data is flushed.

This mode can be enabled when following conditions are met:

- OSPI\_HCLK > OSPI\_RCLK (Comparing the slow data clock with the fast reference one makes Pipeline Mode ineffective – Suspend of SPI Transfer would be possible. Consequently, this condition has to be met to operate in this mode.)

- Only 4-byte sized Data Words are permitted (This ensures more data clock cycles for synchronization of FIFOs between consecutive pulses of the signal indicating transfer has finished.)
- The transfer with introduced wait states or non-sequential transfers can only be triggered in between at least four 4-byte sized Data Bursts sequential accesses (16 Bytes) to be sure that Data Controller can trust buffered incoming data during wait states injection.
- Do not use Pipeline Mode along with Continuous Mode (XIP). Benefit of XIP is limited for bulk data transfers intended to execute in Pipeline Mode.

#### **12.4.2.4.16.2 Read Data Capturing by the PHY Module**

Read Data Capturing by the PHY module is useful, as the user is not responsible for the design dedicated DLL being compatible with the Octal-SPI Flash Controller. Another benefit is an option to adjust both SPI clock and sampling clock in a very wide range to fit them into individual requirements of any system. If loopback clock (OSPI\_RD\_DATA\_CAPTURE\_REG[0] BYPASS\_FLD) and PHY mode (OSPI\_CONFIG\_REG[3] PHY\_MODE\_ENABLE\_FLD) are both enabled, the loopback clock is driven into RX DLL instead of gated reference clock. Because of the architecture of DLL, loopback clock needs to be provided in SPI Mode 0. If DQS (OSPI\_RD\_DATA\_CAPTURE\_REG[8] DQS\_ENABLE\_FLD) and PHY mode (OSPI\_CONFIG\_REG[3] PHY\_MODE\_ENABLE\_FLD) are both enabled, the DQS is driven into RX DLL instead of gated reference clock.

#### 12.4.2.5 OSPI Programming Guide

##### 12.4.2.5.1 Configuring the OSPI Controller for Use After Reset

The OSPI controller has been designed to wake up in a state that is suitable for performing basic reads and writes using the direct access controller. The BASIC read (opcode 0x03) and BASIC write (opcode 0x02) instructions are operations supported by all target devices. The controller also wakes up with a baud rate divider setting of divide-by-32. Assuming the reference clock is operating at 400 MHz after reset, then this means the effective SPI clock is just 12.5 MHz. This should be slow enough to meet all timing requirements of all target devices without any further device programming.

If the target device does not use 3 address bytes, the device size configuration register must be modified to the appropriate size.

If software plans to write to the device, and the number of bytes per device page is not equal to 256, then the device size configuration register must also be modified.

While not a requirement, it is prudent for software to enable the write protect feature prior to enabling the OSPI controller. This will block any data writes from taking effect. To do so, the protection registers (OSPI\_LOWER\_WR\_PROT\_REG, OSPI\_UPPER\_WR\_PROT\_REG and OSPI\_WR\_PROT\_CTRL\_REG) should be setup and the number of bytes per device block in the device size configuration register should also be setup.

After Power-on Reset (POR), software can read from and write to the FLASH device (albeit slowly). Enabling/Disabling the controller and DAC is achieved with just one write to corresponding fields of the OSPI\_CONFIG\_REG register. User shall take note to maintain the default values of the baud rate divisor and the default state of SEL\_CLK\_POL\_FLD/ SEL\_CLK\_PHASE\_FLD bits of this register. A write data value of 0x00780081 is recommended.

##### 12.4.2.5.2 Configuring the OSPI Controller for Optimal Use

---

**Note**

When using the OSPI Controller, the opcodes in OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG[7-0] RD\_OPCODE\_NON\_XIP\_FLD, OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG[7-0] WR\_OPCODE\_FLD and OSPI\_WRITE\_COMPLETION\_CTRL\_REG[7-0] OPCODE\_FLD bit fields shall not match the opcode in the OSPI\_FLASH\_CMD\_CTRL\_REG[31-24] CMD\_OPCODE\_FLD bit field.

---

For high speed transfers PHY mode can be enabled and for optimal configuration PHY Pipeline mode is recommended. For more information, see [Section 12.4.2.4.16.1, PHY Pipeline Mode](#).

To access the flash optimally, software must configure the controller accurately:

1. Wait until any pending STIG or INDAC operation has completed or poll OSPI\_CONFIG\_REG[31] IDLE\_FLD bit.
2. Disable the DAC through OSPI\_CONFIG\_REG[7] ENB\_DIR\_ACC\_CTLR\_FLD bit. It is permitted, but not necessary to also disable the OSPI controller completely via OSPI\_CONFIG\_REG[0] ENB\_SPI\_FLD bit.
3. Update the OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG and OSPI\_DEV\_INSTR\_WR\_CONFIG\_REG registers for the instruction type you wish to use for indirect and direct writes and reads.
4. Update the OSPI\_MODE\_BIT\_CONFIG\_REG[7-0] MODE\_FLD bit field if mode bits have been enabled in the OSPI\_DEV\_INSTR\_RD\_CONFIG\_REG[20] MODE\_BIT\_ENABLE\_FLD bit.
5. Update the OSPI\_DEV\_SIZE\_CONFIG\_REG if the contents are incorrect. Note parts or all of this register may have been updated after initialization. The number of address bytes is a key configuration setting required for performing reads and writes. The number of bytes per page is required for performing any write. The number of bytes per device block is only required if the write protect feature is used. If the default values are correct for the target device, or if some of the values (not including the number address bytes) were incorrect but device writes were not permitted.
6. Update the OSPI\_DEV\_DELAY\_REG. This register allows the user to tweak how the chip select is driven after each FLASH access. This is required as each device may have different timing requirements. As

the serial clock frequency is increased, these timing requirements become more important. Note the numbers programmed in this register are based on the period of reference clock. Example: A device needs 50ns minimum time before CS can be re-asserted after it has been de-asserted. By default, the controller will only provide a minimum of 1 SCLK period. When the device is operating at 100 MHz, the SCLK period is only 10ns, so 40ns extra is required. Since the register defines the number of reference clock cycles to add, and reference clock is running at 400 MHz (2.5ns period), then the user should program a value of at least 16 to the OSPI\_DEV\_DELAY\_REG[31-24] D\_NSS\_FLD. This delay can be extended during auto-polling phase. There is possibility to define the polling repetition delay in the OSPI\_WRITE\_COMPLETION\_CTRL\_REG[31-24] POLL REP\_DELAY\_FLD bit field.

7. Update the OSPI\_REMAP\_ADDR\_REG register, if required. Affects DAC path only.
8. Setup and enable write protection registers (OSPI\_LOWER\_WR\_PROT\_REG, OSPI\_UPPER\_WR\_PROT\_REG and OSPI\_WR\_PROT\_CTRL\_REG) if they are required and if they have not already been setup from post initialization.
9. Enable required interrupts via the OSPI\_IRQ\_MASK\_REG register.
10. Setup the baud rate divisor in the OSPI\_CONFIG\_REG[22-19] MSTR\_BAUD\_DIV\_FLD to define the required clock frequency of the target device.
11. Update the OSPI\_RD\_DATA\_CAPTURE\_REG register. This register will delay when the read data is captured and can help when the read data path from the device to the controller is long and the device clock frequency is high. An update to this register may not be necessary.
12. Enable the OSPI controller and the DAC via the OSPI\_CONFIG\_REG.

#### **12.4.2.5.3 Using the Flash Command Control Register (STIG Operation)**

The OSPI\_FLASH\_CMD\_CTRL\_REG register provides software means to access the FLASH device in a flexible and programmable manner. This is known as a STIG operation (Software Triggered Instruction Generator). The instruction opcode, number of address bytes (if any), the address itself, number of dummy cycles (if any), number of write data bytes (if any), the write data itself and the number of read data bytes (if any) can be programmed. Once these have been programmed, software can trigger the command via OSPI\_FLASH\_CMD\_CTRL\_REG[0] CMD\_EXEC\_FLD bit and wait for its acceptance by polling OSPI\_FLASH\_CMD\_CTRL\_REG[1] CMD\_EXEC\_STATUS\_FLD bit. When CMD\_EXEC\_STATUS\_FLD bit turns de-asserted, another STIG can be triggered. This method of accessing the FLASH is the typical mechanism that software would use to access the FLASH device's registers, as well as for performing ERASE operations. It can also be used to access the FLASH array itself, although the maximum of 8 data bytes may be read or written at any one time, defined in the Flash Command Write and Read Data registers (OSPI\_FLASH\_RD\_DATA\_LOWER\_REG, OSPI\_FLASH\_RD\_DATA\_UPPER\_REG, OSPI\_FLASH\_WR\_DATA\_LOWER\_REG and OSPI\_FLASH\_WR\_DATA\_UPPER\_REG). This number of bytes can be extended for Read Data commands using additional STIG Memory Bank controlled by OSPI\_FLASH\_CMD\_CTRL\_REG[2] STIG\_MEM\_BANK\_EN\_FLD and OSPI\_FLASH\_COMMAND\_CTRL\_MEM\_REG.

Commands issued using this interface have a higher priority than all other READ accesses coming from data interface, and will therefore interrupt any READ commands being requested by the indirect or direct controllers.

#### **12.4.2.5.4 Using SPI Legacy Mode**

SPI legacy mode allows software to access the internal TX-FIFO and RX-FIFO directly, thus bypassing the direct, indirect and STIG controllers.

Legacy mode allows the user to issue any FLASH instruction to the device, but does place a heavy software overhead in order to manage the fill levels of the FIFO's effectively. This is because the legacy SPI core is bi-directional in nature, with data continuously being transferred in either direction while the chip select is enabled. Even if the driver only wishes to read data from the FLASH device, dummy data must be written out to ensure the chip select stays active, and vice versa for write transactions.

Since the TX-FIFO and RX-FIFO are of limited depth, software has a responsibility to maintain the FIFO levels to ensure the TX-FIFO does not become exhausted during the instruction execution and the RX-FIFO doesn't overflow. This can place a lot of overhead on software. Interrupts are provided to indicate when the fill levels

pass programmable watermarks, which are themselves programmable registers OSPI\_TX\_THRESH\_REG and OSPI\_RX\_THRESH\_REG.

The limited depth may impose the limitation over execution of some specific SPI commands in legacy mode. Note that the controller interprets all transmitted bytes as valid. For example, if the Flash Device was configured to return valid data after many dummy cycles, the TX FIFO could become full before the controller sends all of dummy data.

#### **12.4.2.5.5 Entering XIP Mode from POR**

XIP is a mode that can be entered in a non-volatile way if the device has XIP enabled as a non-volatile configuration setting. Software will not be able to discover the state of XIP from POR via FLASH status register reads as the only operation a FLASH device will recognize when XIP mode is enabled is an XIP read operation.

If it is already known that the device will enter XIP from POR, then the OSPI\_MODE\_BIT\_CONFIG\_REG[7-0] MODE\_FLD and OSPI\_CONFIG\_REG[18] ENTER\_XIP\_MODE\_IMM\_FLD bits should be set in initial boot.

If it is not already known that the device will enter XIP from POR, and XIP from POR may be supported by the attached FLASH device, then software can attempt to exit XIP mode by issuing an XIP exit command using a STIG command (via the OSPI\_FLASH\_CMD\_CTRL\_REG register). To do this, software must be aware of the mode bit requirements of that device, as XIP entry and exit changes per device.

#### **12.4.2.5.6 Entering XIP Mode Otherwise**

XIP mode is supported in most FLASH devices. Some of them use signature bits that are sent to the device immediately following the address bytes, other use signature bits and also require a FLASH device configuration register write to enable XIP. For the FLASH devices that must be compliant to the OSPI controller, the following steps can be taken by software to enter XIP mode:

1. Disable the DAC and INDAC (OSPI\_CONFIG\_REG[7] ENB\_DIR\_ACC\_CTRL\_FLD) to ensure no new data read accesses will be sent to the FLASH device.
2. (Optional)Configure the OSPI\_FLASH\_CMD\_CTRL\_REG to issue a VCR write to FLASH memory, because XIP mode must first be enabled for some devices.
3. Configure the XIP mode bits in the OSPI\_MODE\_BIT\_CONFIG\_REG[7-0] MODE\_FLD bit field.
4. Enable the local controllers XIP mode by setting OSPI\_CONFIG\_REG[17] ENTER\_XIP\_MODE\_FLD bit.
5. Re-enable the DAC and, if required, the INDAC.

#### **12.4.2.5.7 Exiting XIP Mode**

To exit XIP mode, software should first disable the DAC and INDAC to ensure no new data read accesses will be sent to the FLASH device. It should then set mode bits to other than the established in the corresponding Flash Device specifications. These are dependent on the FLASH device and manufacturer. Software should then reset OSPI\_CONFIG\_REG[17] ENTER\_XIP\_MODE\_FLD.

Note the FLASH device must see a READ instruction before it can disable its internal XIP mode state, so this means XIP mode will internally stay active until the next READ instruction is serviced. User must take care to ensure that XIP mode is disabled before the end of any READ sequence.

### 12.4.3 General-Purpose Memory Controller (GPMC)

This section describes the General-Purpose Memory Controller (GPMC) for the device.

#### 12.4.3.1 GPMC Overview

The General-Purpose Memory Controller is a unified memory controller dedicated for interfacing with external memory devices like:

- Asynchronous SRAM-like memories and application-specific integrated circuit (ASIC) devices
- Asynchronous, synchronous, and page mode (available only in non-multiplexed mode) burst NOR flash devices
- NAND flash
- Pseudo-SRAM devices

Figure 12-164 shows the GPMC0 module overview.



Figure 12-164. GPMC0 Overview

#### 12.4.3.1.1 GPMC Features

The main features of the GPMC are:

- 8-, 16- or 32-bit-wide data path to external memory device
- Supports up to 4 chip select regions of programmable size and programmable base addresses in a total address space of 1GB
- Supports on-the-fly error code detection using the Bose-Chaudhuri-Hocquenghem (BCH) ( $t = 4, 8, \text{ or } 16$ ) or Hamming code to improve the reliability of NAND with a minimum effect on software (NAND flash with 512-byte page size or greater)
- Fully pipelined operation for optimal memory bandwidth usage
- The clock to the external memory is provided from GPMC\_FCLK divided by 1, 2, 3, or 4
- Supports programmable autoclock gating when no access is detected
- Independent and programmable control signal timing parameters for setup and hold time on a per-chip basis. Parameters are set according to the memory device timing parameters with a timing granularity of one GPMC\_FCLK clock cycle.
- Flexible internal access time control (wait state) and flexible handshake mode using external WAIT pin monitoring

- Support bus keeping
- Support bus turnaround
- Prefetch and write-posting engine associated with DMA controller at system level to achieve full performance from the NAND device with minimum effect on NOR/SRAM concurrent access
- 32-bit interconnect target interface which supports non-wrapping and wrapping burst of up to 16x32 bits.

The GPMC supports the following various access types:

- Asynchronous read/write access
- Asynchronous read page access (4-8-16-32 Word16, 4-8-16 Word32)
- Synchronous read/write access
- Synchronous read/write burst access without wrap capability (4-8-16-32 Word16, 4-8-16 Word32)
- Synchronous read/write burst access with wrap capability (4-8-16-32 Word16, 4-8-16 Word32)
- Address-data-multiplexed (AD) access
- Address-address-data (AAD) multiplexed access
- Little-endian access only

The GPMC can communicate with a wide range of external devices:

- External asynchronous or synchronous 8-bit wide memory or device (non burst device)
- External asynchronous or synchronous 16-bit wide memory or device
- External asynchronous or synchronous 32-bit wide memory or device
- External 16-bit non-multiplexed NOR flash device
- External 16- and 32-bit address and data multiplexed NOR Flash device
- External 8-bit and 16-bit NAND flash device
- External 16-bit and 32-bit pseudo-SRAM (pSRAM) device

---

**Note**

Page mode is available only in non-multiplexed mode.

---

#### **12.4.3.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

### 12.4.3.2 GPMC Environment

The GPMC0 module is hereinafter referred to as GPMC.

This section describes the GPMC0 external connections (environment).

#### 12.4.3.2.1 GPMC Modes

This section shows four GPMC0 external connection options:

- [Figure 12-165](#) shows a connection between the GPMC0 and a 32-bit synchronous address/data-multiplexed external memory device.
- [Figure 12-166](#) shows a connection between the GPMC0 and a 16-bit synchronous address/data-multiplexed (or AAD-multiplexed but this protocol uses fewer address pins) external memory device.
- [Figure 12-167](#) shows a connection between the GPMC0 and a 16-bit synchronous non-multiplexed external memory device.
- [Figure 12-168](#) shows a connection between the GPMC0 and an 8-bit synchronous non-multiplexed external memory device.
- [Figure 12-169](#) shows a connection between the GPMC0 and an 8-bit NAND device.



gpmc-002\_32

i = 0 to 3

j = 0 to 1

**Figure 12-165. GPMC to 32-Bit Address/Data-Multiplexed Memory**



gpmc-002

i = 0 to 3  
j = 0 to 1

**Figure 12-166. GPMC to 16-Bit Address/Data-Multiplexed Memory**



gpmc-045

i = 0 to 3

j = 0 to 1

**Figure 12-167. GPMC to 16-Bit Non-Multiplexed Memory**



gpmc-045a

i = 0 to 3

j = 0 to 1

**Figure 12-168. GPMC to 8-Bit Non-Multiplexed Memory**



gpmc-003

i = 0 to 3

j = 0 to 1

**Figure 12-169. GPMC to 8-Bit NAND Device****12.4.3.2.2 GPMC I/O Signals**

Table 12-186 lists the GPMC subsystem input/output (I/O) pins.

**Table 12-186. GPMC I/O Signals (Controller Mode)**

| Module Pin      | Device Level Signal | I/O <sup>(1)</sup> | Description                                                                                                                                                               | Module Pin Reset Value <sup>(2)</sup> |
|-----------------|---------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| <b>GPMC0</b>    |                     |                    |                                                                                                                                                                           |                                       |
| A[22-0]         | GPMC0_A[22-0]       | O                  | 23-bit output address bus                                                                                                                                                 | -                                     |
| A[27-2]/D[31-0] | GPMC0_AD[31-0]      | I/O                | Multiplexed address/data                                                                                                                                                  | -                                     |
| nCS[3-0]        | GPMC0_CS[3-0]       | O                  | Chip-selects (active low)                                                                                                                                                 | -                                     |
| CLK             | GPMC0_CLK           | O                  | Clock generated for the external memory or device. For more information, see <i>GPMC0 Integration</i> .                                                                   | -                                     |
| CLKLB           |                     |                    |                                                                                                                                                                           |                                       |
| N/A             | GPMC0_FCLK_MUX      | O                  | Free running clock. GPMC functional clock (GPMC0_FCLK) propagated on a device pad. For more information on the GPMC0_FCLK_MUX integration, see <i>GPMC0 Integration</i> . | -                                     |
| nADV/ALE        | GPMC0_ADVn_ALE      | O                  | Address valid (active low). Also used as address latch enable (active high) for NAND protocol memories.                                                                   | -                                     |
| nOE/nRE         | GPMC0_OEn_REn       | O                  | Output enable (active low). Also used as read enable (active low) for NAND protocol memories.                                                                             | -                                     |
| nWE             | GPMC0_WEn           | O                  | Write enable (active low)                                                                                                                                                 | -                                     |
| nBE0/CLE        | GPMC0_BE0n_CLE      | O                  | Lower-byte enable (active low). Also used as command latch enable for NAND protocol memories.                                                                             | -                                     |
| nBE[3-1]        | GPMC0_BE[3-1]n      | O                  | Upper-byte enable (active low)                                                                                                                                            | -                                     |

**Table 12-186. GPMC I/O Signals (Controller Mode) (continued)**

| Module Pin | Device Level Signal | I/O <sup>(1)</sup> | Description                                                                                                                                                                                                                                                 | Module Pin<br>Reset Value <sup>(2)</sup> |
|------------|---------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| WAIT[1-0]  | GPMC0_WAIT[1-0]     | I                  | External wait signal for NOR and NAND protocol memories. Can be mapped on any of the chip-selects.                                                                                                                                                          | -                                        |
| nWP        | GPMC0_WPn           | O                  | Write protect (active low)                                                                                                                                                                                                                                  | -                                        |
| DIR        | GPMC0_DIR           | O                  | This signal can be used to control an external buffer direction. Also controls the signal direction of D[15-0]. Low during transmit (for write access: data OUT from GPMC0 to memory). High during receive (for read access: data IN from memory to GPMC0). | -                                        |

(1) I = Input; O = Output; I/O - Bidirectional

(2) HiZ = High Impedance

**Note**

For GPMC output clock signal (CLK) to work properly, the RXACTIVE bit of the appropriate CTRLMMR\_PADCONFIGy registers should be set to 0x1 because of retiming purposes.

**Note**

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

Table 12-187 shows the use of address and data GPMC pins based on the type of external device.

**Table 12-187. GPMC Pin Multiplexing Options**

| GPMC Pin    | Multiplexed Address Data 32-Bit Device | Multiplexed Address Data 16-Bit Device | non-multiplexed Address Data 16-Bit Device (incomplete 28-bit address range) | non-multiplexed Address Data 8-Bit Device (incomplete 28-bit address range) | 16-Bit NAND Device | 8-Bit NAND Device |
|-------------|----------------------------------------|----------------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--------------------|-------------------|
| GPMC0_A[22] | Not used                               | Not used                               | A22                                                                          | A22                                                                         | Not used           | Not used          |
| GPMC0_A[21] | Not used                               | Not used                               | A21                                                                          | A21                                                                         | Not used           | Not used          |
| GPMC0_A[20] | Not used                               | Not used                               | A20                                                                          | A20                                                                         | Not used           | Not used          |
| GPMC0_A[19] | Not used                               | Not used                               | A19                                                                          | A19                                                                         | Not used           | Not used          |
| GPMC0_A[18] | Not used                               | Not used                               | A18                                                                          | A18                                                                         | Not used           | Not used          |
| GPMC0_A[17] | Not used                               | Not used                               | A17                                                                          | A17                                                                         | Not used           | Not used          |
| GPMC0_A[16] | Not used                               | Not used                               | A16                                                                          | A16                                                                         | Not used           | Not used          |
| GPMC0_A[15] | Not used                               | Not used                               | A15                                                                          | A15                                                                         | Not used           | Not used          |
| GPMC0_A[14] | Not used                               | Not used                               | A14                                                                          | A14                                                                         | Not used           | Not used          |
| GPMC0_A[13] | Not used                               | Not used                               | A13                                                                          | A13                                                                         | Not used           | Not used          |
| GPMC0_A[12] | Not used                               | Not used                               | A12                                                                          | A12                                                                         | Not used           | Not used          |
| GPMC0_A[11] | Not used                               | Not used                               | A11                                                                          | A11                                                                         | Not used           | Not used          |
| GPMC0_A[10] | Not used                               | A26                                    | A10                                                                          | A10                                                                         | Not used           | Not used          |
| GPMC0_A[9]  | Not used                               | A25                                    | A9                                                                           | A9                                                                          | Not used           | Not used          |
| GPMC0_A[8]  | Not used                               | A24                                    | A8                                                                           | A8                                                                          | Not used           | Not used          |
| GPMC0_A[7]  | Not used                               | A23                                    | A7                                                                           | A7                                                                          | Not used           | Not used          |
| GPMC0_A[6]  | Not used                               | A22                                    | A6                                                                           | A6                                                                          | Not used           | Not used          |
| GPMC0_A[5]  | Not used                               | A21                                    | A5                                                                           | A5                                                                          | Not used           | Not used          |
| GPMC0_A[4]  | Not used                               | A20                                    | A4                                                                           | A4                                                                          | Not used           | Not used          |
| GPMC0_A[3]  | Not used                               | A19                                    | A3                                                                           | A3                                                                          | Not used           | Not used          |
| GPMC0_A[2]  | Not used                               | A18                                    | A2                                                                           | A2                                                                          | Not used           | Not used          |

Table 12-187. GPMC Pin Multiplexing Options (continued)

| GPMC Pin                  | Multiplexed Address Data 32-Bit Device | Multiplexed Address Data 16-Bit Device | non-multiplexed Address Data 16-Bit Device<br>(incomplete 28-bit address range) | non-multiplexed Address Data 8-Bit Device<br>(incomplete 28-bit address range) | 16-Bit NAND Device | 8-Bit NAND Device |
|---------------------------|----------------------------------------|----------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------|-------------------|
| GPMC0_A[1]                | Not used                               | A17                                    | A1                                                                              | A1                                                                             | Not used           | Not used          |
| GPMC0_A[0] <sup>(1)</sup> | Not used                               | A0 - Not used                          | Not used                                                                        | A0                                                                             | Not used           | Not used          |
| GPMC0_AD[31]              | D31                                    | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[30]              | D30                                    | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[29]              | D29                                    | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[28]              | D28                                    | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[27]              | D27                                    | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[26]              | D26                                    | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[25]              | A27/D25                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[24]              | A26/D24                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[23]              | A25/D23                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[22]              | A24/D22                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[21]              | A23/D21                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[20]              | A22/D20                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[19]              | A21/D19                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[18]              | A20/D18                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[17]              | A19/D17                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[16]              | A18/D16                                | Not used                               | Not used                                                                        | Not used                                                                       | Not used           | Not used          |
| GPMC0_AD[15]              | A17/D15                                | A16/D15                                | D15                                                                             | Not used                                                                       | D15                | Not used          |
| GPMC0_AD[14]              | A16/D14                                | A15/D14                                | D14                                                                             | Not used                                                                       | D14                | Not used          |
| GPMC0_AD[13]              | A15/D13                                | A14/D13                                | D13                                                                             | Not used                                                                       | D13                | Not used          |
| GPMC0_AD[12]              | A14/D12                                | A13/D12                                | D12                                                                             | Not used                                                                       | D12                | Not used          |
| GPMC0_AD[11]              | A13/D11                                | A12/D11                                | D11                                                                             | Not used                                                                       | D11                | Not used          |
| GPMC0_AD[10]              | A12/D10                                | A11/D10                                | D10                                                                             | Not used                                                                       | D10                | Not used          |
| GPMC0_AD[9]               | A11/D9                                 | A10/D9                                 | D9                                                                              | Not used                                                                       | D9                 | Not used          |
| GPMC0_AD[8]               | A10/D8                                 | A9/D8                                  | D8                                                                              | Not used                                                                       | D8                 | Not used          |
| GPMC0_AD[7]               | A9/D7                                  | A8/D7                                  | D7                                                                              | D7                                                                             | D7                 | D7                |
| GPMC0_AD[6]               | A8/D6                                  | A7/D6                                  | D6                                                                              | D6                                                                             | D6                 | D6                |
| GPMC0_AD[5]               | A7/D5                                  | A6/D5                                  | D5                                                                              | D5                                                                             | D5                 | D5                |
| GPMC0_AD[4]               | A6/D4                                  | A5/D4                                  | D4                                                                              | D4                                                                             | D4                 | D4                |
| GPMC0_AD[3]               | A5/D3                                  | A4/D3                                  | D3                                                                              | D3                                                                             | D3                 | D3                |
| GPMC0_AD[2]               | A4/D2                                  | A3/D2                                  | D2                                                                              | D2                                                                             | D2                 | D2                |
| GPMC0_AD[1]               | A3/D1                                  | A2/D1                                  | D1                                                                              | D1                                                                             | D1                 | D1                |
| GPMC0_AD[0]               | A2/D0                                  | A1/D0                                  | D0                                                                              | D0                                                                             | D0                 | D0                |

(1) Used to effectively address 8-bit (only) non-multiplexed memories

With all device types, the GPMC does not drive unnecessary address lines. They stay at their reset value of 0x0.

Address mapping supports address/data-multiplexed 16- or 32-bit-wide devices:

- The NOR flash memory controller still supports non-multiplexed address and data memory devices.
- Multiplexing mode can be selected through the GPMC\_CONFIG1\_i[9-8] MUXADDDATA bit field (where i = 0 to 3).

#### 12.4.3.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.4.3.4 GPMC Functional Description

The GPMC basic programming model offers maximum flexibility to support various access protocols for each of the four configurable chip-selects. Use optimal chip-select settings, based on the characteristics of the external device:

- Different protocols can be selected to support generic asynchronous or synchronous random-access devices (NOR flash, SRAM) or to support specific NAND devices.
- The address and data bus can be multiplexed on the same external bus.
- Read and write access can be independently defined as asynchronous or synchronous.
- System requests (byte, 16-bit word, burst) are performed through single or multiple accesses. External access profiles (single, multiple with optimized burst length, native- or emulated-wrap) are based on external device characteristics (supported protocol, bus width, data buffer size, native-wrap support).
- System burst read or write requests are synchronous-burst (multiple-read or multiple-write). When neither burst nor page mode is supported by external memory or ASIC devices, system burst read or write requests are translated to successive single synchronous or asynchronous accesses (single reads or single writes). 8-bit wide devices are supported only in single synchronous or single asynchronous read or write mode.
- To simulate a programmable internal-wait-state, an external WAIT pin can be monitored to dynamically control external access at the beginning (initial access time) of and during a burst access.

Each control signal is controlled independently for each chip-select. The internal functional clock of the GPMC (GPMC\_FCLK) is used as a time reference to specify the following:

- Read- and write-access duration
- Most GPMC external interface control-signal assertion and deassertion times
- Data-capture time during read access
- External wait-pin monitoring time
- Duration of idle time between accesses, when required

##### 12.4.3.4.1 GPMC Block Diagram

Figure 12-170 shows the GPMC functional block diagram. The GPMC consists of six blocks:

- Interconnect port interface
- Address decoder, GPMC configuration, and chip-select configuration register file
- Access engine
- Prefetch and write-posting engine
- Error correction code engine (ECC)
- External device/memory port interface



**Figure 12-170. GPMC Block Diagram**

The GPMC can access various external devices. The flexible programming model allows a wide range of attached device types and access schemes.

Based on the programmed configuration bit fields stored in the GPMC registers, the GPMC can generate the timing of all control signals depending on the attached device and access type.

Given the chip-select decoding and its associated configuration registers, the GPMC selects the appropriate control signal timing for the device type.

#### 12.4.3.4.2 GPMC Clock Configuration

Table 12-188 describes the GPMC clocks.

Table 12-188. GPMC Clocks

| Signal                      | I/O <sup>(1)</sup> | Description                                                                               |
|-----------------------------|--------------------|-------------------------------------------------------------------------------------------|
| GPMC_FCLK                   | I                  | Functional clock                                                                          |
| GPMC_ICLK                   | I                  | Interface clock                                                                           |
| CLK<br>(GPMC_CLKOUT<br>pin) | O                  | External clock provided to synchronous external memory devices and to DCC5 in the device. |

(1) I = Input; O = Output; I/O - Bidirectional

The GPMC output clock (CLK) is generated by the GPMC from the internal GPMC\_FCLK clock. The source of the GPMC\_FCLK is described in *GPMC0 Clocks*. The GPMC output clock is configured using the GPMC\_CONFIG1\_i[1-0] GPMCFCLKDIVIDER bit field (where i = 0 to 3), as shown in [Table 12-189](#).

Table 12-189. GPMC Output Clock Configuration

| Source Clock | GPMC_CONFIG1_i[1-0]<br>GPMCFCLKDIVIDER | GPMC Output Clock<br>Provided to External Memory Device |
|--------------|----------------------------------------|---------------------------------------------------------|
| GPMC_FCLK    | 00                                     | GPMC_FCLK                                               |
|              | 01                                     | GPMC_FCLK/2                                             |
|              | 10                                     | GPMC_FCLK/3                                             |
|              | 11                                     | GPMC_FCLK/4                                             |

When using synchronous interface protocols, the GPMC output clock (CLK), toggles only during the read or write access cycle. In some applications, it may be desirable to have a continuous clock running at the GPMC interface clock frequency for clocking attached devices. This option is enabled by an optional clock path from the GPMC functional clock input (GPMC\_FCLK) to the GPMC\_FCLK\_MUX pin. This output clock, to GPMC\_FCLK\_MUX pin, can be selected through the standard MUXMODE selection of the GPMC\_FCLK\_MUX pin PADCONFIG control register.

Note that when using such synchronous interface protocols with the continuous clock option, user should ensure that the GPMC outputs are timed to the same frequency (GPMC\_CONFIG1\_i[1-0] GPMCFCLKDIVIDER = 0).

#### 12.4.3.4.3 GPMC Power Management

[Table 12-190](#) describes the local power-management features available for the GPMC module.

Table 12-190. GPMC Local Power-Management Features

| Feature           | Registers                     | Description                                                                                                             |
|-------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| Clock autogating  | GPMC_SYSCONF/G[0] AUTOIDLE    | This bit allows a local power optimization inside the module, by gating the GPMC_ICLK clock upon the internal activity. |
| Target idle modes | GPMC_SYSCONF/G[4-3] SIDLEMODE | Force-idle, no-idle and smart-idle modes are available.                                                                 |

#### 12.4.3.4.4 GPMC Interrupt Requests

The GPMC generates one interrupt request (see *GPMC0 Hardware Requests*).

[Table 12-191](#) lists the event flags, and their mask, that can cause module interrupts.

Table 12-191. GPMC Interrupt Events

| Event Flag                                        | Event Mask                                        | Sensitivity | Description                                                                                                                                                                                                            |
|---------------------------------------------------|---------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPMC_IRQSTATUS[9]<br>WAIT1EDGE<br>DETECTIONSTATUS | GPMC_IRQENABLE[9]<br>WAIT1EDGE<br>DETECTIONENABLE | Edge        | Wait1 edge detection interrupt: Triggered if a rising or falling edge is detected on the GPMC_WAIT1 signal. The rising or falling edge detection of Wait1 is selected through the GPMC_CONFIG[9] WAIT1PINPOLARITY bit. |

**Table 12-191. GPMC Interrupt Events (continued)**

| Event Flag                                        | Event Mask                                        | Sensitivity | Description                                                                                                                                                                                                            |
|---------------------------------------------------|---------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPMC_IRQSTATUS[8]<br>WAIT0EDGE<br>DETECTIONSTATUS | GPMC_IRQENABLE[8]<br>WAIT0EDGE<br>DETECTIONENABLE | Edge        | Wait0 edge detection interrupt: Triggered if a rising or falling edge is detected on the GPMC_WAIT0 signal. The rising or falling edge detection of Wait0 is selected through the GPMC_CONFIG[8] WAIT0PINPOLARITY bit. |
| GPMC_IRQSTATUS[1]<br>TERMINAL<br>COUNTSTATUS      | GPMC_IRQENABLE[1] TERMINAL<br>COUNTENABLE         | Level       | Terminal count event: Triggered on prefetch process completion; that is, when the number of currently remaining data to be requested reaches 0.                                                                        |
| GPMC_IRQSTATUS[0]<br>FIFOEVENTSTATUS              | GPMC_IRQENABLE[0]<br>FIFOEVENTENABLE              | Level       | FIFO event interrupt: Indicates available FIFO levels for write-posting mode and prefetch mode. GPMC_PREFETCH_CONFIG1[2] DMAMODE must be set to 0.                                                                     |

#### 12.4.3.4.5 GPMC Interconnect Port Interface

##### Note

Some of the GPMC features described in this section may not be supported on this family of devices. For more information, see *GPMC Not Supported Features*.

The GPMC interconnect interface is a pipelined interface including a  $16 \times 32$ -bit word write buffer.

Any system host can issue external access requests through the GPMC.

The device system can issue the following requests through this interface:

- One 8-, 16-, or 32-bit interconnect access (read/write)
- Two incrementing 32-bit interconnect accesses (read/write)
- Two wrapped 32-bit interconnect accesses (read/write)
- Four incrementing 32-bit interconnect accesses (read/write)
- Four wrapped 32-bit interconnect accesses (read/write)
- Eight incrementing 32-bit interconnect accesses (read/write)
- Eight wrapped 32-bit interconnect accesses (read/write)

Only linear burst transactions are supported; interleaved burst transactions are not supported. Only power-of-two-length precise bursts  $2 \times 32$ ,  $4 \times 32$ ,  $8 \times 32$ , and  $16 \times 32$ , with the burst base address aligned on the total burst size, are supported (this limitation applies to incrementing bursts only).

This interface also provides one interrupt and one DMA request line for specific event control.

It is recommended to program the *GPMC\_CONFIG1\_i[24-23] ATTACHEDDEVICEPAGELENGTH* bit field according to the page length of the effective attached device and to enable the *GPMC\_CONFIG1\_i[31] WRAPBURST* bit if the attached device supports wrapping burst.

It is possible, however, to emulate wrapping burst on a nonwrapping memory by providing relevant addresses within the page or by splitting transactions. Bursts larger than the memory page length are chopped into multiple burst transactions. Because of the alignment requirements, a page boundary is never crossed.

#### 12.4.3.4.6 GPMC Address and Data Bus

The current application supports GPMC connection to NAND devices and to address/data-multiplexed memories or devices. Connection to address/data-non-multiplexed memories or devices is supported with an address range of 256MB.

Depending on the GPMC configuration of each chip-select, address and data bus lines that are not required for a particular access protocol are not updated (changed from current value) and are not sampled when input (input data bus).

- For address/data-multiplexed and AAD-multiplexed NOR devices, the address is multiplexed on the data bus.

- 8-bit-wide NOR devices do not use GPMC I/O: GPMC\_AD[15-8] for data (they are used for address if needed).
- 16-bit-wide NAND devices do not use GPMC I/O: GPMC\_A[22-0].
- 8-bit-wide NAND devices do not use GPMC I/O: GPMC\_A[22-0] and GPMC I/O: GPMC\_AD[15-8].

#### 12.4.3.4.6.1 GPMC I/O Configuration Setting

---

##### Note

In this section and the following sections, the *i* in GPMC\_CONFIG*x\_i* stands for the GPMC chip-select *i*, where *i* = 0 to 3.

---

To select a NAND device, program the following register fields:

- GPMC\_CONFIG1\_0[11-10] DEVICETYPE = 0b10
- GPMC\_CONFIG1\_0[9-8] MUXADDDATA = 0b00

To select an address/data-multiplexed device, program the following register fields:

- GPMC\_CONFIG1\_0[11-10] DEVICETYPE = 0b00
- GPMC\_CONFIG1\_0[9-8] MUXADDDATA = 0b10

To select an address/address/data-multiplexed device, program the following register fields:

- GPMC\_CONFIG1\_0[11-10] DEVICETYPE = 0b00
- GPMC\_CONFIG1\_0[9-8] MUXADDDATA = 0b01

To select an address/data-non-multiplexed device, program the following register fields:

- GPMC\_CONFIG1\_0[11-10] DEVICETYPE = 0b00
- GPMC\_CONFIG1\_0[9-8] MUXADDDATA = 0b00

#### 12.4.3.4.7 GPMC Address Decoder and Chip-Select Configuration

Addresses are decoded accordingly with the address request of the chip-select and the content of the chip-select base address register file, which includes a set of global GPMC configuration registers and four sets of chip-select configuration registers.

The GPMC configuration register file is memory-mapped and can be read or written with byte, 16-bit word, or 32-bit word accesses. The register file must be configured as a noncacheable, nonbufferable region to prevent any desynchronization between host execution (write request) and the completion of register configuration (write completed with register updated).

After the chip-select is configured, the access engine accesses the external device, drives the external interface control signals, and applies the interface protocol based on user-defined timing parameters and settings.

#### 12.4.3.4.7.1 Chip-Select Base Address and Region Size

Any external memory or ASIC device attached to the GPMC external interface can be accessed by any device system host within the GPMC 128MB address space. For more information, see *Memory Map*.

---

##### Note

Even though GPMC supports total address space of 1GB, only 128MB are physically available in this device.

---

The GPMC 128MB address space can be divided into a maximum of four chip-select regions with programmable base address and programmable chip-select size. The chip-select size is programmable from 16MB to 256MB (must be a power-of-two) and is defined by the mask field. Attached memory smaller than the programmed chip-select region size is accessed through the entire chip-select region (aliasing).

Each chip-select has a 6-bit base address encoding and 4-bit decoding mask, which must be programmed according to the following rules:

- The programmed chip-select region base address must be aligned on the chip-select region size address boundary and is limited to a power-of-two address value. During access decoding, the value of the register base address is used to compare the address with the address bit line mapping, as shown in [Figure 12-171](#) (with A0 as the device system byte-address line). The base address is programmed through the GPMC\_CONFIG7\_i[5-0] BASEADDRESS bit field.
- The register mask is used to exclude some address lines from the decoding. A register mask bit field set to 0 suppresses the associated address line from the address comparison (incoming address bit line is don't care). The value of the register mask must be limited to the subsequent value, based on the desired chip-select region size. Any other value has an undefined result. When multiple chip-select regions with overlapping addresses are enabled concurrently, access to these chip-select regions is cancelled and a GPMC access error is posted. The mask field is programmed through the GPMC\_CONFIG7\_i[11-8] MASKADDRESS bit field.



**Figure 12-171. Chip-Select Address Mapping and Decoding Mask**

For example, to map the 128MB address space (from 2000 0000h to 27FF FFFFh), the GPMC\_CONFIG7\_i[5-0] BASEADDRESS bit field should be set to 20h.

Chip-select configuration (base and mask address or any protocol and timing settings) must be performed while the associated chip-select is disabled through the GPMC\_CONFIG7\_i[6] CSVALID bit (where i stands for the GPMC chip-select i, where i = 0 to 3). In addition, a chip-select configuration can be disabled only if there is no ongoing access to that chip-select. This requires monitoring the activity of the prefetch or write-posting engine if the engine is active on the chip-select. Also, the write buffer state must be monitored to wait for any posted write completion to the chip-select.

Any access attempted to a nonvalid GPMC address region (CSVALID disabled or address decoding outside a valid chip-select region) is not propagated to the external interface and a GPMC access error is posted. In case of overlapping chip-selects, an error is generated and no access occurs on either chip-select.

CS0 is the only chip-select region enabled after a power up or GPMC reset.

**CAUTION**

Although the GPMC interface can drive up to four chip-selects, the frequency specified for this interface is for a specific load. If this load is exceeded, the maximum frequency cannot be reached. One solution is to implement a board with buffers to allow the slowest device to maintain the total load on the lines at the value specified in the device-specific Datasheet.

**12.4.3.4.7.2 Access Protocol**
**12.4.3.4.7.2.1 Supported Devices**

The access protocol of each chip-select can be independently specified through the *GPMC\_CONFIG1\_i[11-10]* DEVICETYPE parameter (where *i* = 0 to 3) for:

- Random-access synchronous or asynchronous memory, such as NOR flash and SRAM
- NAND flash asynchronous devices

**Note**

For more information about the NAND flash GPMC basic programming model and NAND support, see [Section 12.4.3.4.11, GPMC NAND Device Basic Programming Model](#), and [Section 12.4.3.4.11.1, NAND Memory Device in Byte or Word16 Stream Mode](#).

**12.4.3.4.7.2.2 Access Size Adaptation and Device Width**

Each chip-select can be independently configured through the *GPMC\_CONFIG1\_i[13-12]* DEVICESIZE bit field (where *i* = 0 to 3) to interface with a 16- or 8-bit-wide device. System requests with data width greater than the external device data bus width are split into successive accesses according to the external device data-bus width and little-endian data organization.

**12.4.3.4.7.2.3 Address/Data-Multiplexing Interface**

For random synchronous or asynchronous memory interfacing (DEVICETYPE = 0b00), an address- and data-multiplexing protocol can be selected through the *GPMC\_CONFIG1\_i[9-8]* MUXADDDATA bit field (where *i* = 0 to 3). The nADV signal must be used as the external device address latch control signal. For the associated chip-select configuration, nADV assertion and deassertion time and nOE assertion time must be set to the appropriate value to meet the address latch setup/hold time requirements of the external device. See *Module Integration*.

**Note**

This address/data-multiplexing interface is not applicable to NAND device interfacing. NAND devices require a specific address, command, and data-multiplexing protocol. See [Section 12.4.3.4.11, NAND Device Basic Programming Model](#).

**12.4.3.4.7.3 External Signals**
**12.4.3.4.7.3.1 WAIT Pin Monitoring Control**

GPMC access time can be dynamically controlled using an external GPMC\_WAIT pin when the external device access time is not deterministic and cannot be defined and controlled using only the GPMC internal RDACCESSTIME, WRACCESSTIME, and PAGEBURSTACCESSTIME wait-state generator.

The GPMC features two input WAIT pins: GPMC\_WAIT1, and GPMC\_WAIT0. These pins allow control of external devices with different WAIT pin polarity. They also allow the overlap of WAIT pin assertion from different devices without affecting access to devices for which the WAIT pin is not asserted.

- The *GPMC\_CONFIG1\_i[17-16]* WAITPINSELECT bit field (where *i* = 0 to 3) selects which input GPMC\_WAIT pin is used for the device attached to the corresponding chip-select.

- The polarity of the WAIT pin is defined through the WAITxPINPOLARITY bit of the GPMC\_CONFIG register. A WAIT pin configured to be active low means that low level on the WAIT signal indicates that the data is not ready and that the data bus is invalid. When a WAIT pin is inactive, data is valid.

The GPMC access engine can be configured per chip-select to monitor or not the WAIT pin of the external memory device, based on the access type: read or write.

- The GPMC\_CONFIG1\_i[22] WAITREADMONITORING bit defines whether or not the WAIT pin must be monitored during read accesses.
- The GPMC\_CONFIG1\_i[21] WAITWRITEMONITORING bit defines whether or not the WAIT pin must be monitored during write accesses.

The GPMC access engine can be configured to monitor the WAIT pin of the external memory device asynchronously or synchronously with the GPMC output clock, depending on the access type: synchronous or asynchronous (the GPMC\_CONFIG1\_i[29] READTYPE and GPMC\_CONFIG1\_i[27] WRITETYPE bits).

#### **12.4.3.4.7.3.1.1 Wait Monitoring During Asynchronous Read Access**

When WAIT pin monitoring is enabled for read accesses (WAITREADMONITORING), the effective access time is a logical AND combination of the RDACCESSTIME timing completion and the wait-deasserted state.

During asynchronous read accesses with WAIT pin monitoring enabled, the WAIT pin must be at a valid level (asserted or deasserted) for at least two GPMC clock cycles before RDACCESSTIME completes, to ensure correct dynamic access-time control through WAIT pin monitoring. The advance pipelining of the two GPMC clock cycles is the result of the internal synchronization requirements for the WAIT signal.

In this context, RDACCESSTIME is used as a wait invalid timing window and is set to such a value that the WAIT pin is at a valid state two GPMC clock cycles before RDACCESSTIME completes.

Similarly, during a multiple-access cycle (for example, asynchronous read page mode), the effective access time is a logical AND combination of PAGEBURSTACCESSTIME timing completion and the wait-deasserted state. Wait monitoring pipelining is also applicable to multiple accesses (access within a page).

- Wait monitored as active freezes the CYCLETIME counter. For an access within a page, when the CYCLETIME counter is by definition in a lock state, wait monitored as asserted extends the current access time in the page. Control signals are kept in their current state. The data bus is considered invalid, and no data are captured during this clock cycle.
- Wait monitored as inactive unfreezes the CYCLETIME counter. For an access within a page, when the CYCLETIME counter is by definition in a lock state, wait monitored as inactive completes the current access time and starts the next access phase in the page. The data bus is considered valid, and data are captured during this clock cycle. In case of a single access or if this was the last access in a multiple-access cycle, all signals are controlled according to their related control timing value and according to the CYCLETIME counter status.

When a delay larger than two GPMC clocks must be observed between wait-pin deactivation time and data valid time (including the required GPMC and the device data setup time), an extra delay can be added between wait-pin deassertion time detection and effective data-capture time and the effective unlock of the CYCLETIME counter. This extra delay can be programmed in the GPMC\_CONFIG1\_i[19-18] WAITMONITORINGTIME bit field (where i = 0 to 3).

---

#### **Note**

- The WAITMONITORINGTIME parameter does not delay the WAIT pin active or inactive detection, nor does it modify the two GPMC clocks pipelined detection delay.
- This extra delay is expressed as a number of GPMC output clock cycles, even though the access is defined as asynchronous, and no GPMC output clock is provided to the external device. Still, because GPMC\_CONFIG1\_i[1-0] GPMCFCLKDIVIDER is used as a divider for the GPMC clock, it must be programmed to define the correct WAITMONITORINGTIME delay.

---

Figure 12-172 shows wait behavior during an asynchronous single read access.



**Figure 12-172. Wait Behavior During an Asynchronous Single Read Access (GPMCFCLKDivider = 1)**

## Note

The WAIT signal is active low. *GPMC\_CONFIG1* [19-18] WAITMONITORINGTIME = 0b00, or 0b01.

### **12.4.3.4.7.3.1.2 Wait Monitoring During Asynchronous Write Access**

When WAIT pin monitoring is enabled for write accesses (*GPCM\_CONFIG1\_i[21]* WAITWRITEMONITORING bit = 0x1), the wait invalid timing window is defined by the WRACCESSTIME field. WRACCESSTIME must be set so that the WAIT pin is at a valid state two GPMC clock cycles before WRACCESSTIME completes. The advance pipelining of the two GPMC clock cycles is the result of the internal synchronization requirements for the WAIT signal.

- Wait monitored as active freezes the CYCLETIME counter. This informs the GPMC that the data bus is not captured by the external device. The control signals are kept in their current state. The data bus still drives the data.
  - Wait monitored as inactive unfreezes the CYCLETIME counter. This informs that the data bus is correctly captured by the external device. All signals, including the data bus, are controlled according to their related control timing value and to the CYCLETIME counter status.

When a delay larger than two GPMC clock cycles must be observed between wait-pin deassertion time and the effective data write into the external device (including the required GPMC data setup time and the device data setup time), an extra delay can be added between wait-pin deassertion time detection and effective data write

time into the external device and the effective unfreezing of the CYCLETIME counter. This extra delay can be programmed in the *GPMC\_CONFIG1\_i[19-18]* WAITMONITORINGTIME bit field (where  $i = 0$  to  $3$ ).

**Note**

- The WAITMONITORINGTIME parameter does not delay the WAIT pin assertion or deassertion detection, nor does it modify the two GPMC clock cycles pipelined detection delay.
- This extra delay is expressed as a number of GPMC output clock cycles, even though the access is defined as asynchronous, and even though no clock is provided to the external device. Still, because the *GPMC\_CONFIG1\_i[1-0]* GPMCFCLKDIVIDER bit field is used as a divider for the GPMC clock, it must be programmed to define the correct WAITMONITORINGTIME delay.

#### 12.4.3.4.7.3.1.3 Wait Monitoring During Synchronous Read Access

During synchronous accesses with WAIT pin monitoring enabled, the WAIT pin is captured synchronously with GPMC output clock, using the rising edge of this clock.

The WAIT signal can be programmed to apply to the same clock cycle in which it is captured. Alternatively, it can be sampled one or two GPMC output clock cycles ahead of the clock cycle to which it applies. This pipelining is applicable to the entire burst access and to all data phases in the burst access. This wait pipelining depth is programmed in the *GPMC\_CONFIG1\_i[19-18]* WAITMONITORINGTIME bit field (where  $i = 0$  to  $3$ ), and is expressed as a number of GPMC output clock cycles.

In synchronous mode, when WAIT pin monitoring is enabled (the *GPMC\_CONFIG1\_i[22]* WAITREADMONITORING bit), the effective access time is a logical AND combination of the RDACCESSTIME timing completion and the wait-deasserted state detection.

Depending on the programmed value of WAITMONITORINGTIME, the WAIT pin must be at a valid level, either asserted or deasserted:

- In the same clock cycle the data is valid if WAITMONITORINGTIME = 0 (at RDACCESSTIME completion)
- In the WAITMONITORINGTIME  $x$  (GPMCFCLKDIVIDER + 1) GPMC\_FCLK clock cycles before RDACCESSTIME completion if WAITMONITORINGTIME is not equal to 0

Similarly, during a multiple-access cycle (burst mode), the effective access time is a logical AND combination of PAGEBURSTACCESSTIME timing completion and the WAIT-INACTIVE state. The wait pipelining-depth programming applies to the whole burst access.

- Wait monitored as active freezes the CYCLETIME counter. For an access within a burst (when the CYCLETIME counter is by definition in a lock state), wait monitored as active extends the current access time in the burst. Control signals are kept in their current state. The data bus is considered invalid, and no data are captured during this clock cycle.
- Wait monitored as inactive unfreezes the CYCLETIME counter. For an access within a burst (when the CYCLETIME counter is by definition in lock state), wait monitored as inactive completes the current access time and starts the next access phase in the burst. The data bus is considered valid, and data are captured during this clock cycle. In a single access or if this was the last access in a multiple-access cycle, all signals are controlled according to their relative control timing value and the CYCLETIME counter status.

Figure 12-173 shows wait behavior during a synchronous read burst access.



**Figure 12-173. Wait Behavior During a Synchronous Read Burst Access**

#### Note

The WAIT signal is active low. WAITMONITORINGTIME = 0b00, 0b01.

#### 12.4.3.4.7.3.1.4 Wait Monitoring During Synchronous Write Access

During synchronous accesses with WAIT pin monitoring enabled (the *GPMC\_CONFIG1\_i[21]* WAITWRITEMONITORING bit), the WAIT pin is captured synchronously with GPMC output clock, using the rising edge of this clock.

If enabled, external WAIT pin monitoring can be used in combination with WRACCESSTIME to delay the GPMC output clock capture edge of the effective memory device.

WAIT-monitoring pipelining depth is similar to synchronous read access:

- At WRACCESSTIME completion if WAITMONITORINGTIME = 0
- In the WAITMONITORINGTIME x (GPMCFCLKDIVIDER + 1) GPMC\_FCLK cycles before WRACCESSTIME completion if WAITMONITORINGTIME is not equal to 0

Wait-monitoring pipelining definition applies to whole burst accesses:

- Wait monitored as active freezes the CYCLETIME counter. For accesses within a burst, when the CYCLETIME counter is by definition in a lock state, wait monitored as active indicates that the data bus is not being captured by the external device. Control signals are kept in their current state. The data bus is kept in its current state.
- Wait monitored as inactive unfreezes the CYCLETIME counter. For accesses within a burst, when the CYCLETIME counter is by definition in a lock state, wait monitored as inactive indicates the effective data capture of the bus by the external device and starts the next access of the burst. In case of a single access or if this was the last access in a multiple access cycle, all signals, including the data bus, are controlled according to their related control timing value and the CYCLETIME counter status.

---

**Note**

WAIT monitoring is supported for all configurations except *GPMC\_CONFIG1\_i[19-18]*  
 WAITMONITORINGTIME = 0x0 (where  $i = 0$  to 3) for write bursts with a clock divider of 1 or 2  
 (the *GPMC\_CONFIG1\_i[1-0]* GPMCFCLKDIVIDER bit field is equal to 0x0 or 0x1, respectively).

---

#### **12.4.3.4.7.3.1.5 Wait With NAND Device**

For information about the use of the WAIT pin for communication with a NAND flash external device, see [Section 12.4.3.4.11.2, NAND Device-Ready Pin](#).

#### **12.4.3.4.7.3.1.6 Idle Cycle Control Between Successive Accesses**

##### **12.4.3.4.7.3.1.6.1 Bus Turnaround (BUSTURNAROUND)**

To prevent data-bus contention, an access that follows a read access to a slow memory/device must be delayed (in other words, control the nCS/nOE deassertion to data bus in high-impedance delay).

The bus turnaround is a time-out counter starting after nCS or nOE deassertion time, whichever occurs first, and delays the next access start-cycle time. The counter is programmed through the *GPMC\_CONFIG6\_i[3-0]* BUSTURNAROUND bit field (where  $i = 0$  to 3).

After a read access to a chip-select with a nonzero BUSTURNAROUND, the next access is delayed until the BUSTURNAROUND delay completes, if the next access is one of the following:

- A write access to any chip-select (the same or different chip-select from which the data was read)
- A read access to a different chip-select than the chip-select from which the data was read access
- A read or write access to a chip-select associated with an address/data-multiplexed device

---

**Note**

Bus keeping starts after bus turnaround completion so that DIR changes from IN to OUT after bus turnaround. The bus does not have enough time to go into high-impedance even though it can be driven with the same value before bus turnaround timing.

---

BUSTURNAROUND delay runs in parallel with *GPMC\_CONFIG6\_i[3-0]* CYCLE2CYCLEDELAY bit field delays. BUSTURNAROUND is a timing parameter for the ending chip-select access, while CYCLE2CYCLEDELAY is a timing parameter for the following chip-select access. The effective minimum delay between successive accesses is driven by these delay timing parameters and by the access type of the following access (see [Figure 12-174](#) through [Figure 12-176](#)).

Another way to prevent bus contention is to define an earlier nCS or nOE deassertion time for slow devices or to extend the value of RDCYCLETIME. Doing this prevents bus contention, but it also affects all accesses of this specific chip-select.



**Figure 12-174. Read-to-Read for an Address-Data Multiplexed Device, on Different Chip-Select, Without Bus Turnaround (nCS Attached to a Fast Device)**



**Figure 12-175. Read- to-Read/Write for an Address-Data Multiplexed Device, on Different Chip-Select, With Bus Turnaround**



**Figure 12-176. Read-to-Read/Write for a Address-Data or AAD-Multiplexed Device, on Same Chip-Select, With Bus Turnaround**

#### 12.4.3.4.7.3.1.6.2 Idle Cycles Between Accesses to Same Chip-Select (CYCLE2CYCLESAMECSEN, CYCLE2CYCLEDELAY)

Some devices require a minimum chip-select signal inactive time between accesses. The *GPMC\_CONFIG6\_i[7]* CYCLE2CYCLESAMECSEN bit (where *i* = 0 to 3) enables insertion of a minimum number of GPMC\_FCLK cycles, defined by the *GPMC\_CONFIG6\_i[11-8]* CYCLE2CYCLEDELAY bit field, between successive accesses of any type (read or write) to the same chip-select.

If CYCLE2CYCLESAMECSEN is enabled, any subsequent access to the same chip-select is delayed until its CYCLE2CYCLEDELAY completes. The CYCLE2CYCLEDELAY counter starts when CSRDOFFTIME/CSWROFFTIME completes.

The same applies to successive accesses occurring during 32-bit word or burst accesses split into successive single accesses when the single-access mode is used (*GPMC\_CONFIG1\_i[30]* READMULTIPLE = 0 or *GPMC\_CONFIG1\_i[28]* WRITEMULTIPLE = 0).

All control signals (CS, ADV#/ALE, BE0#/CLE, WE#, and GPMC output clock (CLK)) are kept inactive (ADV#/ALE, BE0#/CLE, and GPMC output clock at low level; and CS, OE#/RE, and WE at high level) during the idle GPMC\_FCLK cycles. This prevents back-to-back accesses to the same chip-select without idle cycles between accesses.

#### 12.4.3.4.7.3.1.6.3 Idle Cycles Between Accesses to Different Chip-Select (CYCLE2CYCLEDIFFCSEN, CYCLE2CYCLEDELAY)

Because of the pipelined behavior of the system, successive accesses to different chip-selects can occur back-to-back with no idle cycles between accesses. Depending on the control signals (nCS, nADV/ALE, nBE0/CLE, nOE/RE, nWE) assertion and deassertion timing parameters and on the device timing parameters, the assertion times of some control signals may overlap between the successive accesses to a different chip-select. Similarly, some control signals (WE, OE/RE) may not respect required transition times.

To work around overlapping and to observe the required control-signal transitions, a minimum of CYCLE2CYCLEDELAY inactive cycles is inserted between the access being initiated to this chip-select and the previous access ending for a different chip-select. This applies to any type of access (read or write).

If the *GPMC\_CONFIG6\_i[6]* CYCLE2CYCLEDIFFCSEN bit is enabled, the chip-select access is delayed until CYCLE2CYCLEDELAY cycles have expired since the end of a previous access to a different chip-select.

CYCLE2CYCLEDELAY count starts at CSRDOFFTIME/CSWROFFTIME completion. All control signals are kept inactive during the idle GPMC\_FCLK cycles.

---

**Note**

CYCLE2CYCLESAMECSEN and CYCLE2CYCLEDIFFCSEN must be set in the *GPMC\_CONF/G6\_i* registers to get idle cycles inserted between accesses on this chip-select and after accesses to a different chip-select, respectively.

The CYCLE2CYCLEDELAY delay runs in parallel with the BUSTURNAROUND delay. The BUSTURNAROUND is a timing parameter defined for the ending chip-select access, whereas CYCLE2CYCLEDELAY is a timing parameter defined for the starting chip-select access. The effective minimum delay between successive accesses is based on the larger delay timing parameter and on access type combination, because bus turnaround does not apply to all access types. For more information about bus turnaround, see [Section 4.3.4.7.3.1.6.1, Bus Turnaround \(BUSTURNAROUND\)](#).

---

Table 12-192 describes the configuration required for idle cycle insertion.

**Table 12-192. Idle Cycle Insertion Configuration**

| 1st Access Type | BUSTURN AROUND Timing Parameter | Second Access Type | Chip-Select | Add/Data Multiplexed | CYCLE2 CYCLE SAMECSEN Parameter | CYCLE2 CYCLE DIFFCSEN Parameter | Idle Cycle Insertion Between the Two Accesses                                                                                                                                |
|-----------------|---------------------------------|--------------------|-------------|----------------------|---------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R/W             | = 0                             | R/W                | Any         | Any                  | 0                               | x                               | No idle cycles are inserted if the two accesses are well pipelined.                                                                                                          |
| R               | > 0                             | R                  | Same        | Nonmuxed             | x                               | 0                               | No idle cycles are inserted if the two accesses are well pipelined.                                                                                                          |
| R               | > 0                             | R                  | Different   | Nonmuxed             | 0                               | 0                               | BUSTURNAROUND cycles are inserted.                                                                                                                                           |
| R               | > 0                             | R/W                | Any         | Muxed                | 0                               | 0                               | BUSTURNAROUND cycles are inserted.                                                                                                                                           |
| R               | > 0                             | W                  | Any         | Any                  | 0                               | 0                               | BUSTURNAROUND cycles are inserted.                                                                                                                                           |
| W               | > 0                             | R/W                | Any         | Any                  | 0                               | 0                               | No idle cycles are inserted if the two accesses are well pipelined.                                                                                                          |
| R/W             | = 0                             | R/W                | Same        | Any                  | 1                               | x                               | CYCLE2CYCLEDELAY cycles are inserted.                                                                                                                                        |
| R/W             | = 0                             | R/W                | Different   | Any                  | x                               | 1                               | CYCLE2CYCLEDELAY cycles are inserted.                                                                                                                                        |
| R/W             | > 0                             | R/W                | Same        | Any                  | 1                               | x                               | CYCLE2CYCLEDELAY cycles are inserted. If BTA idle cycles already apply on these two back-to-back accesses, the effective delay is max (BUSTURNAROUND, CYCLE2CYCLEDELAY).     |
| R/W             | > 0                             | R/W                | Different   | Any                  | x                               | 1                               | CYCLE2CYCLEDELAY cycles are inserted. If BTA idle cycles already apply on these two back-to-back accesses, the effective delay is maximum (BUSTURNAROUND, CYCLE2CYCLEDELAY). |

#### 12.4.3.4.7.3.1.7 Slow Device Support (**TIMEPARAGRANULARITY** Parameter)

All access-timing parameters can be multiplied by 2 by setting the **GPMC\_CONFIG1\_i[4]** **TIMEPARAGRANULARITY** bit (where *i* stands for the GPMC chip-select *i*, where *i* = 0 to 3). Increasing all access timing parameters allows support of slow devices.

#### 12.4.3.4.7.3.2 DIR Pin

The DIR pin is used to control I/O direction on the GPMC data bus GPMC\_D[15-0]. Depending on pad multiplexing, this signal can be output and used externally to the device, if required. The DIR pin is low during transmit (OUT) and high during receive (IN).

For write accesses, the DIR pin stays OUT from start-cycle time to end-cycle time.

For read accesses, the DIR pin goes from OUT to IN at nOE assertion time and stays IN until:

- BUSTURNAROUND is enabled
  - The DIR pin goes from IN to OUT at end-cycle time plus programmable bus turnaround time.
- BUSTURNAROUND is disabled
  - After an asynchronous read access, the DIR pin goes from IN to OUT at RDACCESSTIME + 1 GPMC\_FCLK cycle or when RDCYCLETIME completes, whichever occurs last.
  - After a synchronous read access, the DIR pin goes from IN to OUT at RDACCESSTIME + 2 GPMC\_FCLK cycles or when RDCYCLETIME completes, whichever occurs last.

Because of the bus-keeping feature of the GPMC, after a read or write access and with no other accesses pending, the default value of the DIR pin is OUT (see [Section 12.4.3.4.8.10, Bus Keeping Support](#)). In non-multiplexed devices, the DIR pin stays IN between two successive read accesses to prevent unnecessary toggling.

#### 12.4.3.4.7.3.3 Reset

No reset signal is sent to the external memory device by the GPMC.

GPMC\_RST is the reset signal for the GPMC module. It is connected and controlled by LPSC8 in VD\_CORE. That reset signal initializes the internal state-machine and the internal configuration registers.

#### 12.4.3.4.7.3.4 Write Protect Signal (**nWP**)

When connected to the attached memory device, the write protect signal can enable or disable the lockdown function of the attached memory. The nWP output pin value is controlled through the GPMC\_CONFIG[4] WRITEPROTECT bit which is common for all chip selects.

#### 12.4.3.4.7.3.5 Byte Enable (**nBE1/nBE0**)

Byte enable signals (nBE1/nBE0) are:

- Valid (asserted or nonasserted according to the incoming system request) from access start to access completion for asynchronous and synchronous single accesses
- Asserted low from access start to access completion for asynchronous and synchronous multiple read accesses
- Valid (asserted or nonasserted, according to the incoming system request) synchronously to each written data for synchronous multiple write accesses.

#### 12.4.3.4.7.4 Error Handling

When an error occurs in the GPMC, the error information is stored in the GPMC\_ERR\_TYPE register and the address of the illegal access is stored in the GPMC\_ERR\_ADDRESS register. The GPMC keeps only the first error abort information until the GPMC\_ERR\_TYPE register is reset. Subsequent accesses that cause errors are not logged until the error is cleared by hardware with the GPMC\_ERR\_TYPE[0] ERRORVALID bit.

- ERRORNOTSUPPADD occurs when an incoming system request address decoding does not match any valid chip-select region, or if two chip-select regions are defined as overlapped, or if a register file access is tried outside the valid address range of 1KB.

- **ERRORNOTSUPPMCMD** occurs when an unsupported command request is decoded at the interconnect interface.
- **ERRORTIMEOUT**: A time-out mechanism prevents the system from hanging. The start value of the 9-bit time-out counter is defined in the **GPMC\_TIMEOUT\_CONTROL** register and enabled with the **GPMC\_TIMEOUT\_CONTROL[0] TIMEOUTENABLE** bit. When enabled, the counter starts at start-cycle time until it reaches 0 and data is not responded to from memory, and then a time-out error occurs. When data are sent from memory, this counter is reset to its start value. With multiple accesses (asynchronous page mode or synchronous burst mode), the counter is reset to its start value for each data access within the burst.

The GPMC does not generate interrupts on these errors. An interrupt generation is handled at interconnect level.

#### 12.4.3.4.8 GPMC Timing Setting

The GPMC offers maximum flexibility to support various access protocols. Most of the timing parameters of the protocol access used by the GPMC to communicate with attached memories or devices are programmable on a chip-select basis. Assertion and deassertion times of control signals are defined to match the attached memory or device timing specifications and to get maximum performance during accesses. For more information about **GPMC\_CLKOUT** and **GPMC\_FCLK**, see [Section 12.4.3.4.8.6, GPMC\\_CLKOUT](#).

---

#### Note

In the following sections, the start access time refers to the time at which the access begins.

---

##### 12.4.3.4.8.1 Read Cycle Time and Write Cycle Time (RDCYCLETIME / WRCYCLETIME)

The **GPMC\_CONFIG5\_i[4-0] RDCYCLETIME** and **GPMC\_CONFIG5\_i[12-8] WRCYCLETIME** bit fields (where  $i = 0$  to 3) define the address bus and byte-enable valid times for read and write accesses. To ensure a correct duty cycle of GPMC output clock between accesses, **RDCYCLETIME** and **WRCYCLETIME** are expressed in **GPMC\_FCLK** cycles and must be multiples of the GPMC output clock cycle. The **RDCYCLETIME** and **WRCYCLETIME** bit fields can be set with a granularity of 1 or 2 through the **GPMC\_CONFIG1\_i[4] TIMEPARAGRANULARITY** bit.

When **RDCYCLETIME** or **WRCYCLETIME** completes, if they are not already deasserted, all control signals (nCS, nADV/ALE, nOE/RE, nWE, and BE0/CLE) are deasserted to their reset values, regardless of their deassertion time parameters.

An exception to this forced deassertion occurs when a pipelined request to the same chip-select or to a different chip-select is pending. In such a case, it is not necessary to deassert a control signal with deassertion time parameters equal to the cycle-time parameter. This exception to forced deassertion prevents any unnecessary glitches. This requirement also applies to BE signals, thus avoiding an unnecessary BE glitch transition when pipelining requests.

---

#### Note

All control signals (CS, ADV#/ALE, BE0#/CLE, WE#, and GPMC output clock) are kept inactive (ADV#/ALE, BE0#/CLE, and GPMC output clock at low level; and CS, OE#/RE, and WE at high level) during the idle **GPMC\_FCLK** cycles.

---

If no inactive cycles are required between successive accesses to the same chip-select or a different chip-select (**GPMC\_CONFIG6\_i[7] CYCLE2CYCLESAMECSEN** = 0 or **GPMC\_CONFIG6\_i[6] CYCLE2CYCLEDIFFCSEN** = 0, where  $i = 0$  to 3), and if assertion-time parameters associated with the pipelined access are equal to 0, asserted control signals (nCS, nADV/ALE, nBE0/CLE, nWE, and nOE/RE) are kept asserted. This applies to any read/write to read/write access combination.

If inactive cycles are inserted between successive accesses (that is, **CYCLE2CYCLESAMECSEN** = 1 or **CYCLE2CYCLEDIFFCSEN** = 1), the control signals are forced to their respective default reset values for the number of **GPMC\_FCLK** cycles defined in **CYCLE2CYCLEDELAY**.

#### **12.4.3.4.8.2 nCS: Chip-Select Signal Control Assertion/Deassertion Time (CSONTIME / CSRDOFFTIME / CSWROFFTIME / CSEXTRADELAY)**

The GPMC\_CONFIG2\_i[3-0] CSONTIME bit field (where  $i = 0$  to  $3$ ) defines the nCS signal-assertion time relative to the start access time. It is common for read and write accesses.

The GPMC\_CONFIG2\_i[12-8] CSRDOFFTIME (read access) and GPMC\_CONFIG2\_i[20-16] CSWROFFTIME (write access) bit fields define the nCS signal deassertion time relative to start access time.

The CSONTIME, CSRDOFFTIME, and CSWROFFTIME parameters apply to synchronous and asynchronous modes. CSONTIME can be used to control an address and byte-enable setup time before chip-select assertion. CSRDOFFTIME and CSWROFFTIME can be used to control an address and byte-enable hold time after chip-select deassertion.

nCS signal transitions, as controlled through CSONTIME, CSRDOFFTIME, and CSWROFFTIME, can be delayed by a half-GPMC\_FCLK period by enabling the GPMC\_CONFIG2\_i[7] CSEXTRADELAY bit. This half-GPMC\_FCLK period provides more granularity on the nCS assertion and deassertion time to ensure proper setup and hold time relative to GPMC output clock. CSEXTRADELAY is especially useful in configurations where GPMC output clock and GPMC\_FCLK have the same frequency, but it can also be used for all GPMC configurations. If enabled, CSEXTRADELAY applies to all parameters that control nCS transitions.

The CSEXTRADELAY bit must be used carefully to avoid control signal overlap between successive accesses to different chip-selects. This implies the need to program the RDCYCLETIME and WRCYCLETIME bit fields to be greater than the nCS signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

#### **12.4.3.4.8.3 nADV/ALE: Address Valid/Address Latch Enable Signal Control Assertion/Deassertion Time (ADVONTIME / ADVRDOFFTIME / ADVWROFFTIME / ADVEXTRADELAY/ADVAADMUXONTIME/ADVAADMUXRDOFFTIME/ADVAADMUXWROFFTIME)**

The GPMC\_CONFIG3\_i[3-0] ADVONTIME field (where  $i = 0$  to  $3$ ) defines the nADV/ALE signal-assertion time relative to start access time. It is common to read and write accesses.

The GPMC\_CONFIG3\_i[12-8] ADVRDOFFTIME (read access) and GPMC\_CONFIG3\_i[20-16] ADVWROFFTIME (write access) bit fields define the nADV/ALE signal-deassertion time relative to start access time.

ADVONTIME can be used to control an address and byte-enable valid setup time control before nADV/ALE assertion. ADVRDOFFTIME and ADVWROFFTIME can be used to control an address and byte-enable valid hold time control after nADV/ALE deassertion. ADVRDOFFTIME and ADVWROFFTIME apply to synchronous and asynchronous modes.

The nADV/ALE signal transitions as controlled through ADVONTIME, ADVRDOFFTIME, and ADVWROFFTIME can be delayed by a half-GPMC\_FCLK period by enabling the GPMC\_CONFIG3\_i[7] ADVEXTRADELAY bit. This half-GPMC\_FCLK period provides more granularity on nADV/ALE assertion and deassertion time to ensure proper setup and hold time relative to GPMC output clock. The ADVEXTRADELAY configuration parameter is especially useful in configurations where GPMC output clock and GPMC\_FCLK have the same frequency, but can be used for all GPMC configurations. If enabled, ADVEXTRADELAY applies to all parameters controlling nADV/ALE transitions.

ADVEXTRADELAY must be used carefully to avoid control-signal overlap between successive accesses to different chip-selects. This implies the need to program the RDCYCLETIME and WRCYCLETIME bit fields to be greater than nADV/ALE signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

GPMC\_CONFIG3\_i[6-4] ADVAADMUXONTIME, GPMC\_CONFIG3\_i[26-24] ADVAADMUXRDOFFTIME, and GPMC\_CONFIG3\_i[30-28] ADVAADMUXWROFFTIME parameters have the same functions as ADVONTIME, ADVRDOFFTIME, and ADVWROFFTIME, but apply to the first address phase in the AAD-multiplexed protocol. The user must ensure that ADVAADMUXxxOFFTIME is programmed to a value less than or equal to ADVxxOFFTIME. Functionality in AAD-multiplexed mode is undefined if the settings do not comply with this requirement. ADVAADMUXxxOFFTIME can be programmed to the same value as ADVONTIME if no high nADV

pulse is needed between the two AAD-multiplexed address phases, which is the typical case in synchronous mode. In this configuration, nADV is kept low until it reaches the correct ADVxxOFFTIME.

For more information about the use of ADVONTIME, ADVRDOFFTIME, ADVWROFFTIME, and ADVAADMUXRDOFFTIME and ADVAADMUXWROFFTIME for command latch enable (CLE) and address latch enable (ALE) use for a NAND flash interface, see [Section 12.4.3.4.11, GPMC NAND Access Description](#).

**12.4.3.4.8.4 nOE/nRE: Output Enable/Read Enable Signal Control Assertion/Deassertion Time (OEONTIME / OEOFETIME / OEEXTRADELAY / OEAADMUXONTIME / OEAADMUXOFFTIME)**

The GPMC\_CONFIG4\_i[3-0] OEONTIME bit field (where  $i = 0$  to  $3$ ) defines the nOE/nRE signal assertion time relative to start access time. It applies only to read accesses.

The GPMC\_CONFIG4\_i[12-8] OEOFETIME bit field defines the nOE/nRE signal deassertion time relative to start access time. It applies only to read accesses. nOE/nRE is not asserted during a write cycle.

The OEONTIME, OEOFETIME, OEAADMUXONTIME, and OEAADMUXOFFTIME parameters apply to synchronous and asynchronous modes. OEONTIME can be used to control an address and byte enable valid setup time control before nOE/nRE assertion. OEOFETIME can be used to control an address and byte-enable valid hold time control after nOE/nRE assertion.

The OEAADMUXONTIME and OEAADMUXOFFTIME parameters have the same functions as OEONTIME and OEOFETIME, but apply to the first OE assertion in the AAD-multiplexed protocol for a read phase, or to the only OE assertion for a write phase. The user must ensure that OEAADMUXOFFTIME is programmed to a value less than OEONTIME. Functionality in AAD-multiplexed mode is undefined if the settings do not comply with this requirement. OEAADMUXOFFTIME must never be equal to OEONTIME because the AAD-multiplexed protocol requires a second address phase with the nOE signal deasserted before nOE can be asserted again to define a read command.

The nOE/RE signal transitions as controlled through OEONTIME, OEOFETIME, OEAADMUXONTIME, and OEAADMUXOFFTIME can be delayed by a half-GPMC\_FCLK period by enabling the GPMC\_CONFIG4\_i[7] OEEXTRADELAY bit. This half-GPMC\_FCLK period provides more granularity on the nOE/RE assertion and deassertion time to ensure proper setup and hold time relative to GPMC output clock. If enabled, OEEXTRADELAY applies to all parameters controlling nOE/nRE transitions.

OEEXTRADELAY must be used carefully, to avoid control-signal overlap between successive accesses to different chip-selects. This implies the need to program RDCYCLETIME and WRCYCLETIME to be greater than the nOE/RE signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

---

**Note**

When the GPMC generates a read access to an address-/data-multiplexed device, it drives the address bus until nOE assertion time.

---

**12.4.3.4.8.5 nWE: Write Enable Signal Control Assertion/Deassertion Time (WEONTIME / WEOFETIME / WEEXTRADELAY)**

The GPMC\_CONFIG4\_i[19-16] WEONTIME bit field (where  $i = 0$  to  $3$ ) defines the nWE signal-assertion time relative to start access time. The GPMC\_CONFIG4\_i[28-24] WEOFETIME bit field defines the nWE signal-deassertion time relative to start access time. These bit fields apply only to write accesses. nWE is not asserted during a read cycle.

WEONTIME can be used to control an address and byte-enable valid setup time control before nWE assertion. WEOFETIME can be used to control an address and byte-enable valid hold time control after nWE assertion.

nWE signal transitions as controlled through WEONTIME, and WEOFETIME can be delayed by a half-GPMC\_FCLK period by enabling the GPMC\_CONFIG4\_i[23] WEEXTRADELAY bit. This half-GPMC\_FCLK period provides more granularity on nWE assertion and deassertion time to ensure proper setup and hold time relative to GPMC output clock. If enabled, WEEXTRADELAY applies to all parameters controlling nWE transitions.

The WEEXTRADELAY bit must be used carefully to avoid control-signal overlap between successive accesses to different chip-selects. This implies the need to program the WRCYCLETIME bit field to be greater than the nWE signal-deassertion time, including the extra half-GPMC\_FCLK-period delay.

#### 12.4.3.4.8.6 GPMC\_CLKOUT

The GPMC output clock generated for external synchronous memory or device is GPMC\_CLKOUT.

- The GPMC\_CLKOUT clock frequency is the GPMC\_FCLK functional clock frequency divided by 1, 2, 3, or 4, depending on the GPMC\_CONFIG1\_i[1-0] GPMCFCLKDIVIDER bit field (where  $i = 0$  to 3), with a guaranteed 50-percent duty cycle. For information about the duty cycle error, see the device-specific Datasheet.
- The GPMC\_CLKOUT clock is activated only when the access in progress is defined as synchronous (read or write access).
- The GPMC\_CONFIG1\_i[26-25] CLKACTIVATIONTIME bit field (where  $i = 0$  to 3) defines the number of GPMC\_FCLK cycles from start access time to GPMC\_CLKOUT activation.
- The GPMC\_CLKOUT clock is stopped when cycle time completes and is asserted low between accesses.
- The GPMC\_CLKOUT clock is kept low when access is defined as asynchronous.

#### CAUTION

When the cycle time completes, the GPMC\_CLKOUT may be high because of the GPMC\_CONFIG1\_i[1-0] GPMCFCLKDIVIDER bit field. To ensure correct stoppage of the GPMC\_CLKOUT clock within the required 50-percent duty cycle, the user must extend the RDCYCLETIME or WRCYCLETIME value.

#### Note

To ensure a correct external clock cycle, the following rules must be applied:

- (RDCYCLETIME CLKACTIVATIONTIME) must be a multiple of (GPMCFCLKDIVIDER + 1).
- The PAGEBURSTACCESSTIME value must be a multiple of (GPMCFCLKDIVIDER + 1).

#### 12.4.3.4.8.7 GPMC Output Clock and Control Signals Setup and Hold

Control-signal transition (assertion and deassertion) setup and hold values with respect to the GPMC output clock edge can be controlled in the following ways:

- For the GPMC output clock signal, the GPMC\_CONFIG1\_i[26-25] CLKACTIVATIONTIME bit field (where  $i = 0$  to 3) allows setup and hold control of control-signal assertion time.
- The use of a divided GPMC output clock allows setup and hold control of the control-signal assertion and deassertion times.
- When the GPMC output clock runs at the GPMC\_FCLK frequency so that GPMC output clock edge and control-signal transitions refer to the same GPMC\_FCLK edge, the control-signal transitions can be delayed by a half-GPMC\_FCLK period to provide minimum setup and hold times. This half-GPMC\_FCLK delay is enabled with the CSEXTRADELAY, ADVEXTRADELAY, OEEXTRADELAY, or WEEXTRADELAY parameter. This delay must be used carefully to prevent control-signal overlap between successive accesses to different chip-selects. This implies that the RDCYCLETIME and WRCYCLETIME are greater than the last control-signal deassertion time, including the extra half-GPMC\_FCLK cycle.

#### 12.4.3.4.8.8 Access Time (RDACCESSTIME / WRACCESSTIME)

The read/write access time durations can be programmed independently through the GPMC\_CONFIG5\_i[20-16] RDACCESSTIME and GPMC\_CONFIG6\_i[28-24] WRACCESSTIME bit fields (where  $i = 0$  to 3). This allows nOE and GPMC data-capture timing parameters to be independent of nWE and memory device data capture timing parameters. The RDACCESSTIME and WRACCESSTIME bit fields can be set with a granularity of 1 or 2 through the GPMC\_CONFIG1\_i[4] TIMEPARAGRANULARITY bit.

#### 12.4.3.4.8.8.1 Access Time on Read Access

In asynchronous read mode, for single and paged accesses, the GPMC\_CONFIG5\_i[20-16] RDACCESSTIME bit field (where  $i = 0$  to  $3$ ) defines the number of GPMC\_FCLK cycles from start access time to the GPMC\_FCLK rising edge used for the first data capture. RDACCESSTIME must be programmed to the rounded greater value (in GPMC\_FCLK cycles) of the read access time of the attached memory device.

In synchronous read mode, for single or burst accesses, RDACCESSTIME defines the number of GPMC\_FCLK cycles from the start access time to the GPMC\_FCLK rising edge corresponding to the GPMC output clock rising edge used for the first data capture.

GPMC output clock, which is sent to the memory device for synchronization with the GPMC controller, is internally retimed to correctly latch the returned data. The GPMC\_CONFIG5\_i[4-0] RDCYCLETIME bit field must be greater than RDACCESSTIME to let the GPMC latch the last return data using the internally retimed GPMC output clock.

The external WAIT signal can be used in conjunction with RDACCESSTIME to control the effective GPMC data-capture GPMC\_FCLK edge on read access in asynchronous and synchronous modes. For more information about wait monitoring, see [Section 12.4.3.4.7.3.1, WAIT Pin Monitoring Control](#).

#### 12.4.3.4.8.8.2 Access Time on Write Access

In asynchronous write mode, the GPMC\_CONFIG6\_i[28-24] WRACCESSTIME timing parameter is not used to define the effective write access time. Instead, it is used as a wait invalid timing window and must be set to a correct value so that the GPMC\_WAIT pin is at a valid state two GPMC output clock cycles before WRACCESSTIME completes. For more information about wait monitoring, see [Section 12.4.3.4.7.3.1, WAIT Pin Monitoring Control](#).

In synchronous write mode, for single or burst accesses, WRACCESSTIME defines the number of GPMC\_FCLK cycles from the start access time to the GPMC output clock rising edge used by the memory device for the first data capture.

The external WAIT signal can be used in conjunction with WRACCESSTIME to control the effective memory device data-capture GPMC output clock edge for a synchronous write access. For more information about wait monitoring, see [Section 12.4.3.4.7.3.1, WAIT Pin Monitoring Control](#).

#### 12.4.3.4.8.9 Page Burst Access Time (PAGEBURSTACCESSTIME)

The GPMC\_CONFIG5\_i[27-24] PAGEBURSTACCESSTIME bit field (where  $i = 0$  to  $3$ ) can be set with a granularity of 1 or 2 through the GPMC\_CONFIG1\_i[4] TIMEPARAGRANULARITY bit.

#### 12.4.3.4.8.9.1 Page Burst Access Time on Read Access

In asynchronous page read mode, the delay between successive word captures in a page is controlled through the PAGEBURSTACCESSTIME bit field. The PAGEBURSTACCESSTIME parameter must be programmed to the rounded greater value (in GPMC\_FCLK cycles) of the read access time of the attached device.

In synchronous burst read mode, the delay between successive word captures in a burst is controlled through the PAGEBURSTACCESSTIME bit field.

The external WAIT signal can be used in conjunction with PAGEBURSTACCESSTIME to control the effective GPMC data-capture GPMC\_FCLK edge on read access. For more information about wait monitoring, see [Section 12.4.3.4.7.3.1, WAIT Pin Monitoring Control](#).

#### 12.4.3.4.8.9.2 Page Burst Access Time on Write Access

Asynchronous page write mode is not supported. PAGEBURSTACCESSTIME is irrelevant in this case.

In synchronous burst write mode, PAGEBURSTACCESSTIME controls the delay between successive memory device word captures in a burst.

The external WAIT signal can be used in conjunction with PAGEBURSTACCESSTIME to control the effective memory device data capture GPMC output clock edge in synchronous write mode. For more information about wait monitoring, see [Section 12.4.3.4.7.3.1, WAIT Pin Monitoring Control](#).

#### **12.4.3.4.8.10 Bus Keeping Support**

At the end cycle time of a read access, if no other access is pending, the GPMC drives the bus with the last data read after RDCYCLETIME completes to prevent bus floating and reduce power consumption.

After a write access, if no other access is pending, the GPMC keeps driving the data bus after WRCYCLETIME completes with the same data to prevent bus floating and power consumption.

#### **12.4.3.4.9 GPMC NOR Access Description**

For each chip-select configuration, the read access can be specified as asynchronous or synchronous access through the GPMC\_CONFIG1\_i[29] READTYPE bit (where  $i = 0$  to  $3$ ). For each chip-select configuration, the write access can be specified as synchronous or asynchronous access through the GPMC\_CONFIG1\_i[27] WRITETYPE bit where ( $i = 0$  to  $3$ ).

Asynchronous and synchronous read and write access time and related control signals are controlled through timing parameters that refer to GPMC\_FCLK. The primary difference of synchronous mode is the availability of a configurable clock interface to control the external device. Synchronous mode also affects data-capture and wait-pin monitoring schemes in read access.

For more information about asynchronous and synchronous access, see the descriptions of GPMC output clock (CLK), RdAccessTime, WrAccessTime, and WAIT pin monitoring.

For more information about timing-parameter settings, see the sample timing diagrams in this chapter.

---

#### **Note**

The address bus and nBE[1-0] are fixed for the duration of a synchronous burst read access, but they are updated for each beat of an asynchronous page-read access.

---

#### **12.4.3.4.9.1 Asynchronous Access Description**

This section describes:

- Asynchronous single-read operation on an address/data multiplexed device
- Asynchronous single write operation on an address/data-multiplexed device
- Asynchronous single read operation on an AAD-multiplexed device
- Asynchronous single write operation on an AAD-multiplexed device
- Asynchronous multiple (page) read operation on a non-multiplexed device

In asynchronous operations GPMC output clock is not provided outside the GPMC and is kept low.

##### **12.4.3.4.9.1.1 Access on Address/Data Multiplexed Devices**

###### **12.4.3.4.9.1.1.1 Asynchronous Single-Read Operation on an Address/Data Multiplexed Device**

Figure 12-177 shows an asynchronous single read operation on an address/data-multiplexed device.



**Figure 12-177. Asynchronous Single Read on an Address/Data-Multiplexed Device**

For formulas to calculate timing parameters, see [Section 12.4.3.5.6.1, GPMC Timing Parameters Formulas](#).

[Table 12-232](#) lists the timing bit fields to set up to configure the GPMC in asynchronous single-read mode.

When the GPMC generates a read access to an address/data-multiplexed device, it drives the address bus until nOE assertion time. For more information, see [Section 12.4.3.4.7.2.3, Address/Data-Multiplexing Interface](#).

Address bits (A[16-1] from a GPMC perspective, A[15-0] from an external device perspective) are placed on the address/data bus, and the remaining address bits GPMC\_A[22-16] are placed on the address bus. The address phase ends at nOE assertion, when the DIR signal goes from OUT to IN.

- Chip-select signal nCS:
  - nCS assertion time is controlled by the *GPMC\_CONFIG2\_i[3-0]* CSONTIME bit field. It controls the address setup time to nCS assertion.
  - nCS deassertion time is controlled by the *GPMC\_CONFIG2\_i[12-8]* CSROFFTIME bit field. It controls the address hold time from nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the *GPMC\_CONFIG3\_i[3-0]* ADVONTIME bit field.
  - nADV deassertion time is controlled by the *GPMC\_CONFIG3\_i[12-8]* ADVROFFTIME bit field.
- Output enable signal nOE:
  - nOE assertion indicates a read cycle.
  - nOE assertion time is controlled by the *GPMC\_CONFIG4\_i[3-0]* OEONTIME bit field.
  - nOE deassertion time is controlled by the *GPMC\_CONFIG4\_i[12-8]* OEOFETIME bit field.
- Read data is latched when RDACCESSTIME completes. Access time is defined in the *GPMC\_CONFIG5\_i[20-16]* RDACCESSTIME bit field.
- Direction signal DIR: DIR goes from OUT to IN at the same time that nOE is asserted.
- The end of the access is defined by the *GPMC\_CONFIG5\_i[4-0]* RDCYCLETIME parameter.

In the GPMC, when a 16-bit wide device is attached to the controller, a 32-bit word write access is split into two 16-bit word write accesses. For more information about GPMC access size and type adaptation, see [Section 12.4.3.4.9.5, System Burst Versus External Device Burst Support](#).

Between two successive accesses, if an nCS pulse is needed:

- The *GPMC\_CONFIG6\_i[11-8]* CYCLE2CYCLEDELAY bit field can be programmed with the *GPMC\_CONFIG6\_i[7]* CYCLE2CYCLESAMECSEN bit enabled.
- The CSWROFFTIME and CSONTIME parameters also allow a chip-select pulse, but this affects all other types of access.



gpmc-044

**Figure 12-178. Two Asynchronous Single-Read Accesses on an Address/Data-Multiplexed Device (32-Bit Read Split Into 2 x 16-Bit Read)**

#### 12.4.3.4.9.1.1.2 Asynchronous Single-Write Operation on an Address/Data-Multiplexed Device

Figure 12-179 shows an asynchronous single-write operation on an address/data-multiplexed device.



gpmc-013

**Figure 12-179. Asynchronous Single-Write on an Address/Data-Multiplexed Device**

For formulas to calculate timing parameters, see [Section 12.4.3.5.6.1, GPMC Timing Parameters Formulas](#).

[Table 12-232](#) lists the timing bit fields to set up to configure the GPMC in asynchronous single-write mode.

When the GPMC generates a write access to an address/data-multiplexed device, it drives the address bus until nWE assertion time. For more information, see [Section 12.4.3.4.7.2.3, Address/Data-Multiplexing Interface](#).

The nCS and nADV signals are controlled in the same way as for a asynchronous single-read operation on an address/data-multiplexed device.

- Write enable signal nWE:
  - nWE assertion indicates a write cycle.
  - nWE assertion time is controlled by the GPMC\_CONFIG4\_i[19-16] WEONTIME bit field.
  - nWE deassertion time is controlled by the GPMC\_CONFIG4\_i[28-24] WEOFETIME bit field.
- Direction signal DIR: DIR signal is OUT during the entire access.
- The end of the access is defined by the GPMC\_CONFIG5\_i[12-8] WRCYCLETIME parameter.

Address bits A[16-1] (GPMC point of view) are placed on the address/data bus at the start of cycle time, and the remaining address bits A[22-17] are placed on the address bus.

Data is driven on the address/data bus at a GPMC\_CONFIG6\_i[19-16] WRDATAONADMUXBUS time.

#### Note

Multiple write access in asynchronous mode is not supported. If WRITEMULTIPLE is enabled with WRITETYPE as asynchronous, the GPMC processes single asynchronous accesses.

After a write operation, if no other access (read or write) is pending, the data bus keeps its previous value. See [Section 12.4.3.4.8.10, Bus Keeping Support](#).

#### 12.4.3.4.9.1.1.3 Asynchronous Multiple (Page) Write Operation on an Address/Data-Multiplexed Device

Write multiple (page) access in asynchronous mode is not supported for address/data-multiplexed devices.

If the *GPMC\_CONFIG1\_i[28]* WRITEMULTIPLE bit is enabled (0x1) with the *GPMC\_CONFIG1\_i[27]* WRITETYPE bit as asynchronous (0x0), the GPMC processes single asynchronous accesses.

For accesses on non-multiplexed devices, see [Section 12.4.3.4.9.3, Asynchronous and Synchronous Accesses in non-multiplexed Mode](#).

#### 12.4.3.4.9.1.2 Access on Address/Address/Data-Multiplexed Devices

##### 12.4.3.4.9.1.2.1 Asynchronous Single Read Operation on an AAD-Multiplexed Device

Figure 12-180 shows an asynchronous single-read operation on an AAD-multiplexed device.



**Figure 12-180. Asynchronous Single Read on an AAD-Multiplexed Device**

For formulas to calculate timing parameters, see [Section 12.4.3.5.6.1, GPMC Timing Parameters Formulas](#).

[Table 12-232](#) lists the timing bit fields to set up to configure the GPMC in asynchronous single write mode.

When the GPMC generates a read access to an AAD-multiplexed device, all address bits are driven onto the address/data bus in two separate phases. The first phase is used for the MSB address and is qualified with nOE

driven low. The first address phase ends at the first nOE deassertion time. The second phase for LSB address is qualified with nOE driven high. The second address phase ends at the second nOE assertion time, when the DIR signal goes from OUT to IN.

The nCS and DIR signals are controlled in the same way as for an asynchronous single-read operation on an address/data-multiplexed device.

- Address valid signal nADV. nADV is asserted and deasserted twice during a read transaction:
  - nADV first assertion time is controlled by the *GPMC\_CONFIG3\_i[6-4]* ADVAADMUXONTIME bit field.
  - nADV first deassertion time is controlled by the *GPMC\_CONFIG3\_i[26-24]* ADVAADMUXRDOFFTIME bit field.
  - nADV second assertion time is controlled by the *GPMC\_CONFIG3\_i[3-0]* ADVONTIME bit field.
  - nADV second deassertion time is controlled by the *GPMC\_CONFIG3\_i[12-8]* ADVRDOFFTIME bit field.
- Output Enable signal nOE. nOE is asserted and deasserted twice during a read transaction (nOE second assertion indicates a read cycle):
  - nOE first assertion time is controlled by the *GPMC\_CONFIG4\_i[6-4]* OEAADMUXONTIME bit field.
  - nOE first deassertion time is controlled by the *GPMC\_CONFIG3\_i[15-13]* OEAADMUXOFFTIME bit field.
  - nOE second assertion time is controlled by the *GPMC\_CONFIG4\_i[3-0]* OEONTIME bit field.
  - nOE second deassertion time is controlled by the *GPMC\_CONFIG4\_i[12-8]* OEOFETIME bit field.

#### **12.4.3.4.9.1.2.2 Asynchronous Single-Write Operation on an AAD-Multiplexed Device**

Figure 12-181 shows an asynchronous single-write operation on an AAD-multiplexed device.



gpmc-042

**Figure 12-181. Asynchronous Single Write on an AAD-Multiplexed Device**

For formulas to calculate timing parameters, see [Section 12.4.3.5.6.1, GPMC Timing Parameters Formulas](#).

[Table 12-232](#) lists the timing bit fields to set up to configure the GPMC in asynchronous single-write mode.

When the GPMC generates a write access to an AAD-multiplexed device, all address bits are driven onto the address/data bus in two separate phases. The first phase is used for the MSB address and is qualified with nOE driven low. The second phase for LSB address is qualified with nOE driven high. The address phase ends at nWE assertion time.

The nCS, nWE, and DIR signals are controlled in the same way as for an asynchronous single-write operation on an address/data-multiplexed device. See [Table 12-223, NAND Memory Type](#).

- Address valid signal nADV is asserted and deasserted twice during a write transaction:
  - nADV first assertion time is controlled by the *GPMC\_CONFIG3\_i[6-4]* ADVAADMUXONTIME bit field.
  - nADV first deassertion time is controlled by the *GPMC\_CONFIG3\_i[30-28]* ADVAADMUXWROFFTIME bit field.
  - nADV second assertion time is controlled by the *GPMC\_CONFIG3\_i[3-0]* ADVONTIME bit field.
  - nADV second deassertion time is controlled by the *GPMC\_CONFIG3\_i[20-16]* ADVWROFFTIME bit field.
- Output enable signal nOE is asserted during the address phase of a write transaction:

- nOE assertion time is controlled by the *GPMC\_CONFIG4\_i[6-4]* OEAADMUXONTIME bit field.
- nOE deassertion time is controlled by the *GPMC\_CONFIG3\_i[15-13]* OEAADMUXOFFTIME bit field.

The address bits for the first address phase are driven onto the data bus until nOE deassertion. Data is driven onto the address/data bus at the clock edge defined by the *GPMC\_CONFIG6\_i[19-16]* WRDATAONADMUXBUS parameter.

#### 12.4.3.4.9.1.2.3 Asynchronous Multiple (Page) Read Operation on an AAD-Multiplexed Device

Write multiple (page) access in asynchronous mode is not supported for AAD-multiplexed devices.

If the *GPMC\_CONFIG1\_i[28]* WRITEMULTIPLE bit is enabled (0x1) with the *GPMC\_CONFIG1\_i[27]* WRITETYPE bit as asynchronous (0x0), the GPMC processes single asynchronous accesses.

For accesses on non-multiplexed devices, see [Section 12.4.3.4.9.3, Asynchronous and Synchronous Accessed in non-multiplexed Mode](#).

#### 12.4.3.4.9.2 Synchronous Access Description

This section describes read and write synchronous accesses on address/data-multiplexed devices. All information in this section can be applied to any type of memory (non-multiplexed, address and data-multiplexed, or AAD-multiplexed) with the difference limited to the address phase. For accesses on non-multiplexed devices, see [Section 12.4.3.4.9.3, Asynchronous and Synchronous Accessed in non-multiplexed Mode](#).

In synchronous operations:

- The GPMC\_CLKOUT clock is provided outside the GPMC when accessing the memory device.
- The GPMC\_CLKOUT clock is derived from the GPMC\_FCLK clock using the *GPMC\_CONFIG1\_i[1-0]* GPMCFCLKDIVIDER bit field. In the following section i stands for the chip-select number, i = 0 to 3.
- The *GPMC\_CONFIG1\_i[26-25]* CLKACTIVATIONTIME bit field specifies that the GPMC\_CLKOUT is provided outside the GPMC for 0 to 2 GPMC\_FCLK cycles after start access time until RDCYCLETIME or WRCYCLETIME completes.

#### 12.4.3.4.9.2.1 Synchronous Single Read

[Figure 12-182](#) and [Figure 12-183](#) show a synchronous single-read operation with GPMCFCLKDIVIDER equal to 0 and 1, respectively.



gpmc-015

**Figure 12-182. Synchronous Single Read (GPMCFCLKDIVIDER = 0)**



gpmc-016

**Figure 12-183. Synchronous Single Read (GPMCFCLKDIVIDER = 1)**

For formulas to calculate timing parameters, see [Section 12.4.3.5.6.1, GPMC Timing Parameters Formulas](#).

[Table 12-232](#) lists the timing bit fields to set up to configure the GPMC in asynchronous single-read mode.

When the GPMC generates a read access to an address/data-multiplexed device, it drives the address bus until nOE assertion time. For more information, see [Section 12.4.3.4.7.2.3, Address/Data-Multiplexing Interface](#).

- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC\_CONFIG2\_i[3-0] CSONTIME bit field and ensures address setup time to nCS assertion.
  - nCS deassertion time is controlled by the GPMC\_CONFIG2\_i[12-8] CSROFFTIME bit field and ensures address hold time to nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC\_CONFIG3\_i[3-0] ADVONTIME bit field.
  - nADV deassertion time is controlled by the GPMC\_CONFIG3\_i[12-8] ADVROFFTIME bit field.
- Output enable signal nOE:
  - nOE assertion indicates a read cycle.
  - nOE assertion time is controlled by the GPMC\_CONFIG4\_i[3-0] OEONTIME bit field.
  - nOE deassertion time is controlled by the GPMC\_CONFIG4\_i[12-8] OEOFETIME bit field.
- Initial latency for the first read data is controlled by GPMC\_CONFIG5\_i[20-16] RDACCESSTIME bit field or by monitoring the WAIT signal.
- Total access time (the GPMC\_CONFIG5\_i[4-0] RDCYCLETIME bit field) corresponds to RDACCESSTIME plus the address hold time from nCS deassertion, plus time from RDACCESSTIME to CSROFFTIME.
- Direction signal DIR: DIR goes from OUT to IN at the same time as nOE assertion.

When the GPMC generates a write access to an AAD-multiplexed device, all address bits are driven onto the address/data bus in two separate phases. The first phase is used for the MSB address and is qualified with nOE driven low. The second phase for LSB address is qualified with nOE driven high. The address phase ends at nWE assertion time.

The nCS and DIR signals are controlled in the same way as for a synchronous single-read operation on an address/data-multiplexed device.

- Address valid signal nADV is asserted and deasserted twice during a read transaction:
  - nADV first assertion time is controlled by the GPMC\_CONFIG3\_i[6-4] ADVAADMUXONTIME bit field.
  - nADV first deassertion time is controlled by the GPMC\_CONFIG3\_i[26-24] ADVAADMUXRDOFFTIME bit field.
  - nADV second assertion time is controlled by the GPMC\_CONFIG3\_i[3-0] ADVONTIME bit field.
  - nADV second deassertion time is controlled by the GPMC\_CONFIG3\_i[12-8] ADVRDOFFTIME bit field.
- Output Enable signal nOE is asserted and deasserted twice during a read transaction (nOE second assertion indicates a read cycle):
  - nOE first assertion time is controlled by the GPMC\_CONFIG4\_i[6-4] OEAADMUXONTIME bit field.
  - nOE first deassertion time is controlled by the GPMC\_CONFIG3\_i[15-13] OEAADMUXOFFTIME bit field.
  - nOE second assertion time is controlled by the GPMC\_CONFIG4\_i[3-0] OEONTIME bit field.
  - nOE second deassertion time is controlled by the GPMC\_CONFIG4\_i[12-8] OEOFETIME bit field.

After a read operation, if no other access (read or write) is pending, the data bus is driven with the previous read value. See [Section 12.4.3.4.8.10, Bus Keeping Support](#).

#### **12.4.3.4.9.2.2 Synchronous Multiple (Burst) Read (4-, 8-, 16-Word16 Burst With Wraparound Capability)**

[Figure 12-184](#) and [Figure 12-185](#) show a synchronous multiple-read operation with GPMCFCLKDivider equal to 0 and 1, respectively.



gpmc-018

**Figure 12-184. Synchronous Multiple (Burst) Read (GPMC\_FCLKDIVIDER = 0)**



**Figure 12-185. Synchronous Multiple (Burst) Read (GPMCFCLKDIVIDER = 1)**

When the GPMC\_CONFIG5\_i[20-16] RDACCESSTIME bit field completes, control-signal timings are frozen during the multiple data transactions, corresponding to the GPMC\_CONFIG5\_i[27-24] PAGEBURSTACCESSTIME bit field multiplied by the number of remaining data transactions.

The nCS, nADV, nOE, and DIR signals are controlled in the same way as for a synchronous single-read operation. See [Table 12-218, NOR Memory Type](#).

Initial latency for the first read data is controlled by RDACCESSTIME or by monitoring the WAIT signal. Successive read data are provided by the memory device every one or two GPMC\_CLKOUT cycles. The PAGEBURSTACCESSTIME parameter must be set accordingly with the GPMC\_CONFIG1\_i[1-0] GPMCFCLKDIVIDER bit field and the memory-device internal configuration. Depending on the device page length, the GPMC checks the device page crossing during a new burst request and purposely inserts initial latency (of RDACCESSTIME) when required.

Total access time GPMC\_CONFIG5\_i[4-0] RDCYCLETIME corresponds to RDACCESSTIME plus the address hold time from nCS deassertion. In [Figure 12-185](#), the programmed value of RDCYCLETIME equals RDCYCLETIME0 + RDCYCLETIME1.

After a read operation, if no other access (read or write) is pending, the data bus is driven with the previous read value. See [Section 12.4.3.4.8.10, Bus Keeping Support](#).

Burst wraparound is enabled through the GPMC\_CONFIG1\_i[31] WRAPBURST bit and allows a 4-, 8-, or 16-Word16 linear burst access to wrap within its burst-length boundary through the GPMC\_CONFIG1\_i[24-23] ATTACHEDDEVICEPAGELENGTH bit field.

#### 12.4.3.4.9.2.3 Synchronous Single Write

Burst write mode is used for synchronous single or burst accesses.



gpmc-017

**Figure 12-186. Synchronous Single Write on an Address/Data-Multiplexed Device**

When the GPMC generates a write access to an address/data-multiplexed device, it drives the data bus (with address bits A[16-1]) until the GPMC\_CONFIG6\_i[19-16] WRDATAONADMUXBUS bit field time. The first data of the burst is driven on the address/data bus at WRDATAONADMUXBUS time.

#### 12.4.3.4.9.2.4 Synchronous Multiple (Burst) Write

Synchronous burst write mode provides synchronous single or consecutive accesses.

Figure 12-187 shows a synchronous burst write access when the chip-select is configured in address/data-multiplexed mode.



**Figure 12-187. Synchronous Multiple Write (Burst Write) in Address/Data-Multiplexed Mode**

Figure 12-188 shows the same synchronous burst write access when the chip-select is configured in address/address/data-multiplexed (AAD-multiplexed) mode.



**Figure 12-188. Synchronous Multiple Write (Burst Write) in Address/Address/Data-Multiplexed Mode**

The first data of the burst is driven on the A/D bus at the GPMC\_CONFIG6\_i[19-16] WRDATAONADMUXBUS bit field.

When WRACCESSTIME completes, control-signal timings are frozen during the multiple data transactions, corresponding to the GPMC\_CONFIG5\_i[27-24] PAGEBURSTACCESSTIME bit field multiplied by the number of remaining data transactions.

When the GPMC generates a read access to an address/data-multiplexed device, it drives the address bus until nOE assertion time. For more information, see [Section 12.4.3.4.7.2.3, Address/Data-Multiplexing Interface](#).

- Chip-select signal nCS:
  - nCS assertion time is controlled by the GPMC\_CONFIG2\_i[3-0] CSONTIME bit field (where  $i = 0$  to 3) and ensures address setup time to nCS assertion.
  - nCS deassertion time controlled by the GPMC\_CONFIG2\_i[20-16] CSWROFFTIME bit field and ensures address hold time to nCS deassertion.
- Address valid signal nADV:
  - nADV assertion time is controlled by the GPMC\_CONFIG3\_i[3-0] ADVONTIME bit field.
  - nADV deassertion time is controlled by the GPMC\_CONFIG3\_i[20-16] ADVWROFFTIME bit field.

- Write enable signal nWE:
  - nWE assertion indicates a read cycle.
  - nWE assertion time is controlled by the GPMC\_CONFIG4\_i[19-16] WEONTIME bit field.
  - nWE deassertion time is controlled by the GPMC\_CONFIG4\_i[28-24] WEOFETIME bit field.

---

#### Note

The nWE falling edge must not be used to control the time when the burst first data is driven in the address/data bus, because some new devices require the nWE signal to be low during the address phase.

- Direction signal DIR is OUT during the entire access.

When the GPMC generates a write access to an AAD-multiplexed device, all address bits are driven onto the address/data bus in two separate phases. The first phase is used for the MSB address and is qualified with nOE driven low. The second phase for LSB address is qualified with nOE driven high. The address phase ends at nWE assertion time.

The nCS, and DIR signals are controlled as previously described.

- Address valid signal nADV is asserted and deasserted twice during a read transaction:
  - nADV first assertion time is controlled by the GPMC\_CONFIG3\_i[6-4] ADVAADMUXONTIME bit field.
  - nADV first deassertion time is controlled by the GPMC\_CONFIG3\_i[26-24] ADVAADMUXRDOFFTIME bit field.
  - nADV second assertion time is controlled by the GPMC\_CONFIG3\_i[3-0] ADVONTIME bit field.
  - nADV second deassertion time is controlled by the GPMC\_CONFIG3\_i[12-8] ADVRDOFFTIME bit field.
- Output Enable signal nOE is asserted and deasserted twice during a read transaction (nOE second assertion indicates a read cycle):
  - nOE first assertion time is controlled by the GPMC\_CONFIG4\_i[6-4] OEAADMUXONTIME bit field.
  - nOE first deassertion time is controlled by the GPMC\_CONFIG4\_i[15-13] OEAADMUXOFFTIME bit field.
  - nOE second assertion time is controlled by the GPMC\_CONFIG4\_i[3-0] OEONTIME bit field.
  - nOE second deassertion time is controlled by the GPMC\_CONFIG4\_i[12-8] OEOFETIME bit field.

First write data is driven by the GPMC at GPMC\_CONFIG6\_i[19-16] WRDATAONADMUXBUS, when in address/data-multiplexed configuration. The next write data of the burst is driven on the bus at WRACCESSTIME + 1 during GPMC\_CONFIG5\_i[27-24] PAGEBURSTACCESSTIME GPMC\_FCLK cycles. The last data of the synchronous burst write is driven until GPMC\_CONFIG5\_i[12-8] WRCYCLETIME completes.

- WRACCESSTIME is defined in the GPMC\_CONFIG6\_i[28-24] bit field.
- The PAGEBURSTACCESSTIME parameter must be set accordingly with GPMCFCLKDIVIDER and the memory-device internal configuration.

Total access time GPMC\_CONFIG5\_i[12-8] WRCYCLETIME corresponds to WRACCESSTIME plus the address hold time from nCS deassertion. In [Figure 12-187](#), the programmed value of WRCYCLETIME equals WRCYCLETIME0 + WRCYCLETIME1. WRCYCLETIME0 and WRCYCLETIME1 delays are not actual parameters and are only a graphical representation of the full WRCYCLETIME value.

After a write operation, if no other access (read or write) is pending, the data bus keeps the previous value. See [Section 12.4.3.4.8.10, Bus Keeping Support](#).

#### 12.4.3.4.9.3 Asynchronous and Synchronous Accesses in non-multiplexed Mode

Page mode is available only in non-multiplexed mode.

- Asynchronous single-read operation on a non-multiplexed device
- Asynchronous single-write operation on a non-multiplexed device
- Asynchronous multiple- (page mode) read operation on a non-multiplexed device
- Synchronous operations on a non-multiplexed device

#### 12.4.3.4.9.3.1 Asynchronous Single-Read Operation on non-multiplexed Device

[Figure 12-189](#) shows an asynchronous single-read operation on a non-multiplexed device.



**Figure 12-189. Asynchronous Single Read on an Address/Data-non-multiplexed Device**

The 22-bit address (For a 16-bit data memory device, hence GPMC A[0] is not necessary to be output) is driven onto the address bus A[22-1] and the 16-bit data is driven onto the data bus D[15-0].

Read data is latched at GPMC\_CONFIG1\_5[20-16] RDACCESTIME completion time. The end of the access is defined by the GPMC\_CONFIG1\_5[4-0] RDCYCLETIME parameter.

The nCS, nADV, nOE, and DIR signals are controlled in the same way as address/data-multiplexed accesses (see [Table 12-223, NAND Memory Type](#)).

#### 12.4.3.4.9.3.2 Asynchronous Single-Write Operation on non-multiplexed Device

[Figure 12-190](#) shows an asynchronous single-write operation on a non-multiplexed device.



**Figure 12-190. Asynchronous Single Write on an Address/Data-non-multiplexed Device**

The nCS, nADV, nWE, and DIR signals are controlled in the same way as address/data-multiplexed accesses (see [Table 12-223](#)).

#### **12.4.3.4.9.3.3 Asynchronous Multiple (Page Mode) Read Operation on non-multiplexed Device**

[Figure 12-191](#) shows an asynchronous multiple-read operation on a non-multiplexed device in which two word32 host read accesses to the GPMC are split into one multiple- (page mode of 4 word16) read access to the attached device.



gpmc-014

**Figure 12-191. Asynchronous Multiple (Page Mode) Read**

#### Note

The WAIT signal is active low.

The nCS, nADV, nOE, and DIR signals are controlled in the same way as address/data-multiplexed accesses (see [Table 12-223](#)).

When RDACCESSTIME completes, control signal timings are frozen during the multiple data transactions, corresponding to PAGEBURSTACCESSTIME multiplied by the number of remaining data transactions.

Read data is latched at *GPMC\_CONFIG5\_i[20-16]* RDACCESSTIME completion time (where  $i = 0$  to  $3$ ). The end of the access is defined by the *GPMC\_CONFIG5\_i[4-0]* RDCYCLETIME parameter.

During consecutive accesses, the GPMC increments the address after each data read completes.

Delay between successive read data in the page is controlled by the *GPMC\_CONFIG5\_i[27-24]* PAGEBURSTACCESSTIME parameter. Depending on the device page length, the GPMC can control device page crossing during a burst request and insert initial RDACCESSTIME latency. Page crossing is possible only with a new burst access, meaning a new initial access phase is initiated.

Total access time RDCYCLETIME corresponds to RDACCESSTIME, plus the address hold time, starting from the nCS deassertion.

- The read cycle time is defined in the *GPMC\_CONFIG5\_i[4-0]* RDCYCLETIME bit field.

- In Figure 12-191, the programmed value of RDCYCLETIME equals RDCYCLETIME0 (before paged accesses) + RDCYCLETIME1 (after paged accesses).

#### 12.4.3.4.9.3.4 Synchronous Operations on a non-multiplexed Device

All information for this section is equivalent to similar operations for address/data-multiplexed or AAD-multiplexed accesses. The only difference resides in the address phase. See [Section 12.4.3.5.3, GPMC Configuration in NOR Mode](#).

#### 12.4.3.4.9.4 Page and Burst Support

Each chip-select can be configured to process system single or burst requests into successive single accesses or asynchronous page/synchronous burst accesses, with appropriate access size adaptation.

Depending on the external device page or burst capability, read and write accesses can be independently configured through the GPMC. The GPMC\_CONFIG1\_i[30] READMULTIPLE and GPMC\_CONFIG1\_i[28] WRITMULTIPLE bits (where  $i = 0$  to 3) are associated with the READTYPE and WRITETYPE parameters.

---

#### Note

- Asynchronous write page mode is not supported.
  - 8-bit-wide device support is limited to nonburstable devices (READMULTIPLE and WRITMULTIPLE are ignored).
  - Not applicable to NAND device interfacing.
- 

#### 12.4.3.4.9.5 System Burst vs External Device Burst Support

The device system can issue the following requests to the GPMC:

- Byte, 16-bit word, 32-bit word requests (byte-enable-controlled). This is always a single request from the interconnect point of view.
- Incrementing fixed-length bursts of two, four, and eight words
- Wrapped (critical word access first) fixed-length burst of two, four, or eight words

To process a system request with the optimal protocol, the READMULTIPLE (and READTYPE) and WRITMULTIPLE (and WRITETYPE) parameters must be set according to the burstable capability (synchronous or asynchronous) of the attached device.

The GPMC access engine issues only fixed-length bursts. The maximum length that can be issued is defined per chip-select by the GPMC\_CONFIG1\_i[24-23] ATTACHEDDEVICEPAGELENGTH bit field (where  $i = 0$  to 3). When the value of ATTACHEDDEVICEPAGELENGTH is less than the length of the system burst request (including the appropriate access size adaptation according to the device width), the GPMC splits the system burst request into multiple bursts. Within the specified 4-, 8-, or 16-word value, the value of the ATTACHEDDEVICEPAGELENGTH bit field must correspond to the maximum length burst supported by the memory device configured in fixed-length burst mode (as opposed to continuous burst mode).

To get optimal performance from memory devices that natively support 16 Word16-length-wrapping burst capability (critical word access first), the ATTACHEDDEVICEPAGELENGTH parameter must be set to 16 words and the GPMC\_CONFIG1\_i[31] WRAPBURST bit (where  $i = 0$  to 3) must be set to 1. Similarly DEVICEPAGELENGTH is set to 4 and 8 for memories supporting 4 and 8 Word16-length-wrapping burst, respectively.

When the memory device does not offer (or is not configured to offer) native 16 Word16-length-wrapping burst, the WRAPBURST parameter must be cleared, and the GPMC access engine emulates the wrapping burst by issuing the appropriate burst sequences according to the value of ATTACHEDDEVICEPAGELENGTH.

When the memory device does not support native-wrapping burst, there is usually no difference in behavior between a fixed-burst length mode and a continuous-burst mode configuration (except for a potential power increase from a memory-speculative data prefetch in a continuous burst read). However, even though continuous burst mode is compatible with GPMC behavior, because the GPMC access engine issues only

fixed-length burst and does not benefit from continuous burst mode, it is best to configure the memory device in fixed-length burst mode.

The memory device maximum-length burst (configured in fixed-length burst wrap or nonwrap mode) usually corresponds to the memory device data buffer size. Memory devices with a minimum of 16 half-word buffers are the most appropriate (especially with wrap support), but memory devices with smaller buffer size (4 or 8) are also supported, assuming that the *GPMC\_CONFIG1\_i[24-23] ATTACHEDDEVICEPAGELENGTH* bit field is set accordingly to 4 or 8 words.

The device system issues only requests with addresses or starting addresses for nonwrapping burst requests; that is, the request size boundary is aligned. In case of an eight-word-wrapping burst, the wrapping address always occurs on the eight-word boundary. As a consequence, all words requested must be available from the memory data buffer when the buffer size is equal to or greater than the value of *ATTACHEDDEVICEPAGELENGTH*. This usually means that data can be read from or written to the buffer at a constant rate (number of cycles between data) without wait-states between data accesses. If the memory does not behave this way (nonzero wait-state burstable memory), *WAIT* pin monitoring must be enabled to dynamically control data access completion within the burst.

---

**Note**

When the system burst request length is less than the value of *ATTACHEDDEVICEPAGELENGTH*, the GPMC proceeds with the required accesses.

---

#### **12.4.3.4.10 GPMC pSRAM Access Specificities**

pSRAM devices are SRAM-pin-compatible low-power memories that contain a self-refreshed DRAM memory array. The *GPMC\_CONFIG1\_i[11-10] DEVICETYPE* bit field (where *i* = 0 to 3) must be set to 0b00.

The pSRAM device uses the NOR protocol. It supports the following operations:

- Asynchronous single read
- Asynchronous page read
- Asynchronous single write
- Synchronous single read and write
- Synchronous burst read
- Synchronous burst write (not supported by NOR flash memory)

pSRAM devices must be powered up and initialized in a predefined manner according to the specifications of the attached device.

pSRAM devices can be programmed to use either mode: fixed or variable latency. pSRAM devices can automatically schedule autorefresh operations, which force the GPMC to use its *WAIT* signal capability when read or write operations occur during an internal self-refresh operation, or they can automatically include the autorefresh operation in the access time. These devices do not require additional *WAIT* signal capability or a minimum *nCS* high pulse width between consecutive accesses to ensure that the correct internal refresh operation is scheduled.

#### **12.4.3.4.11 GPMC NAND Access Description**

NAND (8-bit and 16-bit) memory devices using a standard NAND asynchronous address/data-multiplexing scheme can be supported on any chip-select with the appropriate asynchronous configuration settings.

As for any other type of memory compatible with the GPMC interface, accesses to a chip-select allocated to a NAND device can be interleaved with accesses to chip-selects allocated to other external devices. This interleaved capability limits the system to *chip enable don't care* NAND devices, because the chip-select allocated to the NAND device must be deasserted if accesses to other chip-selects are requested.

#### 12.4.3.4.11.1 NAND Memory Device in Byte or 16-bit Word Stream Mode

NAND devices require correct command and address programming before data array read or write accesses. The GPMC does not include specific hardware to translate a random address system request into a NAND-specific multiphase access. In that sense, GPMC NAND support, as opposed to random memory-map device support, is data stream-oriented (byte or 16-bit word).

The GPMC NAND programming model depends on a software driver for address and command formatting with the correct data address pointer value according to the block and page structure. Because of NAND structure and protocol interface diversity, the GPMC does not support automatic command and address phase programming, and software drivers must access the NAND device ID to ensure that correct command and address formatting are used for the identified device.

NAND device data read and write accesses are achieved through an asynchronous read or write access. The associated chip-select signal timing control must be programmed according to the NAND device timing specification.

Any chip-select region can be qualified as a NAND region to constrain the nADV/ALE signal as ALE (ALE active high, default state value at low) during address program access, and the nBE0/CLE signal as CLE (CLE active high, default state value at low) during command program access. GPMC address lines are not used (the previous value is not changed) during NAND access.

##### 12.4.3.4.11.1.1 Chip-Select Configuration for NAND Interfacing in Byte or Word Stream Mode

The GPMC\_CONFIG7\_i register (where  $i = 0$  to  $3$ ) associated with a NAND device region interfaced in byte or word stream mode can be initialized with a minimum size of 16MB, because any address location in the chip-select memory region can be used to access a NAND data array. The NAND flash protocol specifies an address sequence where address bits are passed through the data bus in a series of write accesses with the ALE pin asserted. After this address phase, all operations are streamed and the system requests address is irrelevant.

#### CAUTION

To allow correct command, address, and data-access controls, the GPMC\_CONFIG1\_i register associated with a NAND device region must be initialized in asynchronous read and write modes with the parameters listed in [Table 12-193](#). Failure to comply with these settings corrupts the NAND interface protocol.

**Table 12-193. Chip-Select Configuration for NAND Interfacing**

| Bit Field                | Register                          | Value        | Comments                                         |
|--------------------------|-----------------------------------|--------------|--------------------------------------------------|
| WRAPBURST                | GPMC_CONFIG1_i[31] <sup>(1)</sup> | 0            | No wrap                                          |
| READMULTIPLE             | GPMC_CONFIG1_i[30]                | 0            | Single access                                    |
| READTYPE                 | GPMC_CONFIG1_i[29]                | 0            | Asynchronous mode                                |
| WRITEMULTIPLE            | GPMC_CONFIG1_i[28]                | 0            | Single access                                    |
| WRITETYPE                | GPMC_CONFIG1_i[27]                | 0            | Asynchronous mode                                |
| CLKACTIVATIONTIME        | GPMC_CONFIG1_i[26-25]             | 0b00         |                                                  |
| ATTACHEDDEVICEPAGELENGTH | GPMC_CONFIG1_i[24-23]             | Don't care   | Single-access mode                               |
| WAITREADMONITORING       | GPMC_CONFIG1_i[22]                | 0            | Wait not monitored by GPMC access engine         |
| WAITWRITEMONITORING      | GPMC_CONFIG1_i[21]                | 0            | Wait not monitored by GPMC access engine         |
| WAITMONITORINGTIME       | GPMC_CONFIG1_i[19-18]             | Don't care   | Wait not monitored by GPMC access engine         |
| WAITPINSELECT            | GPMC_CONFIG1_i[17-16]             |              | Select which wait is monitored by edge detectors |
| DEVICESIZE               | GPMC_CONFIG1_i[13-12]             | 0b00 or 0b01 | 8- or 16-bit interface                           |

**Table 12-193. Chip-Select Configuration for NAND Interfacing (continued)**

| Bit Field           | Register              | Value      | Comments                                         |
|---------------------|-----------------------|------------|--------------------------------------------------|
| DEVICETYPE          | GPMC_CONFIG1_i[11-10] | 0b10       | NAND device in stream mode                       |
| MUXADDDATA          | GPMC_CONFIG1_i[9-8]   | 0b00       | non-multiplexed mode                             |
| TIMEPARAGRANULARITY | GPMC_CONFIG1_i[4]     | 0          | Timing achieved with best GPMC clock granularity |
| GPMCFCLKDIVIDER     | GPMC_CONFIG1_i[1-0]   | Don't care | Asynchronous mode                                |

(1)  $i = 0$  to  $3$

The GPMC\_CONFIG1\_i to GPMC\_CONFIG4\_i registers (where  $i = 0$  to  $3$ ) associated with a NAND device region must be initialized with the correct control-signal timing value according to the NAND device timing parameters.

#### 12.4.3.4.11.1.2 NAND Device Command and Address Phase Control

NAND devices require multiple address programming phases. The software driver must issue the correct number of command and address program accesses, according to the device command set and the device address-mapping scheme.

NAND device-command and address-phase programming is achieved through write requests to the GPMC\_NAND\_COMMAND\_i and GPMC\_NAND\_ADDRESS\_i register locations (where  $i = 0$  to  $3$ ) with the correct command and address values. These locations are mapped in the associated chip-select register region. The associated chip-select signal timing control must be programmed according to the NAND device timing specification.

Command and address values are not latched during the access and cannot be read back at the register location.

- Only write accesses must be issued to these locations, but the GPMC does not discard any read access. Accessing a NAND device with nOE and CLE or ALE asserted (read access) can produce undefined results.
- Write accesses to the GPMC\_NAND\_COMMAND\_i and GPMC\_NAND\_ADDRESS\_i register locations must be posted for faster operations (where  $i = 0$  to  $3$ ). The GPMC\_CONFIG[0] NANDFORCEPOSTEDWRITE bit enables write accesses to these locations as posted, even if they are defined as nonposted.

A write buffer is used to store write transaction information before the external device is accessed:

- Up to eight consecutive posted write accesses can be accepted and stored in the write buffer.
- For nonposted write, the pipeline is one deep.
- An GPMC\_STATUS[0] EMPTYWRITEBUFFERSTATUS bit stores the empty status of the write buffer.

The GPMC\_NAND\_COMMAND\_i and GPMC\_NAND\_ADDRESS\_i registers (where  $i = 0$  to  $3$ ) are 32-bit word locations, which means any 32- or 16-bit word access is split into 4- or 2-byte accesses if an 8-bit-wide NAND device is attached. For multiple-command phase or multiple-address phase, the software driver can use 32- or 16-bit word access to these registers, but it must consider the splitting and little-endian ordering scheme. When only one byte command or address phase is required, only byte write access to the GPMC\_NAND\_COMMAND\_i and GPMC\_NAND\_ADDRESS\_i registers can be used, and any of the four byte locations of the registers is valid.

The same applies to a GPMC\_NAND\_COMMAND\_i and a GPMC\_NAND\_ADDRESS\_i (where  $i = 0$  to  $3$ ) 32-bit word write access to a 16-bit-wide NAND device (split into two 16-bit word accesses). In the case of a 16-bit word write access, the MSByte of the 16-bit word value must be set according to the NAND device requirement (usually 0). Either 16-bit word location or any one of the four byte locations of the registers is valid.

#### 12.4.3.4.11.1.3 Command Latch Cycle

Writing data at the GPMC\_NAND\_COMMAND\_i location (where  $i = 0$  to  $3$ ) places the data as the NAND command value on the bus, using a regular asynchronous write access.

- nCE is controlled by the CSONTIME and CSWROFFTIME timing parameters.
- CLE is controlled by the ADVONTIME and ADVWROFFTIME timing parameters.

- nWE is controlled by the WEONTIME and WEOFFTIME timing parameters.
- ALE and nRE (nOE) are maintained inactive.

Figure 12-192 shows the NAND command latch cycle.



**Figure 12-192. NAND Command Latch Cycle**

#### Note

CLE is shared with the nBE0 output signal and has an inverted polarity from BE0. The NAND qualifier deals with this. During the asynchronous NAND data access cycle, nBE0 (also nBE1) must not toggle, because it is shared with CLE.

NAND flash memories do not use byte-enable signals.

#### 12.4.3.4.11.1.4 Address Latch Cycle

Writing data at the *GPMC\_NAND\_ADDRESS\_i* location (where *i* = 0 to 3) places the data as the NAND partial address value on the bus, using a regular asynchronous write access.

- nCS is controlled by the CSONTIME and CSWROFFTIME timing parameters.
- ALE is controlled by the ADVONTIME and ADVWROFFTIME timing parameters.
- nWE is controlled by the WEONTIME and WEOFFTIME timing parameters.
- CLE and nRE (nOE) are maintained inactive.

Figure 12-193 shows the NAND address latch cycle.



**Figure 12-193. NAND Address Latch Cycle**

#### Note

ALE is shared with the nADV output signal and has an inverted polarity from ADV. The NAND qualifier deals with this. During the asynchronous NAND data access cycle, ALE is kept stable.

#### 12.4.3.4.11.1.5 NAND Device Data Read and Write Phase Control in Stream Mode

NAND device data read and write accesses are achieved through a read or write request to the chip-select-associated memory region at any address location in the region or through a read or write request to the GPMC\_NAND\_DATA\_i location (where  $i = 0$  to  $3$ ) mapped in the chip-select-associated control register region. GPMC\_NAND\_DATA\_i is not a true register, but an address location to enable nRE or nWE signal control. The associated chip-select signal timing control must be programmed according to the NAND device timing specification.

Reading data from the GPMC\_NAND\_DATA\_i location or from any location in the associated chip-select memory region activates an asynchronous read access.

- nCS is controlled by the CSONTIME and CSRDOFFTIME timing parameters.
- nRE is controlled by the OEONTIME and OEOFETIME timing parameters.
- To take advantage of nRE high-to-data invalid minimum timing value, RDACCESSTIME can be set so that data are effectively captured after nRE deassertion. This allows optimization of NAND read access cycle time completion. For optimal timing parameter settings, see the NAND device and the device timing parameters.

ALE, CLE, and nWE are maintained inactive.

Figure 12-194 shows the NAND data read cycle.



gpmc-024

**Figure 12-194. NAND Data Read Cycle**

Writing data to the GPMC\_NAND\_DATA\_i location or to any location in the associated chip-select memory region activates an asynchronous write access.

- nCS is controlled by the CSONTIME and CSWROFFTIME timing parameters.
- nWE is controlled by the WEONTIME and WEOFETIME timing parameters.
- ALE, CLE, and nRE (nOE) are maintained inactive.

Figure 12-195 shows the NAND data write cycle.



gpmc-025

**Figure 12-195. NAND Data Write Cycle**

#### 12.4.3.4.11.1.6 NAND Device General Chip-Select Timing Control Requirement

For most NAND devices, read data access time is dominated by nCS-to-data-valid timing and has faster nRE-to-data-valid timing. Successive accesses with nCS deassertions between accesses are affected by this timing constraint. Because accesses to a NAND device can be interleaved with other chip-select accesses, there is no certainty that nCS always stays low between two accesses to the same chip-select. Moreover, an nCS deassertion time between the same chip-select NAND accesses is likely to be required as follows: the nCS deassertion requires programming CYCLETIME and RDACCESSTIME according to the nCS-to-data-valid critical timing.

To get full performance from NAND read and write accesses, the prefetch engine can dynamically reduce the following on back-to-back NAND accesses (to the same memory) and suppress the minimum nCS high pulse width between accesses:

- RDCYCLETIME
- WRCYCLETIME
- RDACCESSTIME
- WRACCESSTIME
- CSRDOFFTIME
- CSWROFFTIME
- ADVRDOFFTIME
- ADVWROFFTIME
- OEOFETIME
- WEOFETIME

For more information about optimal prefetch engine access, see [Section 12.4.3.4.11.4, Prefetch and Write-Posting Engine](#).

Some NAND devices require minimum write-to-read idle time, especially for device-status read accesses following status-read command programming (write access). If such write-to-read transactions are used, a minimum nCS high pulse width must be set. For this, CYCLE2CYCLESAMECSEN and CYCLE2CYCLEDELAY must be set according to the appropriate timing requirement to prevent any timing violation.

NAND devices usually have an important nRE high-to-data bus in three-state mode. This requires a bus turnaround setting (BUSTURNAROUND = 1) so that the next access to a different chip-select is delayed until the BUSTURNAROUND delay completes. Back-to-back NAND read accesses to the same NAND flash are not affected by the programmed bus turnaround delay.

#### **12.4.3.4.11.1.7 Read and Write Access Size Adaptation**

##### **12.4.3.4.11.1.7.1 8-Bit-Wide NAND Device**

Host 16- and 32-bit word read and write access requests to a chip-select associated with an 8-bit-wide NAND device are split into successive read and write byte accesses to the NAND memory device. Byte access is ordered according to little-endian organization. A NAND 8-bit-wide device must be interfaced on the D0D7 interface bus lane. GPMC data accesses are justified on this bus lane when the cs is associated with an 8-bit-wide NAND device.

##### **12.4.3.4.11.1.7.2 16-Bit-Wide NAND Device**

Host 32-bit word read and write access requests to a chip-select associated with a 16-bit-wide NAND device are split into successive read and write 16-bit word accesses to the NAND memory device. 16-bit word access is ordered according to little-endian organization.

Host byte read and write access requests to a 16-bit-wide NAND device are completed as 16-bit accesses on the device itself, because there is no byte-addressing capability on 16-bit-wide NAND devices. This means that the NAND device address pointer is incremented on a 16-bit word basis and not on a byte basis. For a read access, only the requested byte is given back to the host, but the remaining byte is not stored or saved by the GPMC, and the next byte or 16-bit word read access gets the next 16-bit word NAND location. For a write access, the invalid byte part of the 16-bit word is driven to FF, and the next byte or 16-bit word write access programs the next 16-bit word NAND location.

Generally, byte access to a 16-bit-wide NAND device must be avoided, especially when ECC calculation is enabled. 8- or 16-bit ECC-based computations are corrupted by a byte read to a 16-bit-wide NAND device, because the nonrequested byte is considered invalid on a read access (not captured on the external data bus; FF is fed to the ECC engine) and is set to FF on a write access.

Host requests (read/write) issued in the chip-select memory region are translated in successive single or split accesses (read/write) to the attached device. Therefore, incrementing 32-bit burst requests are translated in multiple 32-bit sequential accesses following the access adaptation of the 32-bit to 8- or 16-bit device.

#### 12.4.3.4.11.2 NAND Device-Ready Pin

The NAND memory device provides a ready pin to indicate data availability after a block/page opening and to indicate that data programming is complete. The ready pin can be connected to one of the wait GPMC input pins; data read accesses must not be tried when the ready pin is sampled inactive (device is not ready) even if the associated chip-select WAITREADMONITORING bit field is set. The duration of the NAND device busy state after the block/page opening is so long (up to 50 micro second) that accesses occurring when the ready pin is sampled inactive can stall GPMC access and eventually cause a system time-out.

---

##### Note

If a read access to a NAND flash is done using WAIT monitoring mode, the device is blocked during a page opening, and so is the GPMC. If the correct settings are used, other chip-selects can be used while the memory processes the page opening command.

To avoid a time-out caused by a block/page opening delay in NAND flash, disable the WAIT pin monitoring for read and write accesses (that is, set the *GPMC\_CONFIG1\_i[21]* WAITWRITEMONITORING and *GPMC\_CONFIG1\_i[22]* WAITREADMONITORING bits to 0, where *i* = 0 to 3), and use one of the following methods instead:

- Use software to poll the WAITxSTATUS bit (where *x* = 0 to 1) of the *GPMC\_STATUS*.
- Configure an interrupt that is generated on the WAIT signal change (through the *GPMC\_IRQENABLE* register bits[11-8]).

Even if the READWAITMONITORING bit is not set, the external memory nR/B pin status is captured in the programmed wait bit in the *GPMC\_STATUS* register.

The READWAITMONITORING bit method must be used for other memories than NAND flash, if they require the use of a WAIT signal.

---

#### 12.4.3.4.11.2.1 Ready Pin Monitored by Software Polling

The ready signal state can be monitored through the *GPMC\_STATUS[9-8]* WAITxSTATUS bit (where *x* = 0 to 1). Software must monitor the ready pin only when the signal is declared valid. Refer to the NAND device timing parameters to set the correct software temporization to monitor ready only after the invalid window is complete from the last read command written to the NAND device.

#### 12.4.3.4.11.2.2 Ready Pin Monitored by Hardware Interrupt

Each GPMC\_WAIT input pin can generate an interrupt when a wait-to-no-wait transition is detected. Depending on whether the *GPMC\_CONFIG[9-8]* WAITxPINPOLARITY bits (where *x* = 0 to 1) is active low or active high, the wait-to-no-wait transition is a low-to-high external WAIT signal transition or a high-to-low external WAIT signal transition, respectively.

The wait transition pin detector must be cleared before any transition detection. This is done by writing 1 to the WAITxEDGEDETECTIONSTATUS bit (where *x* = 0 to 1) of the *GPMC\_IRQSTATUS* register according to the GPMC\_WAIT pin used for the NAND device-ready signal monitoring. To detect a wait-to-no-wait transition, the transition detector requires a wait active time detection of a minimum of two GPMC\_FCLK cycles. Software must incorporate precautions to clear the wait transition pin detector before wait (busy) time completes.

A wait-to-no-wait transition detection can issue a GPMC interrupt if the WAITxEDGEDETECTIONENABLE bit in the *GPMC\_IRQENABLE* register is set and if the WAITxEDGEDETECTIONSTATUS bit field in the *GPMC\_IRQSTATUS* register is set.

The WAITMONITORINGTIME bit field does not affect wait-to-no-wait transition time detection.

It is also possible to poll the WAITxEDGEDETECTIONSTATUS bit field in the *GPMC\_IRQSTATUS* register according to the GPMC\_WAIT pin used for NAND device ready signal monitoring.

#### 12.4.3.4.11.3 ECC Calculator

The GPMC includes an error code correction (ECC) calculator circuitry that enables ECC calculation on the fly during data read or data program (that is, write) operations. The page size supported by the ECC calculator in one calculation/context is 512 bytes.

The user can choose from two different algorithms with different error correction capabilities through the *GPMC\_ECC\_CONFIG[16]* ECCALGORITHM bit:

1. Hamming code for 1-bit error code correction on 8- or 16-bit NAND flash organized with page size greater than 512 bytes
2. Bose-Chaudhuri-Hocquenghem (BCH) code for 4- to 16-bit error correction

The GPMC does not handle the error code correction directly. During writes, the GPMC computes parity bits. During reads, the GPMC provides enough information for the processor to correct errors without reading the data buffer all over again.

The Hamming code ECC is based on a 2-dimensional (2D) (row and column) bit parity accumulation. This parity accumulation is accomplished on the programmed number of bytes or 16-bit words read from the memory device, or is written to the memory device in stream mode.

Because the ECC engine includes only one accumulation context, it can be allocated to only one chip-select at a time through the *GPMC\_ECC\_CONFIG[3-1]* ECCCS bit field. Even if two chip-selects use different ECC algorithms, one the Hamming code and the other a BCH code, they must define separate ECC contexts because some of the ECC registers are common to all types of algorithms.

##### 12.4.3.4.11.3.1 Hamming Code

All references to ECC in this subsection refer to the 1-bit error correction Hamming code.

The ECC is based on a 2D (row and column) bit parity accumulation known as the Hamming code. The parity accumulation is done for a programmed number of bytes or 16-bit word read from the memory device or written to the memory device in stream mode.

There is no automatic error detection or correction, and the software NAND driver must read the multiple ECC calculation results, compare them to the expected code value, and take the appropriate corrective actions according to the error handling strategy (ECC storage in spare byte, error correction on read, block invalidation).

The ECC engine includes a single accumulation context. It can be allocated to a single designated chip-select at a time, and parallel computations on different chip-selects are not possible. Because it is allocated to a single chip-select, the ECC computation is not affected by interleaved GPMC accesses to other chip-selects and devices. The ECC accumulation is sequentially processed in the order of data read from or written to the memory on the designated chip-select. The ECC engine does not differentiate read accesses from write accesses and does not differentiate data from command or status information. Software must ensure that only relevant data are passed to the NAND flash memory while the ECC computation engine is active.

The starting NAND page location must be programmed first, followed by an ECC accumulation context reset with an ECC enabling, if required. The NAND device accesses discussed in the following sections must be limited to data read or write until the specified number of ECC calculations is complete.

##### 12.4.3.4.11.3.1.1 ECC Result Register and ECC Computation Accumulation Size

The GPMC includes up to nine ECC result registers (*GPMC\_ECCj\_RESULT*, where *j* = 1 to 9) to store ECC computation results when the specified number of bytes or 16-bit words has been computed.

The ECC result registers are used sequentially: one ECC result is stored in one ECC result register on the list, the next ECC result is stored in the next ECC result register on the list, and so forth, until the last ECC computation. The value of the *GPMC\_ECCj\_RESULT* register is valid only when the programmed number of bytes or 16-bit words has been accumulated, which means that the same number of bytes or 16-bit words has been read from or written to the NAND device in sequence.

The *GPMC\_ECC\_CONTROL[3-0]* ECCPOINTER bit field must be set to the correct value to select the ECC result register to be used first in the list for the incoming ECC computation process. The ECCPointer can be read to determine which ECC register is used in the next ECC result storage for the ongoing ECC computation. The value of the *GPMC\_ECCj\_RESULT* register (where  $j = 1$  to  $9$ ) can be considered valid when ECCPOINTER equals  $j + 1$ . When the *GPMC\_ECCj\_RESULT* register (where  $j = 9$ ) is updated, ECCPOINTER is frozen at 10, and ECC computing is stopped (ECCENABLE = 0).

The ECC accumulator must be reset before any ECC computation accumulation process. The *GPMC\_ECC\_CONTROL[8]* ECCCLEAR bit must be set to 1 (nonpersistent bit) to clear the accumulator and all ECC result registers.

For each ECC result (each *GPMC\_ECCj\_RESULT* register, where  $j = 1$  to  $9$ ), the number of bytes or 16-bit words used for ECC computing accumulation can be selected from between two programmable values.

The *ECCjRESULTSIZE* bits (where  $j = 1$  to  $9$ ) in the *GPMC\_ECC\_SIZE\_CONFIG* register select which programmable size value (ECCSIZE0 or ECCSIZE1) must be used for this ECC result (stored in the *GPMC\_ECCj\_RESULT* register).

The ECCSIZE0 and ECCSIZE1 bit fields allow selection of the number of bytes or 16-bit words used for ECC computation accumulation. Any even values from 2 to 512 are allowed.

Flexibility in the number of ECCs computed and the number of bytes or 16-bit words used in the successive ECC computations enables different NAND page error-correction strategies. Usually based on 256 or 512 bytes and on 128 or 256 16-bit word, the number of ECC results required is a function of the NAND device page size. Specific ECC accumulation size can be used when computing the ECC on the NAND spare byte.

For example, with a 2-KB data page, 8-bit-wide NAND device, eight ECCs accumulated on 256 bytes can be computed and added to one extra ECC computed on the 24 spare bytes area where the eight ECC results used for comparison and correction with the computed data page ECC are stored. The GPMC then provides nine *GPMC\_ECCj\_RESULT* registers ( $j = 1$  to  $9$ ) to store the results. In this case, ECCSIZE0 is set to 256, and ECCSIZE1 is set to 24; the ECC[1-8]RESULTSIZE bits are set to 0, and the ECC9RESULTSIZE bit is set to 1.

#### 12.4.3.4.11.3.1.2 ECC Enabling

The *GPMC\_ECC\_CONFIG[3-1]* ECCCS bit field selects the allocated chip-select. The *GPMC\_ECC\_CONFIG[0]* ECCENABLE bit enables ECC computation on the next detected read or write access to the selected chip-select.

The following fields must not be changed or cleared while an ECC computation is in progress:

- CCPOINTER
- ECCCLEAR
- ECCSIZE
- ECCjRESULTSIZE (where  $j = 1$  to  $9$ )
- ECC16B
- ECCCS

The ECC accumulator and ECC result register must not be changed or cleared while an ECC computation is in progress.

Table 12-194 describes the ECC enable settings.

**Table 12-194. ECC Enable Settings**

| Bit Field  | Register                | Value | Comments                                                                                                                  |
|------------|-------------------------|-------|---------------------------------------------------------------------------------------------------------------------------|
| ECCCS      | <i>GPMC_ECC_CONFIG</i>  | 0-3   | Selects the chip-select where ECC is computed                                                                             |
| ECC16B     | <i>GPMC_ECC_CONFIG</i>  | 0/1   | Selects column number for ECC calculation                                                                                 |
| ECCCLEAR   | <i>GPMC_ECC_CONTROL</i> | 0-7   | Clears all ECC result registers                                                                                           |
| ECCPOINTER | <i>GPMC_ECC_CONTROL</i> | 0-7   | A write to this bit field selects the ECC result register where the first ECC computation is stored. Set to 1 by default. |

Table 12-194. ECC Enable Settings (continued)

| Bit Field                         | Register             | Value     | Comments                                 |
|-----------------------------------|----------------------|-----------|------------------------------------------|
| ECCSIZE1                          | GPMC_ECC_SIZE_CONFIG | 0x00–0xFF | Defines ECCSIZE1                         |
| ECCSIZE0                          | GPMC_ECC_SIZE_CONFIG | 0x00–0xFF | Defines ECCSIZE0                         |
| ECCjRESULTSIZE<br>(j from 1 to 9) | GPMC_ECC_SIZE_CONFIG | 0/1       | Selects the size of ECCn result register |
| ECCENABLE                         | GPMC_ECC_CONFIG      | 1         | Enables the ECC computation              |

#### 12.4.3.4.11.3.1.3 ECC Computation

The ECC algorithm is a multiple parity bit accumulation computed on the odd and even bit streams extracted from the byte or Word16 streams. The parity accumulation is split into row and column accumulations, as shown in [Figure 12-196](#) and [Figure 12-197](#). The intermediate row and column parities are used to compute the upper level row and column parities. Only the final computation of each parity bit is used for ECC comparison and correction.

$P1o = \text{bit7 XOR bit5 XOR bit3 XOR bit1}$  on each byte of the data stream

$P1e = \text{bit6 XOR bit4 XOR bit2 XOR bit0}$  on each byte of the data stream

$P2o = \text{bit7 XOR bit6 XOR bit5 XOR bit2}$  on each byte of the data stream

$P2e = \text{bit5 XOR bit4 XOR bit1 XOR bit0}$  on each byte of the data stream

$P4o = \text{bit7 XOR bit6 XOR bit5 XOR bit4}$  on each byte of the data stream

$P4e = \text{bit3 XOR bit2 XOR bit1 XOR bit0}$  on each byte of the data stream

Each column parity bit is XORed with the previous accumulated value.



gpmc-026

Figure 12-196. Hamming Code Accumulation Algorithm (1/2)

For line parities, the bits of each new data are XORed together, and line parity bits are computed as described below:

$P8e = \text{row0 XOR row2 XOR row4 XOR ... XOR row254}$

$P8o = \text{row1 XOR row3 XOR row5 XOR ... XOR row255}$

$P16e = \text{row0 XOR row1 XOR row4 XOR row5 XOR ... XOR row252 XOR row253}$

$P16o = \text{row2 XOR row3 XOR row6 XOR row7 XOR ... XOR row254 XOR row255}$



**Figure 12-197. Hamming Code Accumulation Algorithm (2/2)**

Unused parity bits in the result registers are set to 0.

Figure 12-198 shows ECC computation for a 256-byte data stream (read or write). The result includes six column parity bits (P1o-P2o-P4o for odd parities, and P1e-P2e-P4e for even parities) and sixteen row parity bits (P8o-P16o-P32o--P1024o for odd parities, and P8e-P16e-P32e--P1024e for even parities).



**Figure 12-198. ECC Computation for a 256-Byte Data Stream (Read or Write)**

Figure 12-199 shows ECC computation for a 512-byte data stream (read or write). The result includes six column parity bits (P1o-P2o-P4o for odd parities, and P1e-P2e-P4e for even parities) and eighteen row parity bits (P8o-P16o-P32o--P1024o--P2048o for odd parities, and P8e-P16e-P32e--P1024e--P2048e for even parities).



gpmc-029

**Figure 12-199. ECC Computation for a 512-Byte Data Stream (Read or Write)**

For a 2-KB page, four 512 bytes ECC calculations plus 1 for the spare area are required. Results are stored in the *GPMC\_ECC<sub>j</sub>\_RESULT* registers (where  $j = 1$  to 9).

#### 12.4.3.4.11.3.1.4 ECC Comparison and Correction

To detect an error, the computed ECC result must be XORed with the parity value stored in the spare area of the accessed page.

- If the result of this logical XOR is all 0s, no error is detected and the read data is correct.
- If every second bit in the parity result is a 1, 1 bit is corrupted and is located at bit address (P2048o, P1024o, P512o, P256o, P128o, P64o, P32o, P16o, P8o, P4o, P2o, P1o). Software must correct the corresponding bit.
- If only 1 bit in the parity result is 1, it is an ECC error and the read data is correct.

#### 12.4.3.4.11.3.1.5 ECC Calculation Based on 8-Bit Word

The 8-bit-based ECC computation is used for 8-bit-wide NAND device interfacing.

The 8-bit-based ECC computation can be used for 16-bit-wide NAND device interfacing to get backward compatibility on the error-handling strategy used with 8-bit-wide NAND devices. In this case, the 16-bit-wide data read from or written to the NAND device is fragmented into 2 bytes. According to little-endian access, the LSB of the 16-bit-wide data is ordered first in the byte stream used for 8-bit-based ECC computation.

#### 12.4.3.4.11.3.1.6 ECC Calculation Based on 16-Bit Word

ECC computation based on an 16-bit word is used for 16-bit-wide NAND device interfacing. This ECC computation is not supported when interfacing an 8-bit-wide NAND device, and the *GPMC\_ECC\_CONFIG[7]* ECC16B bit must be set to 0 when interfacing an 8-bit-wide NAND device.

The parity computation based on 16-bit words affects the row and column parity mapping. The main difference is that the odd and even parity bits P8o and P8e are computed on rows for an 8-bit-based ECC and on columns for a 16-bit based ECC. [Figure 12-200](#) and [Figure 12-201](#) show a 128 Word16 ECC computation scheme and a 256 16-bit word ECC computation scheme.



**Figure 12-200. 128 Word16 ECC Computation**



**Figure 12-201. 256 Word16 ECC Computation**

#### 12.4.3.4.11.3.2 BCH Code

All references to ECC in this subsection refer to the 4- to 16-bit error correction BCH code.

##### 12.4.3.4.11.3.2.1 Requirements

1. Read and write accesses to a NAND flash take place by whole pages, in a predetermined sequence: first the data byte page itself, and then some spare bytes, including the BCH ECC (and other information). The NAND device can cache a full page, including spares, for read and write accesses.
  - Typical page write sequence:
    - Sequential write to NAND cache of main data plus spare data, for a page. ECC is calculated on the fly. Calculated ECC can be inserted on the fly in the spares or replaced by dummy accesses.

- When the calculated ECC is replaced by dummy accesses, it must be written to the cache in a second, separate phase. The ECC module is disabled during that time.
  - NAND writes its cache line (page) to the array.
  - Typical page read sequence:
    - Sequential read of a page. ECC is calculated on the fly.
    - The status of the ECC module buffers determines the presence of errors.
2. Accesses to several memories can be interleaved by the GPMC, but only one of those memories at a time can be a NAND using the BCH engine; in other words, only one BCH calculation (for example, for a single page) can be ongoing at any time. The sequential nature of NAND accesses ensures that the data is always written or read out in the same order. BCH-relevant accesses are selected by the chip-selects of the GPMC.
  3. Each page can hold up to 4KB of data, spare bytes not included. This means up to  $8 \times 512$ -byte BCH messages. Because all the data is written or read out first, followed by the BCH ECC, the BCH engine must be able to hold eight 104-bit remainders or syndromes (or smaller, 52-bit ones) at the same time.
- The BCH module can store all remainders internally. After the page start, an internal counter is used to detect the 512-byte sector boundaries. On those boundaries, the current remainder is stored and the divider reset for the next calculation. At the end of the page, the BCH module contains all remainders.
4. NAND access cycles hold 8 or 16 bits of data each (1 or 2 bytes); Each NAND cycle takes at least four cycles of the GPMC internal clock. This means the NAND flash timing parameters must define a RDCYCLETIME and a WRCYCLETIME of at least four clock cycles after optimization when using the BCH calculator.
  5. The spare area is assumed to be large enough to hold the BCH ECC; that is, to have a message of at least 13 bytes available per 512-byte sector of data. The zone of unused spare area by the ECC may or may not be protected by the same ECC scheme, by extending the BCH message beyond 512 bytes (the maximum codeword is 1023 bytes long, ECC included, which leaves much space to cover spare bytes).

#### 12.4.3.4.11.3.2.2 Memory Mapping of BCH Codeword

BCH encoding considers a block of data to protect as a polynomial message  $M(x)$ . In a standard case, 512 bytes of data (that is,  $2^{12}$  bits = 4096 bits) are seen as a polynomial of degree  $2^{12} - 1 = 4095$ , with parameters ranging from  $M_0$  to  $M_{4095}$ . For 512 bytes of data, 52 bits are required for 4-bit error correction, 104 bits are required for 8-bit error correction, and 207 bits are required for 16-bit error correction. The ECC is a remainder polynomial  $R(x)$  of degree 103 (or 51, depending on the selected mode). The complete codeword  $C(x)$  is the concatenation of  $M(x)$  and  $R(x)$ , as described in [Table 12-195](#).

**Table 12-195. Flattened BCH Codeword Mapping (512 Bytes + 104 Bits)**

|            | Message $M(x)$ |     |       | ECC $R(x)$ |     |       |
|------------|----------------|-----|-------|------------|-----|-------|
| Bit Number | $M_{4095}$     | ... | $M_0$ | $R_{103}$  | ... | $R_0$ |
|            |                |     |       |            |     |       |

If the message is extended by the addition of spare bytes to be protected by the same ECC, the principle is still valid. For example, a 3-byte extension of the message gives a polynomial message  $M(x)$  of degree  $((512 + 3) \times 8) - 1 = 4119$ , for a total of  $3 + 13 = 16$  spare bytes of spare, all protected as part of the same codeword.

The message and the ECC bits are manipulated and mapped in the GPMC byte-oriented system. The ECC bits are stored in the following registers (where  $i = 0$  to 3):

- GPMC\_BCH\_RESULT0\_i
- GPMC\_BCH\_RESULT1\_i
- GPMC\_BCH\_RESULT2\_i
- GPMC\_BCH\_RESULT3\_i

#### 12.4.3.4.11.3.2.2.1 Memory Mapping of Data Message

The data message mapping must follow the following rules:

- Bit endianness within a byte is little-endian; that is, the bytes LSB is also the lowest-degree polynomial parameter: a byte  $b_7-b_0$  (with  $b_0$  the LSB) represents a segment of polynomial  $b_7 * x^{(7+i)} + b_6 * x^{(6+i)} + \dots + b_0 * x^i$

- The message is mapped in the NAND starting with the highest-order parameters, that is, in the lowest addresses of a NAND page.
- Byte endianness within the 16-bit words in the NAND is big-endian (that is, the same message mapped in 8- and 16-bit memories has the same content at the same byte address).

### Note

The BCH module has no visibility over actual addresses. The most important point is the sequence of data words the BCH sees. However, the NAND page is always scanned incrementally in read and write accesses, which produces the mapping patterns described in the following.

**Table 12-196** and **Table 12-197** describe the mapping of the same 512-byte vector (typically, a BCH message) in the NAND memory space. The byte address is only an offset module 512 (0x200), because the same page may contain several contiguous 512-byte sectors (BCH blocks). The LSB and MSB are, respectively, the bits M0 and M( $2^{12}-1$ ) of the codeword mapping discussed previously. In both cases the data vectors are aligned; that is, their boundaries coincide with the RAM data word boundaries.

**Table 12-196. Aligned Message Byte Mapping in 8-Bit NAND**

| Byte Offset | 8-Bit Word             |
|-------------|------------------------|
| 0x000       | (MSB) Byte 511 (0x1FF) |
| 0x001       | Byte 510 (0x1FE)       |
| ...         | ...                    |
| 0x1FF       | Byte 0 (0x0) (LSB)     |

**Table 12-197. Aligned Message Byte Mapping in 16-Bit NAND**

| Byte Offset | 16-Bit Word MSB  | 16-Bit Word LSB        |
|-------------|------------------|------------------------|
| 0x000       | Byte 510 (0x1FE) | (MSB) Byte 511 (0x1FF) |
| 0x002       | Byte 508 (0x1FC) | Byte 509 (0x1FD)       |
| ...         | ...              | ...                    |
| 0x1FE       | Byte 0 (0x0)     | (LSB) Byte 1 (0x1)     |

**Table 12-198** through **Table 12-203** list the mapping in memory of arbitrarily-sized messages, starting on access (byte or 16-bit word) boundaries for more clarity. Note that message may actually start and stop on arbitrary nibbles. A nibble is a 4-bit entity. The unused nibbles are not discarded, and they can still be used by the BCH module, but as part of the next message section (for example, on the ECC of another sector).

**Table 12-198. Aligned Nibble Mapping of Message in 8-Bit NAND**

| Byte Offset | 8-Bit Word                    |                                |
|-------------|-------------------------------|--------------------------------|
|             | 4-Bit Most Significant Nibble | 4-Bit Least Significant Nibble |
| 1           | (MSB) Nibble S-1              | Nibble S-2                     |
| 2           | Nibble S-3                    | Nibble S-4                     |
| ...         | ...                           | ...                            |
| S/2 - 2     | Nibble 3                      | Nibble 2                       |
| S/2 - 1     | Nibble 1                      | Nibble 0 (LSB)                 |

**Table 12-199. Misaligned Nibble Mapping of Message in 8-Bit NAND**

| Byte Offset     | 8-Bit Word                    |                                |
|-----------------|-------------------------------|--------------------------------|
|                 | 4-Bit Most Significant Nibble | 4-Bit Least Significant Nibble |
| 1               | (MSB) Nibble S-1              | Nibble S-2                     |
| 2               | Nibble S-3                    | Nibble S-4                     |
| ...             | ...                           | ...                            |
| (S + 1) / 2 - 2 | Nibble 2                      | Nibble 1                       |

**Table 12-199. Misaligned Nibble Mapping of Message in 8-Bit NAND (continued)**

| Byte Offset       | 8-Bit Word     |  |  |  |
|-------------------|----------------|--|--|--|
| $(S + 1) / 2 - 1$ | Nibble 0 (LSB) |  |  |  |

**Table 12-200. Aligned Nibble Mapping of Message in 16-Bit NAND**

| Byte Offset | 16-Bit Word                   |                |                                |            |
|-------------|-------------------------------|----------------|--------------------------------|------------|
|             | 4-Bit Most Significant Nibble |                | 4-Bit Least Significant Nibble |            |
| 0           | Nibble S-3                    | Nibble S-4     | (MSB) Nibble S-1               | Nibble S-2 |
| 2           | Nibble S-7                    | Nibble S-8     | Nibble S-5                     | Nibble S-6 |
| ...         | ...                           | ...            | ...                            | ...        |
| $S/2 - 4$   | Nibble 5                      | Nibble 4       | Nibble 7                       | Nibble 6   |
| $S/2 - 2$   | Nibble 1                      | Nibble 0 (LSB) | Nibble 3                       | Nibble 2   |

**Table 12-201. Misaligned Nibble Mapping of Message in 16-Bit NAND (1 Unused Nibble)**

| Byte Offset       | 16-Bit Word                   |            |                                |            |
|-------------------|-------------------------------|------------|--------------------------------|------------|
|                   | 4-Bit Most Significant Nibble |            | 4-Bit Least Significant Nibble |            |
| 0                 | Nibble S-3                    | Nibble S-4 | (MSB) Nibble S-1               | Nibble S-2 |
| 2                 | Nibble S-7                    | Nibble S-8 | Nibble S-5                     | Nibble S-6 |
| ...               | ...                           | ...        | ...                            | ...        |
| $(S + 1) / 2 - 4$ | Nibble 4                      | Nibble 3   | Nibble 6                       | Nibble 5   |
| $(S + 1) / 2 - 2$ | Nibble 0 (LSB)                |            |                                | Nibble 2   |
|                   |                               |            |                                | Nibble 1   |

**Table 12-202. Misaligned Nibble Mapping of Message in 16-Bit NAND (2 Unused Nibbles)**

| Byte Offset       | 16-Bit Word                   |            |                                |                |
|-------------------|-------------------------------|------------|--------------------------------|----------------|
|                   | 4-Bit Most Significant Nibble |            | 4-Bit Least Significant Nibble |                |
| 0                 | Nibble S-3                    | Nibble S-4 | (MSB) Nibble S-1               | Nibble S-2     |
| 2                 | Nibble S-7                    | Nibble S-8 | Nibble S-5                     | Nibble S-6     |
| ...               | ...                           | ...        | ...                            | ...            |
| $(S + 2) / 2 - 4$ | Nibble 3                      | Nibble 2   | Nibble 5                       | Nibble 4       |
| $(S + 2) / 2 - 2$ |                               |            | Nibble 1                       | Nibble 0 (LSB) |

**Table 12-203. Misaligned Nibble Mapping of Message in 16-Bit NAND (3 Unused Nibbles)**

| Byte Offset       | 16-Bit Word                   |            |                                |            |  |
|-------------------|-------------------------------|------------|--------------------------------|------------|--|
|                   | 4-Bit Most Significant Nibble |            | 4-Bit Least Significant Nibble |            |  |
| 0                 | Nibble S-3                    | Nibble S-4 | (MSB) Nibble S-1               | Nibble S-2 |  |
| 2                 | Nibble S-7                    | Nibble S-8 | Nibble S-5                     | Nibble S-6 |  |
| ...               | ...                           | ...        | ...                            | ...        |  |
| $(S + 3) / 2 - 4$ | Nibble 2                      | Nibble 1   | Nibble 4                       | Nibble 3   |  |
| $(S + 3) / 2 - 2$ |                               |            | Nibble 0 (LSB)                 |            |  |

Many other cases exist than those given in the previous tables; for example, where the message does not start on a word boundary.

#### 12.4.3.4.11.3.2.2.2 Memory-Mapping of the ECC

The ECC (or remainder) is presented by the BCH module as a single 104-bit (or 52-bit), little-endian vector. Software must fetch those 13 bytes (or 6 bytes) from the module interface and then store them to the spare area (page write) in the NAND or to an intermediate buffer for comparison with the stored ECC (page read). There are no constraints on the ECC mapping inside the spare area: it is software-controlled.

It is advised, however, to maintain a coherence in the respective formats of the message or the ECC remainder once they have been read out of the NAND. The error correction algorithm works from the complete codeword

(concatenated message and remainder) once an error is detected. The creation of this codeword must be made as straightforward as possible.

There are cases in which the same NAND access contains both data and the ECC protecting that data. This is the case when the data/ECC boundary (which can be on any nibble) does not coincide with an access boundary. The ECC is calculated on the fly following the write. In that case, the write must also contain part of the ECC because it is impossible to insert the ECC on the fly. Instead:

- During the initial page write (BCH encoding), the ECC is replaced by dummy bits. The BCH encoder is by definition turned OFF during the ECC section, so the BCH result is unmodified.
- During a second phase, the ECC is written to the correct location, next to the actual data.
- The completed line buffer is then written to the NAND array.

#### **12.4.3.4.11.3.2.2.3 Wrapping Modes**

For a given wrapping mode, the module automatically goes through a specific number of sections as data is being fed into the module. For each section, the BCH core can be enabled (in which case the data is fed to the BCH divider) or not (in which case the BCH simply counts to the end of the section). When enabled, the data is added to the ongoing calculation for a given sector number (for example, number 0).

Wrapping modes are described as follows. To better understand and see the real-life read and write sequences implemented with each mode, see [Section 12.4.3.4.11.3.2.3, Supported NAND Page Mappings and ECC Schemes](#).

For each mode:

- A sequence describes the mode in pseudo language, with, for each section, the size and the buffer used for ECC processing (if ON). The programmable lengths are size, size0, and size1.
- A checksum condition is given. If the checksum condition is not respected for a given mode, the module behavior is unpredictable. S is the number of sectors in the page; size0 and size1 are the section sizes programmed for the mode, in nibbles.

Wrapping modes 8 through 11 insert a 1-nibble padding where the BCH processing is OFF. This is intended for t = 4 ECC, where ECC is 6 bytes long and the ECC area is expected to include (at least) 1 unused nibble to remain byte-aligned.

##### **12.4.3.4.11.3.2.2.3.1 Manual Mode (0x0)**

This mode is intended for short sequences, added manually to a given buffer through the software data port input. A complete page may be built out of several such sequences.

To process an arbitrary sequence of 4-bit nibbles, accesses to the software data port, containing the appropriate data, must be made. If the sequence end does not coincide with an access boundary (for example, to process 5 nibbles = 20 bits in 16-bit access mode) and those nibbles must be skipped, a number of unused nibbles must be programmed in GPMC\_ECC\_SIZE\_CONFIG[31-22] ECCSIZE1 In the same example, 5 nibbles to process + 3 to discard = 8 nibbles = 2 × 16-bit accesses. Software must set:

- GPMC\_ECC\_SIZE\_CONFIG[21-12] ECCSIZE0 = 0x5
- GPMC\_ECC\_SIZE\_CONFIG[31-22] ECCSIZE1 = 0x3

---

##### **Note**

In the following figures, size and size0 are the same parameter.

---



gpmc-032

**Figure 12-202. Manual Mode Sequence and Mapping**

Section processing sequence:

- One time with buffer
  - size0 nibbles of data, processing ON
  - size1 nibbles of unused data, processing OFF

Checksum: size0 + size1 nibbles must fit in a whole number of accesses.

In the following sections, S is the number of sectors in the page.

#### 12.4.3.4.11.3.2.2.3.2 Mode 0x1

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing ON
  - size1 nibbles spare, processing OFF

Checksum: Spare area size (nibbles) = S – (size0 + size1)

#### 12.4.3.4.11.3.2.2.3.3 Mode 0xA (10)

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing ON
  - 1 nibble pad spare, processing OFF
  - size1 nibbles spare, processing OFF

Checksum: Spare area size (nibbles) = S – (size0 + 1 + size1)

#### 12.4.3.4.11.3.2.2.3.4 Mode 0x2

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - size0 nibbles spare, processing OFF
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = S – (size0 + size1)

#### 12.4.3.4.11.3.2.2.3.5 Mode 0x3

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time with buffer 0
  - size0 nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = size0 + (S – size1)

#### 12.4.3.4.11.3.2.2.3.6 Mode 0x7

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time with buffer 0
  - size0 nibbles spare, processing ON
- Repeat S times (no buffer used)
  - size1 nibbles spare, processing OFF

Checksum: Spare area size (nibbles) = size0 + (S – size1)

#### 12.4.3.4.11.3.2.2.3.7 Mode 0x8

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time with buffer 0
  - size0 nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - 1 nibble padding spare, processing OFF
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = size0 + (S – (1 + size1))

#### 12.4.3.4.11.3.2.2.3.8 Mode 0x4

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time (no buffer used)
  - size0 nibbles spare, processing OFF
- Repeat with buffer 0 to S-1
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) = size0 + (S – size1)

#### 12.4.3.4.11.3.2.2.3.9 Mode 0x9

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- One time (no buffer used)
  - size0 nibbles spare, processing OFF
- Repeat with buffer 0 to S-1
  - 1 nibble padding spare, processing OFF
  - size1 nibbles spare, processing ON

Checksum: Spare area size (nibbles) =  $\text{size0} + (\text{S} - (1 + \text{size1}))$

#### 12.4.3.4.11.3.2.2.3.10 Mode 0x5

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - $\text{size0}$  nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - $\text{size1}$  nibbles spare, processing ON

Checksum: Spare area size (nibbles) =  $\text{S} - (\text{size0} + \text{size1})$

#### 12.4.3.4.11.3.2.2.3.11 Mode 0xB (11)

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - $\text{size0}$  nibbles spare, processing ON
- Repeat with buffer 0 to S-1
  - 1 nibble padding spare, processing OFF
  - $\text{size1}$  nibbles spare, processing ON

Checksum: Spare area size (nibbles) =  $\text{S} - (\text{size0} + 1 + \text{size1})$

#### 12.4.3.4.11.3.2.2.3.12 Mode 0x6

Page processing sequence:

- Repeat with buffer 0 to S-1
  - 512-byte data, processing ON
- Repeat with buffer 0 to S-1
  - $\text{size0}$  nibbles spare, processing ON
- Repeat S times (no buffer used)
  - $\text{size1}$  nibbles spare, processing OFF

Checksum: Spare area size (nibbles) =  $\text{S} - (\text{size0} + \text{size1})$

### **12.4.3.4.11.3.2.3 Supported NAND Page Mappings and ECC Schemes**

The following rules apply to the entire mapping description:

- Main data area (sectors) size is hardcoded to 512 bytes.
- Spare area size is programmable.
- All page sections (of main area data bytes, protected spare bytes, unprotected spare bytes, and ECC) are defined as explained in [Section 4.3.4.11.3.2.2.1, Memory Mapping of Data Message](#).

Each of the following sections gives a NAND page mapping example (per-sector spare mappings, pooled spare mapping, per-sector spare mapping, with ECC separated at the end of the page).

In the mapping diagrams, sections that belong to the same BCH codeword have the same color (blue or green); unprotected sections are not covered (orange) by the BCH scheme.

Below each mapping diagram, a write (encoding) and read (decoding: syndrome generation) sequence is given, with the number of the active buffers at each point in time (yellow). In the inactive zones (grey), no computing is taking place but the data counter is still active.

In [Figure 12-203](#) through [Figure 12-205](#), the tables on the left summarize the mode, size0, and size1 parameters to program for, respectively, write and read processing of a page, with the given mapping, where:

- P is the size of spare byte section Protected by the ECC (in nibbles)
- U is the size of spare byte section Unprotected by the ECC (in nibbles)
- E is the size of the ECC (in nibbles)
- S is the number of Sectors per page (two in the current diagrams)

Each time the processing of a BCH block is complete (ECC calculation for write/encoding, syndrome generation for read/decoding, indicated by red arrows), the update pointer is pulsed. The processing for block 0 can be the first or the last to complete, depending on the NAND page mapping and operation (read or write). All examples show a page size of 1 KB + spares; that is, S = 2 sectors of 512 bytes. The same principles can be extended to larger pages by adding more sectors.

The actual BCH codeword size is used during the error location work to restrict the search range: by definition, errors can happen only in the codeword that was actually written to the NAND, not in the mathematical codeword of  $n = 2^{13} - 1 = 8191$  bits; that codeword (higher-order bits) is all-zero and implicit during computations.

The actual BCH codeword size depends on the mode, the programmed sizes, and the sector number (all sizes in nibbles):

- Spares mapped and protected per sector (below: see M1-M2-M3-M9-M10):
  - All sectors:  $(512) + P + E$
- Spares pooled and protected by sector 0 (below: see M5-M6):
  - Sector 0 codeword:  $(512) + P + E$
  - Other sectors:  $(512) + E$
- Unprotected spares (below: see M4-M7-M8-M11-M12):
  - All codewords  $(512) + E$

#### **12.4.3.4.11.3.2.3.1 Per-Sector Spare Mappings**

In these schemes, each 512-byte sector of the main area has its own dedicated section of the spare area. The spare area of each sector is composed of:

- ECC, which must be located after the data it protects
- Other data, which may or may not be protected by the ECC for its sector.

| M1                                                                                   | Per-sector spares<br>Spares covered by sector ECC per sector ECC mapping.                                                                                                                                                                 |       |       |  |      |       |       |       |   |   |   |      |   |     |
|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|--|------|-------|-------|-------|---|---|---|------|---|-----|
|                                                                                      | <table border="1"> <thead> <tr> <th></th><th>Mode</th><th>Size0</th><th>Size1</th></tr> </thead> <tbody> <tr> <td>Write</td><td>1</td><td>P</td><td>E</td></tr> <tr> <td>Read</td><td>1</td><td>P+E</td><td>0</td></tr> </tbody> </table> |       |       |  | Mode | Size0 | Size1 | Write | 1 | P | E | Read | 1 | P+E |
|                                                                                      | Mode                                                                                                                                                                                                                                      | Size0 | Size1 |  |      |       |       |       |   |   |   |      |   |     |
| Write                                                                                | 1                                                                                                                                                                                                                                         | P     | E     |  |      |       |       |       |   |   |   |      |   |     |
| Read                                                                                 | 1                                                                                                                                                                                                                                         | P+E   | 0     |  |      |       |       |       |   |   |   |      |   |     |
|    |                                                                                                                                                                                                                                           |       |       |  |      |       |       |       |   |   |   |      |   |     |
|    |                                                                                                                                                                                                                                           |       |       |  |      |       |       |       |   |   |   |      |   |     |
|   |                                                                                                                                                                                                                                           |       |       |  |      |       |       |       |   |   |   |      |   |     |
|  |                                                                                                                                                                                                                                           |       |       |  |      |       |       |       |   |   |   |      |   |     |

gpmc-033

Figure 12-203. NAND Page Mapping and ECC: Per-Sector Schemes

#### 12.4.3.4.11.3.2.3.2 Pooled Spare Mapping

In the following schemes, the spare area is pooled for the page.

- The ECC of each sector is aligned at the end of the spare area.
- The non-ECC spare data may or may not be covered by the ECC of sector 0.



gpmc-034

**Figure 12-204. NAND Page Mapping and ECC: Pooled Spare Schemes**

#### 12.4.3.4.11.3.2.3.3 Per-Sector Spare Mapping, with ECC Separated at the End of the Page

In these schemes, each 512-byte sector of the main area is associated with two sections of the spare area.

- ECC section, all aligned at the end of the page
- Other data section, aligned before the ECCs, each of which may or may not be protected by the ECC for its sector.

|                                                                                      |                                                                                                      |       |       |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-------|-------|
| M9                                                                                   | Per-sector spares, separate ECC<br>Spares covered by sector ECC.<br>All ECC at the end.              |       |       |
|                                                                                      | Mode                                                                                                 | Size0 | Size1 |
| Write                                                                                | 6                                                                                                    | P     | E     |
| Read                                                                                 | 5                                                                                                    | P     | E     |
|    |                                                                                                      |       |       |
| M10                                                                                  | Per-sector spares, separate ECC<br>Spares covered by sector ECC.<br>All ECC at the end, left-padded. |       |       |
|                                                                                      | Mode                                                                                                 | Size0 | Size1 |
| Write                                                                                | 6                                                                                                    | P     | 1+E   |
| Read                                                                                 | 11                                                                                                   | P     | E     |
|    |                                                                                                      |       |       |
| M11                                                                                  | Per-sector spares, separate ECC<br>Spares not covered by ECC.<br>All ECC at the end.                 |       |       |
|                                                                                      | Mode                                                                                                 | Size0 | Size1 |
| Write                                                                                | 6                                                                                                    | 0     | U+E   |
| Read                                                                                 | 4                                                                                                    | SU    | E     |
|   |                                                                                                      |       |       |
| M12                                                                                  | Per-sector spares, separate ECC<br>Spares not covered by ECC.<br>All ECC at the end, left-padded.    |       |       |
|                                                                                      | Mode                                                                                                 | Size0 | Size1 |
| Write                                                                                | 6                                                                                                    | 0     | U+1+E |
| Read                                                                                 | 9                                                                                                    | SU    | E     |
|  |                                                                                                      |       |       |

gpmc\_035

Figure 12-205. NAND Page Mapping and ECC: Per-Sector Schemes, With Separate ECC

## 12.4.3.4.11.4 Prefetch and Write-Posting Engine

## Note

Some of the GPMC features described in this section may not be supported on this family of devices.  
For more information, see *GPMC Not Supported Features*.

NAND device data access cycles are usually much slower than the CPU system frequency; such NAND read or write accesses issued by the processor affect the overall system performance, especially considering long

read or write sequences required for NAND page loading or programming. To minimize this effect on system performance, the GPMC includes a prefetch and write-posting engine, which can be used to read from or write to any chip-select location in a buffered manner.

The prefetch and write-posting engine is a simplified embedded-access requester that presents requests to the access engine on a user-defined chip-select target. The access engine interleaves these requests with any request coming from the interconnect interface; as a default, the prefetch and write-posting engine has the lowest priority.

The prefetch and write-posting engine is dedicated to data-stream access (as opposed to random data access); thus, it is primarily dedicated to NAND support. The engine does not include an address generator; the request is limited to chip-select target identification. It includes a 64-byte FIFO associated with a DMA request synchronization line, for optimal DMA-based use.

The prefetch and write-posting engine uses an embedded 64-byte (32 16-bit word) FIFO to prefetch data from the NAND device in read mode (prefetch mode) or to store host data to be programmed into the NAND device in write mode (write-posting mode). The FIFO draining and filling (read and write) can be controlled by a device host processor through interrupt synchronization (an interrupt is triggered whenever a programmable threshold is reached) or by a device DMA module through DMA request synchronization, with a programmable request byte size in prefetch or posting mode.

The prefetch and write-posting engine includes a single memory pool. Therefore, only one mode, read or write, can be used at any given time. In other words, the prefetch and write-posting engine is a single-context engine that can be allocated to only one chip-select at a time for a read prefetch or a write-posting process.

The engine does not support atomic command and address phase programming and is limited to linear memory read or write access. As a consequence, it is limited to NAND data-stream access. The engine depends on the NAND software driver to control block and page opening with the correct data address pointer initialization, before the engine can read from or write to the NAND memory device.

Once started, engine data read and write sequencing is based solely on FIFO location availability and until the total programmed number of bytes is read or written.

Any host-concurrent accesses to a different chip-select are correctly interleaved with ongoing engine accesses. The engine has the lowest priority access so that host accesses to a different chip-select do not suffer a large latency.

A round-robin arbitration scheme can be enabled to ensure minimum bandwidth to the prefetch and write-posting engine in the case of back-to-back direct memory requests to a different chip-select. If the *GPMC\_PREFETCH\_CONFIG1[23]* PFPWENROUNDROBIN bit is enabled, the arbitration grants the prefetch and write-posting engine access to the GPMC bus for a number of requests programmed in the *GPMC\_PREFETCH\_CONFIG1[19-16]* PFPWWEIGHTEDPRIO bit field.

The prefetch/write-posting engine read or write request is routed to the access engine with the chip-select destination ID. After the required arbitration phase, the access engine processes the request as a single access with the data access size equal to the device size specified in the corresponding chip-select configuration.

---

#### Note

The destination chip-select configuration must be set to the NAND protocol-compatible configuration for which address lines are not used (the address bus is not changed from its current value). Selecting a different chip-select configuration can produce undefined behavior.

---

##### **12.4.3.4.11.4.1 General Facts About the Engine Configuration**

The engine can be configured only if the *GPMC\_PREFETCH\_CONTROL[0]* STARTENGINE bit is deasserted.

The engine must be correctly configured in prefetch or write-posting mode and must be linked to a NAND chip-select before it can be started. The chip-select is linked using the *GPMC\_PREFETCH\_CONFIG1[26-24]* ENGINECSSELECTION bit field.

In prefetch and write-posting modes, the engine uses byte or 16-bit word access requests, respectively, for an 8- or 16-bit-wide NAND device attached to the linked chip-select. The FIFOTHRESHOLD and TRANSFERCOUNT bit fields must be programmed accordingly as a number of bytes.

When the GPMC\_PREFETCH\_CONFIG1[7] ENABLEENGINE bit is set, the FIFO entry on the interconnect port side is accessible at any address in the associated chip-select memory region. When the ENABLEENGINE bit is set, any host access to this chip-select is rerouted to the FIFO input. Directly accessing the NAND device linked to this chip-select from the host is still possible through the following registers (where  $i = 0$  to 3):

- GPMC\_NAND\_COMMAND\_i
- GPMC\_NAND\_ADDRESS\_i
- GPMC\_NAND\_DATA\_i

The FIFO entry on the interconnect port can be accessed with byte, 16-bit word, or 32-bit word access size, according to little-endian format, even though the FIFO input is 32 bits wide.

The FIFO control is made easier through the use of interrupts or DMA requests associated with the FIFOTHRESHOLD bit field. The GPMC\_PREFETCH\_STATUS[30-24] FIFOPOINTER bit field monitors the number of available bytes to be read in prefetch mode or the number of free empty slots that can be written in write-posting mode. The GPMC\_PREFETCH\_STATUS[13-0] COUNTVALUE bit field monitors the number of remaining bytes to be read or written by the engine according to the value of the TRANSFERCOUNT bit field. The FIFOPOINTER and COUNTVALUE bit fields are always expressed as a number of bytes even if a 16-bit-wide NAND device is attached to the linked chip-select.

In prefetch mode, when the FIFOPOINTER equals 0 (that is, the FIFO is empty), a host read access receives the byte last read from the FIFO as its response. In case of 32-bit word or 16-bit word read accesses, the last byte read from the FIFO is copied the required number of times to fit the requested word size. In write-posting mode, when the FIFOPOINTER equals 0 (that is, the FIFO is full), a host write overwrites the last FIFO byte location. There is no underflow or overflow error reporting in the GPMC.

#### 12.4.3.4.11.4.2 Prefetch Mode

The prefetch mode is selected when the GPMC\_PREFETCH\_CONFIG1[0] ACCESSMODE bit is cleared.

The NAND software driver must issue the block and page opening (READ) command with the correct data address pointer initialization before the engine can be started to read from the NAND memory device. The engine is started by asserting the GPMC\_PREFETCH\_CONTROL[0] STARTENGINE bit. The STARTENGINE bit automatically clears when the prefetch process completes.

If required, the ECC calculator engine must be initialized (that is, reset, configured, and enabled) before the prefetch engine is started so that the ECC is computed correctly on all data read by the prefetch engine.

When the GPMC\_PREFETCH\_CONFIG1[3] SYNCHROMODE bit is cleared, the prefetch engine starts requesting data as soon as the STARTENGINE bit is set. If using this configuration, the host must monitor the NAND device-ready pin so that it sets the STARTENGINE bit only when the NAND device is in a ready state (that is, data is valid for prefetching).

When the SYNCHROMODE bit is set, the prefetch engine starts requesting data when an active-to-inactive WAIT signal transition is detected. The transition detector must be cleared before any transition detection (see [Section 12.4.3.4.11.2.2, Ready Pin Monitored by Hardware Interrupt](#)). The GPMC\_PREFETCH\_CONFIG1[5-4] WAITPINSELECTOR bit field selects which GPMC\_WAIT pin edge detector triggers the prefetch engine in this synchronized mode.

If the STARTENGINE bit is set after the NAND address phase (page opening command), the engine is effectively started only after the actual NAND address phase completion. To prevent GPMC stall during this NAND address phase, set the STARTENGINE bit before NAND address phase completion when in synchronized mode. The prefetch engine starts when an active-to-inactive WAIT signal transition is detected. The STARTENGINE bit is automatically cleared on prefetch process completion.

The prefetch engine issues a read request to fill the FIFO with the amount of data specified by the GPMC\_PREFETCH\_CONFIG2[13-0] TRANSFERCOUNT bit field.

Table 12-204 describes the prefetch mode configuration.

**Table 12-204. Prefetch Mode Configuration**

| Bit Field             | Register                     | Value  | Comments                                                                                                          |
|-----------------------|------------------------------|--------|-------------------------------------------------------------------------------------------------------------------|
| STARTENGINE           | GPMC_PREFETCH_CONTROL[0]     | 0      | Prefetch engine can be configured only if STARTENGINE is set to 0.                                                |
| ENGINECSSELECTOR      | GPMC_PREFETCH_CONFIG1[26-24] | 0 to 3 | Selects the chip-select associated with a NAND device where the prefetch engine is active.                        |
| ACCESSIONMODE         | GPMC_PREFETCH_CONFIG1[0]     | 0      | Selects prefetch mode                                                                                             |
| FIFOTHRESHOLD         | GPMC_PREFETCH_CONFIG1[14-8]  |        | Selects the maximum number of bytes read or written by the host on DMA or interrupt request                       |
| TRANSFERCOUNT         | GPMC_PREFETCH_CONFIG2[13-0]  |        | Selects the number of bytes to be read or written by the engine to the selected chip-select                       |
| SYNCHROMODE           | GPMC_PREFETCH_CONFIG1[3]     | 0/1    | Selects when the engine starts the access to the chip-select                                                      |
| WAITPINSELECT         | GPMC_PREFETCH_CONFIG1[17-16] | 0 to 1 | Selects WAIT pin edge detector (if GPMC_PREFETCH_CONFIG1[3] SYNCHROMODE = 0x1)                                    |
| ENABLEOPTIMIZEDACCESS | GPMC_PREFETCH_CONFIG1[27]    | 0/1    | See <a href="#">Section 12.4.3.4.11.4.6, Optimizing NAND Access Using the Prefetch and Write-Posting Engine</a> . |
| CYCLEOPTIMIZATION     | GPMC_PREFETCH_CONFIG1[30-28] |        | Number of clock cycle removed to timing parameters                                                                |
| ENABLEENGINE          | GPMC_PREFETCH_CONFIG1[7]     | 1      | Engine enabled                                                                                                    |
| STARTENGINE           | GPMC_PREFETCH_CONTROL[0]     | 1      | Starts the prefetch engine                                                                                        |

#### 12.4.3.4.11.4.3 FIFO Control in Prefetch Mode

##### Note

Some of the GPMC features described in this section may not be supported on this family of devices. For more information, see *GPMC Not Supported Features*.

The FIFO can be drained directly by a device host processor or a DMA module channel.

In draining mode, the FIFO status can be monitored through the GPMC\_PREFETCH\_STATUS[30-24] FIFOPOINTER bit field or through the GPMC\_PREFETCH\_STATUS[16] FIFOTHRESHOLDSTATUS bit. The FIFOPOINTER indicates the current number of available data to be read; FIFOTHRESHOLDSTATUS set to 1 indicates that at least FIFOTHRESHOLD bytes are available from the FIFO.

An interrupt can be triggered by the GPMC if the GPMC\_IRQENABLE[0] FIFOEVENTENABLE bit is set. The FIFO interrupt event is logged, and the GPMC\_IRQSTATUS[0] FIFOEVENTSTATUS bit is set. To clear the interrupt, all the available bytes must be read, or at least enough bytes to get below the programmed FIFO threshold, and the FIFOEVENTSTATUS bit must be cleared to enable further interrupt events. The FIFOEVENTSTATUS bit must always be reset before asserting the FIFOEVENTENABLE bit to clear any out-of-date logged interrupt event. This interrupt generation must be enabled after enabling the STARTENGINE bit.

Prefetch completion can be monitored through the GPMC\_PREFETCH\_STATUS[13-0] COUNTVALUE bit field. COUNTVALUE indicates the number of currently remaining data to be requested according to the TRANSFERCOUNT value. An interrupt can be triggered by the GPMC when the prefetch process is complete (that is, COUNTVALUE equals 0) if the GPMC\_IRQENABLE[1] TERMINALCOUNTEVENTENABLE bit is set. At prefetch completion, the TERMINALCOUNT interrupt event is also logged, and the GPMC\_IRQSTATUS[1] TERMINALCOUNTSTATUS bit is set. To clear the interrupt, the TERMINALCOUNTSTATUS bit must

be cleared. The TERMINALCOUNTSTATUS bit must always be cleared prior to asserting the TERMINALCOUNTEVENTENABLE bit to clear any out-of-date logged interrupt event.

---

**Note**

The COUNTVALUE value is valid only when the prefetch engine is active (started), and an interrupt is only triggered when COUNTVALUE reaches 0, that is, when the prefetch engine automatically goes from an active to an inactive state.

---

The number of bytes to be prefetched (programmed in TRANSFERCOUNT) must be a multiple of the programmed FIFOTHRESHOLD to trigger the correct number of interrupts allowing a deterministic and transparent FIFO control. If this guideline is respected, the number of ISR accesses is always required and the FIFO is always empty after the last interrupt is triggered. In other cases, the TERMINALCOUNT interrupt must be used to read the remaining bytes in the FIFO (the number of remaining bytes being lower than the FIFOTHRESHOLD value).

In DMA draining mode, the GPMC\_PREFETCH\_CONFIG1[2] DMAMODE bit must be set so that the GPMC issues a DMA hardware request when at least FIFOTHRESHOLD bytes are ready to be read from the FIFO. The DMA channel that owns this DMA request must be programmed so that the number of bytes programmed in FIFOTHRESHOLD is read from the FIFO during the DMA request process. The DMA request is kept active until this number of bytes has effectively been read from the FIFO, and no other DMA request can be issued until the ongoing active request is complete.

In prefetch mode, the TERMINALCOUNT event is also a source of DMA requests if the number of bytes to be prefetched is not a multiple of FIFOTHRESHOLD, the remaining bytes in the FIFO can be read by the DMA channel using the last DMA request. This assumes that the number of remaining bytes to be read is known and controlled through the DMA channel programming model.

Any potentially active DMA request is cleared when the prefetch engine goes from inactive-to-active prefetch (the STARTENGINE bit is set to 1). The associated DMA channel must always be enabled after setting the STARTENGINE bit so that the out-of-date active DMA request does not trigger spurious DMA transfers.

#### 12.4.3.4.11.4.4 Write-Posting Mode

The write-posting mode is selected when the *GPMC\_PREFETCH\_CONFIG1[0]* ACCESSMODE bit is set.

The NAND software driver must issue the correct address pointer initialization command (page program) before the engine can start writing data into the NAND memory device. The engine starts when the *GPMC\_PREFETCH\_CONTROL[0]* STARTENGINE bit is set to 1. The STARTENGINE bit clears automatically when posting completes. When all data have been written to the NAND memory device, the NAND software driver must issue the second cycle program command and monitor the status for programming process completion (adding ECC handling, if required).

If used, the ECC calculator engine must be started (configured, reset, and enabled) before the posting engine is started so that the ECC parities are calculated properly on all data written by the prefetch engine to the associated chip-select.

In write-posting mode, the *GPMC\_PREFETCH\_CONFIG1[3]* SYNCHROMODE bit must be cleared so that posting starts as soon as the STARTENGINE bit is set and the FIFO is not empty.

If the STARTENGINE bit is set after the NAND address phase (page program command), the STARTENGINE setting is effective only after the actual NAND command completion. To prevent GPMC stall during this NAND command phase, set the STARTENGINE bit field before the NAND address completion and ensure that the associated DMA channel is enabled after the NAND address phase.

The posting engine issues a write request when valid data are available from the FIFO and until the programmed *GPMC\_PREFETCH\_CONFIG2[13-0]* TRANSFERCOUNT accesses are complete.

The STARTENGINE bit clears automatically when posting completes. When all data have been written to the NAND memory device, the NAND software driver must issue the second cycle program command and monitor

the status for programming process completion. The closing program command phase must be issued only when the full NAND page has been written into the NAND flash write buffer, including the spare area data and the ECC parities, if used.

Table 12-205 describes the write-posting configuration.

**Table 12-205. Write-Posting Mode Configuration**

| Bit Field             | Register                     | Value  | Comments                                                                                                          |
|-----------------------|------------------------------|--------|-------------------------------------------------------------------------------------------------------------------|
| STARTENGINE           | GPMC_PREFETCH_CONTROL[0]     | 0      | Write-posting engine can be configured only if STARTENGINE is set to 0.                                           |
| ENGINECSSELECTOR      | GPMC_PREFETCH_CONFIG1[26-24] | 0 to 3 | Selects the chip-select associated with a NAND device where the prefetch engine is active                         |
| ACCESSMODE            | GPMC_PREFETCH_CONFIG1[0]     | 1      | Selects write-posting mode                                                                                        |
| FIFOTHRESHOLD         | GPMC_PREFETCH_CONFIG1[14-8]  |        | Selects the maximum number of bytes read or written by the host on DMA or interrupt request                       |
| TRANSFERCOUNT         | GPMC_PREFETCH_CONFIG2[13-0]  |        | Selects the number of bytes to be read or written by the engine from/to the selected chip-select                  |
| SYNCHROMODE           | GPMC_PREFETCH_CONFIG1[3]     | 0      | Engine starts the access to chip-select as soon as STARTENGINE is set.                                            |
| ENABLEOPTIMIZEDACCESS | GPMC_PREFETCH_CONFIG1[27]    | 0/1    | See <a href="#">Section 12.4.3.4.11.4.6, Optimizing NAND Access Using the Prefetch and Write-Posting Engine</a> . |
| CYCLEOPTIMIZATION     | GPMC_PREFETCH_CONFIG1[30-28] |        |                                                                                                                   |
| ENABLEENGINE          | GPMC_PREFETCH_CONFIG1[7]     | 1      | Engine enabled                                                                                                    |
| STARTENGINE           | GPMC_PREFETCH_CONTROL[0]     | 1      | Starts the prefetch engine                                                                                        |

#### 12.4.3.4.11.4.5 FIFO Control in Write-Posting Mode

##### Note

Some of the GPMC features described in this section may not be supported on this family of devices. For more information, see *GPMC Not Supported Features*.

The FIFO can be filled directly by a device host processor or a DMA module channel.

In filling mode, the FIFO status can be monitored through the FIFOPOINTER or through the GPMC\_PREFETCH\_STATUS[16] FIFOTHRESHOLDSTATUS bit. FIFOPOINTER indicates the current number of available free byte places in the FIFO, and the FIFOTHRESHOLDSTATUS bit, when set, indicates that at least FIFOTHRESHOLD free byte places are available in the FIFO.

An interrupt can be issued by the GPMC if the GPMC\_IRQENABLE[0] FIFOEVENTENABLE bit is set. When the interrupt is fired, the GPMC\_IRQSTATUS[0] FIFOEVENTSTATUS bit is set. To clear the interrupt, enough bytes must be written to fill the FIFO or to get below the programmed threshold, and the FIFOEVENTSTATUS bit must be cleared to get further interrupt events. The FIFOEVENTSTATUS bit must always be cleared before asserting the FIFOEVENTENABLE bit to clear any out-of-date logged interrupt event. This interrupt must be enabled after enabling the STARTENGINE bit.

The posting completion can be monitored through the GPMC\_PREFETCH\_STATUS[13-0] COUNTVALUE bit field. COUNTVALUE indicates the current number of remaining data to be written based on the value of the TRANSFERCOUNT bit field. An interrupt is issued by the GPMC when the write-posting process completes (that is, COUNTVALUE equal to 0) if the GPMC\_IRQENABLE[1] TERMINALCOUNTEVENTENABLE bit is set. When the interrupt is fired, the GPMC\_IRQSTATUS[1] TERMINALCOUNTSTATUS bit is set. To clear the interrupt, the TERMINALCOUNTSTATUS bit must be cleared. The TERMINALCOUNTSTATUS bit must always be cleared before asserting the TERMINALCOUNTEVENTENABLE bit to clear any out-of-date logged interrupt event.

---

**Note**

The value of the COUNTVALUE bit field is valid only if the write-posting engine is active and started, and an interrupt is issued only when COUNTVALUE reaches 0; that is, when the posting engine automatically goes from active to inactive.

In DMA filling mode, the DMAMode bit field in the GPMC\_PREFETCH\_CONFIG1[2] DMAMODE bit must be set so that the GPMC issues a DMA hardware request when at least FIFOTHRESHOLD bytes-free places are available in the FIFO. The DMA channel that owns this DMA request must be programmed so that a number of bytes equal to the value programmed in the FIFOTHRESHOLD bit field are written into the FIFO during the DMA access. The DMA request remains active until the associated number of bytes has effectively been written into the FIFO, and no other DMA request can be issued until the ongoing active request completes.

Any potentially active DMA request is cleared when the prefetch engine goes from inactive-to-active prefetch (STARTENGINE set to 1). The associated DMA channel must always be enabled after setting the STARTENGINE bit so that an out-of-date active DMA request does not trigger spurious DMA transfers.

In write-posting mode, DMA or CPU fills the FIFO with no consideration for the associated byte enables. Any byte stored in the FIFO is written into the memory device.

#### **12.4.3.4.11.4.6 Optimizing NAND Access Using the Prefetch and Write-Posting Engine**

Access time to a NAND memory device can be optimized for back-to-back accesses if the associated nCS signal is not deasserted between accesses. The GPMC access engine can track prefetch engine accesses to optimize the access timing parameter programmed for the allocated chip-select, if no accesses to other chip-selects (that is, interleaved accesses) occur. Similarly, the access engine also eliminates CYCLE2CYCLEDELAY even if CYCLE2CYCLESAMECSEN is set. This capability is limited to the prefetch and write-posting engine accesses, and accesses to a NAND memory device (through the defined chip-select memory region or through the GPMC\_NAND\_DATA\_i location, where  $i = 0$  to 3) are never optimized.

The GPMC\_PREFETCH\_CONFIG1[27] ENABLEOPTIMIZEDACCESS bit must be set to enable optimized accesses. To optimize access time, the GPMC\_PREFETCH\_CONFIG1[30-28] CYCLEOPTIMIZATION bit field defines the number of GPMC\_FCLK cycles to be suppressed from the following timing parameters:

- RDCYCLETIME
- WRCYCLETIME
- RDACCESSTIME
- WRACCESSTIME
- CSOFFTIME
- ADVOFFTIME
- OEOFETIME
- WEOFETIME

Figure 12-206 shows that in the case of back-to-back accesses to the NAND flash through the prefetch engine, CYCLE2CYCLESAMECSEN is forced to 0 when using optimized accesses. The first access uses the regular timing settings for this chip-select. All accesses after this one use settings reduced by  $x$  clock cycles,  $x$  being defined by the GPMC\_PREFETCH\_CONFIG1[30-28] CYCLEOPTIMIZATION bit field.



**Figure 12-206. NAND Read Cycle Optimization Timing Description**

#### 12.4.3.4.11.4.7 Interleaved Accesses Between Prefetch and Write-Posting Engine and Other Chip-Selects

Any on-going read or write access from the prefetch and write-posting engine is completed before an access to any other chip-select can be initiated. As a default, the arbiter uses a fixed-priority algorithm, and the prefetch and write-posting engine has the lowest priority. The maximum latency added to access starting time in this case equals the RDCYCLETIME or WRCYCLETIME (optimized or not) plus the requested BUSTURNAROUND delay for bus turnaround completion programmed for the chip-select to which the NAND device is connected.

Alternatively, a round-robin arbitration can be used to prioritize accesses to the external bus. This arbitration scheme is enabled by setting the *GPMC\_PREFETCH\_CONFIG1[23]* PFPWENROUNDROBIN bit. When a request to another chip-select is received while the prefetch and write-posting engine is active, priority is given to the new request. The request processed thereafter is the prefetch and write-posting engine request, even if another interconnect request is passed in the mean time. The engine keeps control of the bus for an additional number of requests programmed in the *GPMC\_PREFETCH\_CONFIG1[19:16]* PFPWWEIGHTEDPRIO bit field. Control is then passed to the direct interconnect request.

As an example, the round-robin arbitration scheme is selected with PFPWWEIGHTEDPRIO set to 0x2. Considering that the prefetch and write-posting engine and the interconnect interface are always requesting access to the external interface, the GPMC grants priority to the direct interconnect access for one request. The GPMC then grants priority to the engine for three requests, and finally back to the direct interconnect access, until the arbiter is reset when one of the two initiators stops initiating requests.

#### 12.4.3.4.12 GPMC Use Cases and Tips

##### 12.4.3.4.12.1 How to Set GPMC Timing Parameters for Typical Accesses

###### 12.4.3.4.12.1.1 External Memory Attached to the GPMC Module

As discussed in the introduction to this chapter, the GPMC module supports the following external memory types:

- Asynchronous or synchronous, 8- or 16-bit-wide memory or device
- 16-bit address/data-multiplexed or non-multiplexed NOR flash device
- 8- or 16-bit NAND flash device

The following examples describe how to calculate GPMC timing parameters by showing a typical parameter setup for the access to be performed.

The example is based on a 512-Mb multiplexed NOR flash memory with the following characteristics:

- Type: NOR flash (address/data-multiplexed mode)
- Size: 512M bits
- Data Bus: 16 bits wide
- Speed: 104-MHz clock frequency
- Read access time: 80 ns

###### 12.4.3.4.12.1.2 Typical GPMC Setup

Table 12-206 lists some of the I/Os of the GPMC module.

**Table 12-206. Typical GPMC Setup Signals**

| Module Pin      | I/O <sup>(1)</sup> | Description                                                                          |
|-----------------|--------------------|--------------------------------------------------------------------------------------|
| GPMC0_FCLK      | Internal           | Functional clock. Acts as the time reference.                                        |
| GPMC0_ICLK      | Internal           | Interface clock. Acts as the time reference.                                         |
| GPMC0_CLKOUT    | O                  | External clock provided to the external device for synchronous operations            |
| GPMC0_A[21-16]  | O                  | Address                                                                              |
| GPMC0_AD[15-0]  | I/O                | Data-multiplexed with addresses A[16-1] on memory side                               |
| GPMC0_CSn[3-0]  | O                  | Chip-selects                                                                         |
| GPMC0_ADVn_ALE  | O                  | Address valid enable                                                                 |
| GPMC0_OEn_REn   | O                  | Output enable (read access only)                                                     |
| GPMC0_WEn       | O                  | Write enable (write access only)                                                     |
| GPMC0_WAIT[1-0] | I                  | Ready signal from memory device. Indicates when valid burst data is ready to be read |

(1) I = Input; O = Output

Figure 12-207 shows the typical connection between the GPMC module and an attached NOR Flash memory.



**Figure 12-207. GPMC Connection to an External NOR Flash Memory**

The following sections demonstrate how to calculate GPMC parameters for three access types:

- Synchronous burst read
- Asynchronous read
- Asynchronous single write

#### 12.4.3.4.12.1.2.1 GPMC Configuration for Synchronous Burst Read Access

##### Note

The examples in [Section 12.4.3.4.12.1.2.1](#) through [Section 12.4.3.4.12.1.2.3](#) are based on a clock rate of 104 MHz. See the device-specific Datasheet for the maximum frequency appropriate for this device and the memory datasheet for the maximum frequency for the particular memory device.

The clock runs at 104 MHz ( $f = 104$  MHz;  $T = 9.615$  ns).

[Table 12-207](#) shows the timing parameters (on the memory side) that determine the parameters on the GPMC side.

[Table 12-208](#) shows how to calculate timings for the GPMC using the memory parameters.

[Figure 12-208](#) shows the synchronous burst read access.

**Table 12-207. Useful Timing Parameters on the Memory Side**

| AC Read Characteristics on the Memory Side | Description                                   | Duration (ns) |
|--------------------------------------------|-----------------------------------------------|---------------|
| tCES                                       | nCS setup time to clock                       | 0             |
| tAACS                                      | Address setup time to clock                   | 3             |
| tiACC                                      | Synchronous access time                       | 80            |
| tBACC                                      | Burst access time valid clock to output delay | 5.2           |

**Table 12-207. Useful Timing Parameters on the Memory Side (continued)**

| AC Read Characteristics on the Memory Side | Description                  | Duration (ns) |
|--------------------------------------------|------------------------------|---------------|
| tCEZ                                       | Chip-select to High-Z        | 7             |
| tOEZ                                       | Output enable to High-Z      | 7             |
| tAVC                                       | nADV setup time              | 6             |
| tAVD                                       | nADV pulse                   | 6             |
| tAHC                                       | Address hold time from clock | 3             |

The following terms, which describe the timing interface between the controller and its attached device, are used to calculate the timing parameters on the GPMC side:

- Read access time (GPMC side): Time required to activate the clock + read access time requested on the memory side + data setup time required for optimal capture of a burst of data
- Data setup time (GPMC side): Ensures a good capture of a burst of data (as opposed to taking a burst of data out). One word of data is processed in one clock cycle ( $T = 9.615$  ns). The read access time between two bursts of data is  $tBACC = 5.2$  ns. Therefore, data setup time is a clock period –  $tBACC = 4.415$  ns of data setup.
- Access completion (GPMC side): (Different from page burst access time) Time required between the last burst access and access completion: nCS/nOE hold time (nCS and nOE must be released at the end of an access. These signals are held to allow the access to complete).
- Read cycle time (GPMC side): Read access time + access completion
- Write cycle time for burst access: Not supported for NOR flash memory

**Table 12-208. Calculating GPMC Timing Parameters**

| Parameter Name on GPMC Side | Formula                                                           | Duration (ns)               | Number of Clock Cycles (F = 104 MHz) | GPMC Register Configurations |
|-----------------------------|-------------------------------------------------------------------|-----------------------------|--------------------------------------|------------------------------|
| GPMC FCLK Divider           | –                                                                 | –                           | –                                    | GPMCFCLKDIVIDER = 0x0        |
| ClkActivation Time          | min (tCES, tACS)                                                  | 3                           | 1                                    | CLKACTIVATIONTIME = 0x1      |
| RdAccessTime                | roundmax (ClkActivationTime + tIACC + DataSetupTime)              | 94.03: (9.615 + 80 + 4.415) | 10: roundmax (94.03 / 9.615)         | RDACCESSTIME = 0xA           |
| PageBurst RdAccessTime      | roundmax (tBACC)                                                  | roundmax (5.2)              | 1                                    | PAGEBURSTACCESSTIME = 0x1    |
| RdCycleTime                 | RdAccess time + max (tCEZ, tOEZ)                                  | 101.03: (94.03 + 7)         | 11                                   | RDCYCLETIME = 0xB            |
| CsOnTime                    | tCES                                                              | 0                           | 0                                    | CSONTIME = 0x0               |
| CsReadOffTime               | RdCycleTime                                                       | –                           | 11                                   | CSRDOFFTIME = 0xB            |
| AdvOnTime                   | tAVC <sup>(1)</sup>                                               | 0                           | 0                                    | ADVONTIME = 0x0              |
| AdvRdOffTime                | tAVD + tAVC <sup>(2)</sup>                                        | 12                          | 2                                    | ADVRDOFFTIME = 0x2           |
| OeOnTime <sup>(3)</sup>     | (ClkActivationTime + tAHC) < OeOnTime (ClkActivationTime + tIACC) | –                           | 3, for instance                      | OEONTIME = 0x3               |
| OeOffTime                   | RdCycleTime                                                       | –                           | 11                                   | OEOFETIME = 0xB              |

(1) The external clock provided to the NOR flash is not yet available.

(2) AdvRdOffTime – AdvOnTime = tAVD; thus, AdvRdOffTime = tAVD + AdvOnTime = tAVD + tAVC.

(3) OeOnTime must ensure that addresses are available. It must not exceed the availability of the first burst of data.



**Figure 12-208. Synchronous Burst Read Access (Timing Parameters in Clock Cycles)**

#### 12.4.3.4.12.1.2.2 GPMC Configuration for Asynchronous Read Access

The clock runs at 104 MHz ( $f = 104$  MHz;  $T = 9.615$  ns).

Table 12-209 shows the timing parameters (on the memory side) that determine the parameters on the GPMC side.

Table 12-210 shows how to calculate timings for the GPMC using the memory parameters.

Figure 12-209 shows the asynchronous read access.

**Table 12-209. AC Characteristics for Asynchronous Read Access**

| AC Read Characteristics on the Memory Side | Description                               | Duration (ns) |
|--------------------------------------------|-------------------------------------------|---------------|
| tCE                                        | Read Access time from nCS low             | 80            |
| tAAVDS                                     | Address setup time to rising edge of nADV | 3             |
| tAVDP                                      | nADV low time                             | 6             |
| tCAS                                       | nCS setup time to nADV                    | 0             |
| tOE                                        | Output enable to output valid             | 6             |
| tOEZ                                       | Output enable to High-Z                   | 7             |

Use the following formula to calculate the RdCycleTime parameter for this typical access:

$$\text{RdCycleTime} = \text{RdAccessTime} + \text{AccessCompletion} = \text{RdAccessTime} + 1 \text{ clock cycle} + \text{tOEZ}$$

1. On the memory side, the external memory makes the data available to the output bus. This is the memory-side read access time defined in Table 12-209: the number of clock cycles between the address capture (nADV rising edge) and the data valid on the output bus.

The GPMC requires some hold time to allow the data to be captured correctly and the access to be finished.

2. To read the data correctly, the GPMC must be configured to meet the data setup time requirement of the memory; the GPMC module captures the data on the next rising edge. This is access time on the GPMC side.
3. There must also be a data hold time for correctly reading the data (checking that there is no nOE/nCS deassertion while reading the data). This data hold time is one clock cycle (that is, RdAccessTime + 1).
4. To complete the access, nOE/nCS signals are driven to High-Z. RdAccessTime + 1 + tOEZ is the read cycle time.

5. Addresses can now be relatched and a new read cycle begun.

**Table 12-210. GPMC Timing Parameters for Asynchronous Read Access**

| Parameter Name<br>on GPMC Side | Formula                                            | Duration (ns) | Number of<br>Clock Cycles<br>( $F = 104$ MHz) | GPMC Register<br>Configurations |
|--------------------------------|----------------------------------------------------|---------------|-----------------------------------------------|---------------------------------|
| ClkActivationTime              | n/a (asynchronous mode)                            |               |                                               |                                 |
| RdAccessTime                   | round max (tCE)                                    | 80            | 10                                            | RDACCESSTIME = 0xA              |
| PageBurstAccessTi<br>me        | N/A (single access)                                |               |                                               |                                 |
| RdCycleTime                    | RdAccessTime + 1cycle + tOEZ                       | 96.615        | 12                                            | RDCYCLETIME = 0xC               |
| CsOnTime                       | tCAS                                               | 0             | 0                                             | CSONTIME = 0x0                  |
| CsReadOffTime                  | RdAccessTime + 1 cycle                             | 89.615        | 11                                            | CSRDOFFTIME = 0xB               |
| AdvOnTime                      | tAAVDS                                             | 3             | 1                                             | ADVONTIME = 0x1                 |
| AdvRdOffTime                   | tAAVDS + tAVDP                                     | 9             | 1                                             | ADVRDOFFTIME = 0x1              |
| OeOnTime                       | OeOnTime $\geq$ AdvRdOffTime<br>(multiplexed mode) | -             | 3, for instance                               | OEONTIME = 0x3                  |
| OeOffTime                      | RdAccessTime + 1cycle                              | 89.615        | 11                                            | OEOFETIME = 0xB                 |



**Figure 12-209. Asynchronous Single Read Access (Timing Parameters in Clock Cycles)**

#### 12.4.3.4.12.1.2.3 GPMC Configuration for Asynchronous Single Write Access

The clock runs at 104 MHz: ( $f = 104$  MHz;  $T = 9.615$  ns).

Table 12-212 shows how to calculate timings for the GPMC using the memory parameters.

Table 12-211 shows the timing parameters (on the memory side) that determine the parameters on the GPMC side.

Figure 12-210 shows the synchronous burst write access.

**Table 12-211. AC Characteristics for Asynchronous Single Write (Memory Side)**

| AC Characteristics on the Memory Side | Description            | Duration (ns) |
|---------------------------------------|------------------------|---------------|
| tWC                                   | Write cycle time       | 60            |
| tAVDP                                 | nADV low time          | 6             |
| tWP                                   | Write pulse width      | 25            |
| tWPH                                  | Write pulse width high | 20            |

**Table 12-211. AC Characteristics for Asynchronous Single Write (Memory Side) (continued)**

| AC Characteristics on the Memory Side | Description            | Duration (ns) |
|---------------------------------------|------------------------|---------------|
| tCS                                   | nCS setup time to nWE  | 3             |
| tCAS                                  | nCS setup time to nADV | 0             |
| tAVSC                                 | nADV setup time        | 3             |

For asynchronous single write access, write cycle time is  $WrCycleTime = WeOffTime + AccessCompletion = WeOffTime + 1$ . For the AccessCompletion, the GPMC requires one cycle of data hold time (nCS deassertion). For more information, see the device-specific Datasheet.

**Table 12-212. GPMC Timing Parameters for Asynchronous Single Write**

| Parameter Name on GPMC Side | Formula                      | Duration (ns)                                                                | Number of Clock Cycles (F = 104 MHz) | GPMC Registers Configuration |
|-----------------------------|------------------------------|------------------------------------------------------------------------------|--------------------------------------|------------------------------|
| ClkActivationTime           |                              | N/A (asynchronous mode)                                                      |                                      |                              |
| WdAccessTime                |                              | Applicable only to WAITMONITORING (the value is the same as for read access) |                                      |                              |
| PageBurstAccessTime         |                              | N/A (single access)                                                          |                                      |                              |
| WrCycleTime                 | WeOffTime + AccessCompletion | 57.615                                                                       | 6                                    | WRCYCLETIME = 0x6            |
| CsOnTime                    | tCAS                         | 0                                                                            | 0                                    | CSONTIME = 0x0               |
| CsWrOffTime                 | WeOffTime + 1                | 57.615                                                                       | 6                                    | CSWROFFTIME = 0x6            |
| AdvOnTime                   | tAVSC                        | 3                                                                            | 1                                    | ADVONTIME = 0x1              |
| AdvWrOffTime                | tAVSC + tAVDP                | 9                                                                            | 1                                    | ADVWROFFTIME = 0x1           |
| WeOnTime                    | tCS                          | 3                                                                            | 1                                    | WEONTIME = 0x1               |
| WeOffTime                   | tCS + tWP + tWPH             | 48                                                                           | 5                                    | WEOFETIME = 0x5              |



gpmc-040

**Figure 12-210. Asynchronous Single Write Access (Timing Parameters in Clock Cycles)**

#### 12.4.3.4.12.2 How to Choose a Suitable Memory to Use With the GPMC

This section is intended to help the user select a suitable memory device to interface with the GPMC controller.

#### 12.4.3.4.12.2.1 Supported Memories or Devices

NAND flash and NOR flash architectures are the two flash technologies. The GPMC supports various types of external memory or devices, basically any one that supports NAND or NOR protocols:

- 8- and 16-bit-wide asynchronous or synchronous memory or device (only 8-bit: nonburst device)
- 16-bit address and data-multiplexed NOR flash devices (pSRAM, and so on)
- 8- and 16-bit NAND flash devices

#### 12.4.3.4.12.2.1.1 Memory Pin Multiplexing

This section describes the interfacing differences of the GPMC supported memories.

**Table 12-213. Supported Memory Interfaces**

| Function    | 16-Bit Address/<br>Data-Multiplexed<br>pSRAM or NOR Flash <sup>(1)</sup> | 16-Bit NAND | 8-Bit NAND |
|-------------|--------------------------------------------------------------------------|-------------|------------|
| GPMC_A[22]  |                                                                          |             |            |
| GPMC_A[21]  |                                                                          |             |            |
| GPMC_A[20]  |                                                                          |             |            |
| GPMC_A[19]  |                                                                          |             |            |
| GPMC_A[18]  |                                                                          |             |            |
| GPMC_A[17]  |                                                                          |             |            |
| GPMC_A[16]  |                                                                          |             |            |
| GPMC_A[15]  |                                                                          |             |            |
| GPMC_A[14]  |                                                                          |             |            |
| GPMC_A[13]  |                                                                          |             |            |
| GPMC_A[12]  |                                                                          |             |            |
| GPMC_A[11]  |                                                                          |             |            |
| GPMC_A[10]  | A26                                                                      |             |            |
| GPMC_A[9]   | A25                                                                      |             |            |
| GPMC_A[8]   | A24                                                                      |             |            |
| GPMC_A[7]   | A23                                                                      |             |            |
| GPMC_A[6]   | A22                                                                      |             |            |
| GPMC_A[5]   | A21                                                                      |             |            |
| GPMC_A[4]   | A20                                                                      |             |            |
| GPMC_A[3]   | A19                                                                      |             |            |
| GPMC_A[2]   | A18                                                                      |             |            |
| GPMC_A[1]   | A17                                                                      |             |            |
| GPMC_A[0]   | A16                                                                      |             |            |
| GPMC_AD[15] | D15 or A16                                                               | IO15        |            |
| GPMC_AD[14] | D14 or A15                                                               | IO14        |            |
| GPMC_AD[13] | D13 or A14                                                               | IO13        |            |
| GPMC_AD[12] | D12 or A13                                                               | IO12        |            |
| GPMC_AD[11] | D11 or A12                                                               | IO11        |            |
| GPMC_AD[10] | D10 or A11                                                               | IO10        |            |
| GPMC_AD[9]  | D9 or A10                                                                | IO9         |            |
| GPMC_AD[8]  | D8 or A9                                                                 | IO8         |            |
| GPMC_AD[7]  | D7 or A8                                                                 | IO7         |            |
| GPMC_AD[6]  | D6 or A7                                                                 | IO6         |            |
| GPMC_AD[5]  | D5 or A6                                                                 | IO5         |            |
| GPMC_AD[4]  | D4 or A5                                                                 | IO4         |            |

**Table 12-213. Supported Memory Interfaces (continued)**

| Function      | 16-Bit Address/<br>Data-Multiplexed<br>pSRAM or NOR Flash <sup>(1)</sup> | 16-Bit NAND | 8-Bit NAND                 |
|---------------|--------------------------------------------------------------------------|-------------|----------------------------|
| GPMC_AD[3]    | D3 or A4                                                                 |             | IO3                        |
| GPMC_AD[2]    | D2 or A3                                                                 |             | IO2                        |
| GPMC_AD[1]    | D1 or A2                                                                 |             | IO1                        |
| GPMC_AD[0]    | D0 or A1                                                                 |             | IO0                        |
| GPMC_CLKOUT   | CLK                                                                      |             |                            |
| GPMC_CSn0     | nCS0 (chip-select)                                                       |             | nCE0 (chip-enable)         |
| GPMC_CSn1     | nCS1                                                                     |             | nCE1                       |
| GPMC_CSn2     | nCS2                                                                     |             | nCE2                       |
| GPMC_CSn3     | nCS3                                                                     |             | nCE3                       |
| GPMC_ADVn_ALE | nADV (address valid)                                                     |             | ALE (address latch enable) |
| GPMC_OEn_REn  | nOE (output enable)                                                      |             | nRE (read enable)          |
| GPMC_WEn      | nWE (Write enable)                                                       |             | nWE (write enable)         |
| GPMC_BE0n_CLE | nBE0 (byte enable)                                                       |             | CLE (command latch enable) |
| GPMC_BE1n     | nBE1                                                                     |             |                            |
| GPMC_WAIT0    | WAIT0                                                                    |             | R/nB0 (ready/busy)         |
| GPMC_WAIT1    | WAIT1                                                                    |             | R/nB1                      |
| GPMC_WPn      | nWP (Write Protect)                                                      |             | nWP (Write Protect)        |

(1) Addresses seen from the device side. When interfacing to the external device, A1 is connected to the memory A0, A2 to the memory A1, and so on.

#### 12.4.3.4.12.2.1.2 NAND Interface Protocol

NAND flash architecture, introduced in 1989, is a flash technology. NAND is a page-oriented memory device; that is, read and write accesses are done by pages. NAND achieves great density by sharing common areas of the storage transistor, which creates strings of serially connected transistors (in NOR devices, each transistor stands alone). Because of its high density NAND is best suited to devices that require high capacity data storage, such as pictures, music, and data files. NAND nonvolatility makes of it a good storage solution for many applications where mobility, low power, and speed are key factors. Low pin count and simple interface are other advantages of NAND.

Table 12-214 summarizes the NAND interface signals level applied to external device or memories.

**Table 12-214. NAND Interface Bus Operations Summary**

| Bus Operation         | CLE | ALE | nCE              | nWE <sup>(1)</sup> | nRE <sup>(1)</sup> | nWP |
|-----------------------|-----|-----|------------------|--------------------|--------------------|-----|
| Read (cmd input)      | H   | L   | L                | RE                 | H                  | x   |
| Read (add input)      | L   | H   | L                | RE                 | H                  | x   |
| Write (cmd input)     | H   | L   | L                | RE                 | H                  | H   |
| Write (add input)     | L   | H   | L                | RE                 | H                  | H   |
| Data input            | L   | L   | L                | RE                 | H                  | H   |
| Data output           | L   | L   | L                | H                  | FE                 | x   |
| Busy (during read)    | x   | x   | H <sup>(2)</sup> | H <sup>(2)</sup>   | H <sup>(2)</sup>   | x   |
| Busy (during program) | x   | x   | x                | x                  | x                  | H   |
| Busy (during erase)   | x   | x   | x                | x                  | x                  | H   |
| Write protect         | x   | x   | x                | x                  | x                  | L   |
| Standby               | x   | x   | H                | x                  | x                  | H/L |

(1) RE stands for rising edge; FE stands for falling edge

(2) Can be nCE high, or WE and nRE high.

#### 12.4.3.4.12.2.1.3 NOR Interface Protocol

NOR flash architecture, introduced in 1988, is a flash technology. Unlike NAND, which is a sequential access device, NOR is directly addressable; that is, it is designed to be a random access device. NOR is best suited to devices used to store and run code or firmware, usually in small capacities. While NOR has fast read capabilities, it also has slow write and erase functions when compared to the NAND architecture.

Table 12-215 summarizes the level of the NOR interface signals applied to external devices or memories.

**Table 12-215. NOR Interface Bus Operations Summary**

| Bus Operation        | CLK     | nADV | nCS | nOE | nWE | WAIT     | DQ[15-0] |
|----------------------|---------|------|-----|-----|-----|----------|----------|
| Read (asynchronous)  | x       | L    | L   | L   | H   | Asserted | Output   |
| Read (synchronous)   | Running | L    | L   | L   | H   | Driven   | Output   |
| Read (burst suspend) | Halted  | x    | L   | H   | H   | Active   | Output   |
| Write                | x       | L    | L   | H   | L   | Asserted | Input    |
| Output disable       | x       | x    | L   | H   | H   | Asserted | High-Z   |
| Standby              | x       | x    | H   | x   | x   | High-Z   | High-Z   |

#### 12.4.3.4.12.2.1.4 Other Technologies

Other supported device types interact with the GPMC through the NOR interface protocol.

FPGA (Field-Programmable Gate Array) is a low-power integrated circuit based on an array of programmable logic blocks.

pSRAM (pseudo-static random access memory) is a low-power memory device. pSRAM is based on the DRAM cell with internal refresh and address control features, and interfaces as a synchronous NOR flash. It has synchronous write capability.

**12.4.3.5 GPMC Basic Programming Model****12.4.3.5.1 GPMC High-Level Programming Model Overview**

The goal of the basic high-level programming model is to introduce a top-down approach to users that need to configure the GPMC module.

**Figure 12-211** and **Table 12-216** through **Table 12-217** show a programming model top-level diagram for the GPMC, and a description of each step. Each block of the diagram is described in one of the following sections through a set of registers to configure.



gpmc-uc-001

Figure 12-211. Programming Model Top-Level Diagram

Table 12-216. GPMC Configuration in NOR Mode

| Step            | Description                        |
|-----------------|------------------------------------|
| NOR Memory Type | See <a href="#">Table 12-218</a> . |

**Table 12-216. GPMC Configuration in NOR Mode (continued)**

| Step                          | Description                        |
|-------------------------------|------------------------------------|
| NOR Chip-Select Configuration | See <a href="#">Table 12-219</a> . |
| NOR Timings Configuration     | See <a href="#">Table 12-220</a> . |
| WAIT Pin Configuration        | See <a href="#">Table 12-228</a> . |
| Enable Chip-Select            | See <a href="#">Table 12-229</a> . |

**Table 12-217. GPMC Configuration in NAND Mode**

| Step                              | Description                        |
|-----------------------------------|------------------------------------|
| NAND Memory Type                  | See <a href="#">Table 12-223</a> . |
| NAND Chip-Select Configuration    | See <a href="#">Table 12-224</a> . |
| Write Operations (Asynchronous)   | See <a href="#">Table 12-225</a> . |
| Read Operations (Asynchronous)    | See <a href="#">Table 12-225</a> . |
| ECC Engine                        | See <a href="#">Table 12-226</a> . |
| Prefetch and Write-Posting Engine | See <a href="#">Table 12-227</a> . |
| WAIT Pin Configuration            | See <a href="#">Table 12-228</a> . |
| Enable Chip-Select                | See <a href="#">Table 12-229</a> . |

#### 12.4.3.5.2 GPMC Initialization

GPMC can be reset via software bit in LPSC. For more information, see [Reset](#).

#### 12.4.3.5.3 GPMC Configuration in NOR Mode

This section gives a generic configuration for parameters related to the NOR memory connected to the GPMC.

**Table 12-218. NOR Memory Type**

| Subprocess Name                                                      | Register / Bit Field                           | Value |
|----------------------------------------------------------------------|------------------------------------------------|-------|
| Set the NOR protocol.                                                | GPMC_CONFIG1_i[11-10] DEVICETYPE               | 0x0   |
| Set a device size.                                                   | GPMC_CONFIG1_i[13-12] DEVICESIZE               | x     |
| Select an address and data multiplexing protocol.                    | GPMC_CONFIG1_i[9] MUXADDDATA                   | x     |
| Set the attached device page length.                                 | GPMC_CONFIG1_i[24-23] ATTACHEDDEVICEPAGELength | x     |
| Set the wrapping burst capabilities.                                 | GPMC_CONFIG1_i[31] WRAPBURST                   | x     |
| Select a timing signals latencies factor.                            | GPMC_CONFIG1_i[4] TIMEPARAGRANULARITY          | x     |
| Select an output clock frequency <sup>(1)</sup> .                    | GPMC_CONFIG1_i[1-0] GPMCFCLKDIVIDER            | x     |
| Choose an output clock activation time <sup>(1)</sup> .              | GPMC_CONFIG1_i[26-25] CLKACTIVATIONTIME        | x     |
| Set a single or multiple access for read operations <sup>(1)</sup> . | GPMC_CONFIG1_i[30] READMULTIPLE                | x     |
| Set a synchronous or asynchronous mode for read operations.          | GPMC_CONFIG1_i[29] READTYPE                    | x     |
| Set a single or multiple access for write operations.                | GPMC_CONFIG1_i[28] WRITEMULTIPLE               | x     |
| Set a synchronous or asynchronous mode for write operations.         | GPMC_CONFIG1_i[27] WRITETYPE                   | x     |

(1) Applies only to synchronous configurations (or non-multiplexed asynchronous for multiple access one)

**Table 12-219. NOR Chip-Select Configuration**

| Subprocess Name                      | Register/Bit Field               | Value |
|--------------------------------------|----------------------------------|-------|
| Select the chip-select base address. | GPMC_CONFIG7_i[5-0] BASEADDRESS  | x     |
| Select the chip-select mask address. | GPMC_CONFIG7_i[11-8] MASKADDRESS | x     |

**Table 12-220. NOR Timings Configuration**

| Subprocess Name                                               | Register/Bit Field                | Value |
|---------------------------------------------------------------|-----------------------------------|-------|
| Configure adequate timing parameters in various memory modes. | See <i>GPMC Timing Parameters</i> |       |

**Table 12-221. WAIT Pin Configuration**

| Subprocess Name                                             | Register/Bit Field                       | Value |
|-------------------------------------------------------------|------------------------------------------|-------|
| Enable or disable WAIT pin monitoring for read operations.  | GPMC_CONFIG1_i[22] WAITREADMONITORING    | x     |
| Enable or disable WAIT pin monitoring for write operations. | GPMC_CONFIG1_i[21] WAITWRITEMONITORING   | x     |
| Select a WAIT pin monitoring time.                          | GPMC_CONFIG1_i[19-18] WAITMONITORINGTIME | x     |
| Choose the input WAIT pin for the chip-select.              | GPMC_CONFIG1_i[17-16] WAITPINSELECT      | x     |

**Table 12-222. Enable Chip-Select**

| Subprocess Name                                             | Register/Bit Field        | Value |
|-------------------------------------------------------------|---------------------------|-------|
| When all parameters are configured, enable the chip-select. | GPMC_CONFIG7_i[6] CSVALID | x     |

#### 12.4.3.5.4 GPMC Configuration in NAND Mode

This section gives a generic configuration for parameters related to the NAND memory connected to the GPMC.

##### Note

Some of the GPMC features described in this section may not be supported on this family of devices. For more information, see *GPMC Not Supported Features*.

**Table 12-223. NAND Memory Type**

| Subprocess Name                                                                                       | Register/Bit Field                                          | Value |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-------|
| Set the NAND protocol.                                                                                | GPMC_CONFIG1_i[11-10] DEVICETYPE                            | 0x2   |
| Set a device size.                                                                                    | GPMC_CONFIG1_i[13-12] DEVICESIZE                            | x     |
| Set the address and data multiplexing protocol to non-multiplexed attached device.                    | GPMC_CONFIG1_i[9] MUXADDDATA                                | 0x0   |
| Select a timing signals latencies factor.                                                             | GPMC_CONFIG1_i[4] TIMEPARAGRANULARITY                       | x     |
| Set a synchronous or asynchronous mode and a single or multiple access for read and write operations. | See <a href="#">Section 12.4.3.5.5, Set Memory Access</a> . | x     |

**Table 12-224. NAND Chip-Select Configuration**

| Subprocess Name                                    | Register/Bit Field               | Value |
|----------------------------------------------------|----------------------------------|-------|
| Select the chip-select base address.               | GPMC_CONFIG7_i[5-0] BASEADDRESS  | x     |
| Select the chip-select minimum granularity (16MB). | GPMC_CONFIG7_i[11-8] MASKADDRESS | x     |

**Table 12-225. Asynchronous Read and Write Operations**

| Subprocess Name                                             | Register/Bit Field                                               | Value |
|-------------------------------------------------------------|------------------------------------------------------------------|-------|
| Configure adequate timing parameters in asynchronous modes. | See <a href="#">Section 12.4.3.5.6, GPMC Timing Parameters</a> . |       |

**Table 12-226. ECC Engine**

| Subprocess Name                                                                                     | Register/Bit Field                                        | Value             |
|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-------------------|
| Select the ECC result register where the first ECC computation is stored (applies only to Hamming). | GPMC_ECC_CONTROL[3-0] ECCPOINTER                          | x <sup>(2)</sup>  |
| Clear all ECC result registers.                                                                     | GPMC_ECC_CONTROL[8] ECCCLEAR                              | Write 1 to clear. |
| Define ECCSIZE0 and ECCSIZE1.                                                                       | GPMC_ECC_SIZE_CONFIG[21-12] ECCSIZE0 and [31-22] ECCSIZE1 | x <sup>(1)</sup>  |
| Select the size of each of the 9 result registers (size specified by ECCSIZE0 or ECCSIZE1).         | GPMC_ECC_SIZE_CONFIG[j-1] ECCjRESULTSIZE where j = 1 to 9 | x                 |

**Table 12-226. ECC Engine (continued)**

| Subprocess Name                                                                                              | Register/Bit Field                                                                         | Value |
|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-------|
| Select the chip-select where ECC is computed.                                                                | <i>GPMC_ECC_CONTROL[3-1]</i> ECCCS                                                         | x     |
| Select the Hamming code or BCH code ECC algorithm in use.                                                    | <i>GPMC_ECC_CONTROL[16]</i> ECCALGORITHM                                                   | x     |
| Select word size for ECC calculation.                                                                        | <i>GPMC_ECC_CONTROL[7]</i> ECC16B                                                          | x     |
| If the BCH code is used,<br>Set an error correction capability and<br>Select a number of sectors to process. | <i>GPMC_ECC_CONTROL[13-12]</i> ECCBCHTSEL and<br><i>GPMC_ECC_CONTROL[6-4]</i> ECCTOPSECTOR | x     |
| Enable the ECC computation.                                                                                  | <i>GPMC_ECC_CONTROL[0]</i> ECCENABLE                                                       | 0x1   |

(1) Depends on the size of each sector in the NAND page

(2) This parameter depends on the numbers of sectors in a page.

**Table 12-227. Prefetch and Write-Posting Engine**

| Subprocess Name                                                                                                                                        | Register/Bit Field                                    | Value |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------|
| Disable the engine before configuration.                                                                                                               | <i>GPMC_PREFETCH_CONTROL[0]</i> STARTENGINE           | 0x0   |
| Select the chip-select associated with a NAND device where the prefetch engine is active.                                                              | <i>GPMC_PREFETCH_CONFIG1[26-24]</i> ENGINECSSELECTOR  | x     |
| Select access direction through prefetch engine, read or write.                                                                                        | <i>GPMC_PREFETCH_CONFIG1[0]</i> ACCESSMODE            | x     |
| Select the threshold used to issue an interrupt request.                                                                                               | <i>GPMC_PREFETCH_CONFIG1[14-8]</i> FIFOThreshold      | x     |
| Select interrupt synchronization mode.                                                                                                                 | <i>GPMC_PREFETCH_CONFIG1[2]</i> DMAMODE               | x     |
| Select if the engine immediately starts accessing the memory upon STARTENGINE assertion or if hardware synchronization based on a WAIT signal is used. | <i>GPMC_PREFETCH_CONFIG1[3]</i> SYNCHROMODE           | x     |
| Select which WAIT pin edge detector should start the engine in synchronized mode.                                                                      | <i>GPMC_PREFETCH_CONFIG1[5-4]</i> WAITPINSELECTOR     | x     |
| Enter a number of clock cycles removed to timing parameters (for all back-to-back accesses to the NAND flash except the first one).                    | <i>GPMC_PREFETCH_CONFIG1[30-28]</i> CYCLEOPTIMIZATION | x     |
| Enable the prefetch postwrite engine.                                                                                                                  | <i>GPMC_PREFETCH_CONFIG1[7]</i> ENABLEENGINE          | 0x1   |
| Select the number of bytes to be read or written by the engine to the selected chip-select.                                                            | <i>GPMC_PREFETCH_CONFIG2[13-0]</i> TRANSFERCOUNT      | x     |
| Start the prefetch engine.                                                                                                                             | <i>GPMC_PREFETCH_CONTROL[0]</i> STARTENGINE           | 0x1   |

**Table 12-228. WAIT Pin Configuration**

| Subprocess Name                                                                   | Register/Bit Field                                | Value |
|-----------------------------------------------------------------------------------|---------------------------------------------------|-------|
| Selects when the engine starts the access to chip-select.                         | <i>GPMC_PREFETCH_CONFIG1[3]</i> SYNCHROMODE       | x     |
| Select which WAIT pin edge detector should start the engine in synchronized mode. | <i>GPMC_PREFETCH_CONFIG1[5-4]</i> WAITPINSELECTOR | x     |

**Table 12-229. Enable Chip-Select**

| Subprocess Name                                             | Register/Bit Field             | Value |
|-------------------------------------------------------------|--------------------------------|-------|
| When all parameters are configured, enable the chip-select. | <i>GPMC_CONFIG7[6]</i> CSVALID | x     |

#### 12.4.3.5.5 Set Memory Access

##### Note

Some of the GPMC features described in this section may not be supported on this family of devices. For more information, see *GPMC Not Supported Features*.

This section describes the bit field to configure to set the GPMC in various memory modes. [Table 12-230](#) and [Table 12-231](#) provide check lists for mode parameters and access type parameters, respectively.

Table 12-230. Mode Parameters Check List

| Register       | Bit | Name          | Asynchronous       |                     |                             |                              | Synchronous        |                     |                              |                               |
|----------------|-----|---------------|--------------------|---------------------|-----------------------------|------------------------------|--------------------|---------------------|------------------------------|-------------------------------|
|                |     |               | Single Read Access | Single Write Access | Multiple Read (Page) Access | Multiple Write (Page) Access | Single Read Access | Single Write Access | Multiple Read (Burst) Access | Multiple Write (Burst) Access |
| GPMC_CONFIG1_i | 30  | READMULTIPLE  | 0x0                | Don't care          | 0x1 <sup>(1)</sup>          | Not Supported                | 0x0                | Don't care          | 0x1                          | Don't care                    |
| GPMC_CONFIG1_i | 29  | READTYPE      | 0x0                | Don't care          | 0x0 <sup>(1)</sup>          | Not Supported                | 0x1                | Don't care          | 0x1                          | Don't care                    |
| GPMC_CONFIG1_i | 28  | WRITEMULTIPLE | Don't care         | 0x0                 | - <sup>(1)</sup>            | Not Supported                | Don't care         | 0x0                 | Don't care                   | 0x1                           |
| GPMC_CONFIG1_i | 27  | WRITETYPE     | Don't care         | 0x0                 | - <sup>(1)</sup>            | Not Supported                | Don't care         | 0x1                 | Don't care                   | 0x1                           |

(1) Multiple read is not supported in address/data-multiplexed and AAD-multiplexed modes. Multiple read is supported in non-multiplexed mode.

Table 12-231. Access Type Parameters Check List

| Register       | Bit | Name       | Access Type     |                              |                 |
|----------------|-----|------------|-----------------|------------------------------|-----------------|
|                |     |            | non-multiplexed | Address/<br>Data-Multiplexed | AAD-Multiplexed |
| GPMC_CONFIG1_i | 9-8 | MUXADDDATA | 0x0             | 0x2                          | 0x1             |

#### 12.4.3.5.6 GPMC Timing Parameters

Figure 12-212 shows a programming model diagram for the NOR interfacing timing parameters.



gpmc-uc-002

**Figure 12-212. NOR Interfacing Timing Parameters Diagram**

Table 12-232 lists the bit fields to configure adequate timing parameters in various memory modes.

**Table 12-232. Timing Parameters**

| Register       | Bit | Name          | Asynchronous        |                      |                                | Synchronous         |                      |                                 | Access Type                      |                 |                          |                  |
|----------------|-----|---------------|---------------------|----------------------|--------------------------------|---------------------|----------------------|---------------------------------|----------------------------------|-----------------|--------------------------|------------------|
|                |     |               | Single Read Acces s | Single Write Acces s | Multipl e Read (Page ) acces s | Single Read Acces s | Single Write Acces s | Multipl e Read (Burst ) Acces s | Multipl e Write (Burst ) Acces s | Non-multiplexed | Address-Data-Multiplexed | AAD Multipl exed |
| GPMC_CONFIG1_i | 9   | MUXADDDATA    | y                   | y                    | y                              | y                   | y                    | y                               | y                                | y               | y                        | y                |
| GPMC_CONFIG1_i | 29  | READYTYPE     | y                   |                      | y                              | y                   |                      | y                               |                                  | y               | y                        | y                |
| GPMC_CONFIG1_i | 30  | READMULTIPLE  | y                   |                      | y                              | y                   |                      | y                               |                                  | y               | y                        | y                |
| GPMC_CONFIG1_i | 27  | WRITETYPE     |                     | y                    |                                |                     | y                    |                                 | y                                | y               | y                        | y                |
| GPMC_CONFIG1_i | 28  | WRITEMULTIPLE |                     | y                    |                                |                     | y                    |                                 | y                                | y               | y                        | y                |
| GPMC_CONFIG1_i | 31  | WRAPBURST     |                     |                      |                                |                     |                      | y                               | y                                | y               | y                        | y                |

Table 12-232. Timing Parameters (continued)

|                |           | Asynchronous        |   |   | Synchronous |   |   | Access Type |   |   |
|----------------|-----------|---------------------|---|---|-------------|---|---|-------------|---|---|
| GPMC_CONFIG1_i | 26-2<br>5 | CLKACTIVATIONTIME   |   |   | y           | y | y | y           | y | y |
| GPMC_CONFIG1_i | 19-1<br>8 | WAITMONITORINGTIME  | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG1_i | 4         | TIMEPARAGRANULARITY | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG2_i | 20-1<br>6 | CSWROFFTIME         |   | y |             |   | y |             | y | y |
| GPMC_CONFIG2_i | 12-8      | CSRDOFFTIME         | y |   | y           | y |   | y           | y | y |
| GPMC_CONFIG2_i | 7         | CSEXTRADELAY        | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG2_i | 3-0       | CSONTIME            | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG3_i | 30-2<br>8 | ADVAADMUXWROFFTIME  |   | y |             |   | y |             | y |   |
| GPMC_CONFIG3_i | 30-2<br>9 | ADVAADMUXRDOFFTIME  | y |   | y           | y |   | y           |   | y |
| GPMC_CONFIG3_i | 6-4       | ADVAADMUXONTIME     | y | y | y           | y | y | y           |   | y |
| GPMC_CONFIG3_i | 20-1<br>6 | ADVWROFFTIME        |   | y |             |   | y |             | y | y |
| GPMC_CONFIG3_i | 12-8      | ADVRDOFFTIME        | y |   | y           | y |   | y           | y | y |
| GPMC_CONFIG3_i | 7         | ADVEXTRADELAY       | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG3_i | 3-0       | ADVONTIME           | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG4_i | 15-1<br>3 | OEAADMUXOFFTIME     | y | y | y           | y | y | y           |   | y |
| GPMC_CONFIG4_i | 6-4       | OEAADMUXONTIME      | y | y | y           | y | y | y           |   | y |
| GPMC_CONFIG4_i | 28-2<br>4 | WEOFFTIME           |   | y |             |   | y |             | y | y |
| GPMC_CONFIG4_i | 23        | WEEXTRADELAY        |   | y |             |   | y |             | y | y |
| GPMC_CONFIG4_i | 19-1<br>6 | WEONTIME            |   | y |             |   | y |             | y | y |
| GPMC_CONFIG4_i | 12-8      | OEOFETIME           | y |   | y           | y |   | y           | y | y |
| GPMC_CONFIG4_i | 7         | OEEXTRADELAY        | y |   | y           | y |   | y           | y | y |
| GPMC_CONFIG4_i | 3-0       | OEONTIME            | y |   | y           | y |   | y           | y | y |
| GPMC_CONFIG5_i | 27-2<br>4 | PAGEBURSTACCESSTIME |   |   | y           |   |   | y           | y | y |
| GPMC_CONFIG5_i | 20-1<br>6 | RDACCESSTIME        | y |   | y           | y |   | y           | y | y |
| GPMC_CONFIG5_i | 12-8      | WRCYCLETIME         |   | y |             |   | y |             | y | y |
| GPMC_CONFIG5_i | 4-0       | RDCYCLETIME         | y |   | y           | y |   | y           | y | y |
| GPMC_CONFIG6_i | 28-2<br>4 | WRACCESSTIME        |   | y |             |   | y |             | y | y |
| GPMC_CONFIG6_i | 19-1<br>6 | WRDATAONADMUXBUS    |   | y |             |   | y |             | y | y |
| GPMC_CONFIG6_i | 11-8      | CYCLE2CYCLEDELAY    | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG6_i | 7         | CYCLE2CYCLESAMECSEN | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG6_i | 6         | CYCLE2CYCLEDIFFCSEN | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG6_i | 3-0       | BUSTURNAROUND       | y | y | y           | y | y | y           | y | y |
| GPMC_CONFIG7_i | 6         | CSVALID             | y | y | y           | y | y | y           | y | y |

#### 12.4.3.5.6.1 GPMC Timing Parameters Formulas

This section is intended to help the user calculate the GPMC timing bit field values. Formulas are not listed exhaustively.

The section describes:

- NAND flash interface timing parameters formulas
- Synchronous NOR flash timing parameters formulas
- Asynchronous NOR flash timing parameters formulas

For complete information, such as OPP and board effects on timings, see the device-specific Datasheet.

##### 12.4.3.5.6.1.1 NAND Flash Interface Timing Parameters Formulas

This section lists formulas to calculate NAND timing parameters. This is the case when GPMC\_CONFIG1\_i[11-10] DEVICETYPE = 0x2. [Table 12-233](#) describes the NAND timing parameters.

**Table 12-233. NAND Formulas Description**

| Configuration Parameter | Unit | Description                                                          |
|-------------------------|------|----------------------------------------------------------------------|
| A                       | ns   | Pulse duration – GPMC_WEn valid time                                 |
| B                       | ns   | Delay time – GPMC_CS valid to GPMC_WEn valid                         |
| C                       | ns   | Delay time – GPMC_BE0n_CLE/GPMC_ADVn_ALE high to GPMC_WEn valid      |
| D                       | ns   | Delay time – GPMC_AD[15-0] valid to GPMC_WEn valid                   |
| E                       | ns   | Delay time – GPMC_WEn invalid to GPMC_AD[15-0] invalid               |
| F                       | ns   | Delay time – GPMC_WEn invalid to GPMC_BE0n_CLE/GPMC_ADVn_ALE invalid |
| G                       | ns   | Delay time – GPMC_WEn invalid to GPMC_CS invalid                     |
| H                       | ns   | Cycle time – Write cycle time                                        |
| I                       | ns   | Delay time – GPMC_CS valid to GPMC_OEn_REn valid                     |
| J                       | ns   | Setup time – GPMC_AD[15-0] valid to GPMC_OEn_REn invalid             |
| K                       | ns   | Pulse duration – GPMC_OEn_REn valid time                             |
| L                       | ns   | Cycle time – Read cycle time                                         |
| M                       | ns   | Delay time – GPMC_OEn_REn invalid to GPMC_CS invalid                 |

The configuration parameters are calculated through the following formulas. For more information, see the device-specific Datasheet.

$$A = (WEOffTime - WEOOnTime) * (TimeParaGranularity + 1) * GPMC_FCLK \text{ period}$$

$$B = ((WEOOnTime - CSOnTime) * (TimeParaGranularity + 1) + 0.5 * (WEEExtraDelay - CSEExtraDelay)) * GPMC_FCLK \text{ period}$$

$$C = ((WEOnTime - ADVOnTime) * (TimeParaGranularity + 1) + 0.5 * (WEEExtraDelay - ADVExtraDelay)) * GPMC_FCLK \text{ period}$$

$$D = (WEOOnTime * (TimeParaGranularity + 1) + 0.5 * WEEExtraDelay) * GPMC_FCLK \text{ period}$$

$$E = (WrCycleTime - WEOOffTime * (TimeParaGranularity + 1) - 0.5 * WEEExtraDelay) * GPMC_FCLK \text{ period}$$

$$F = (ADVWrOffTime - WEOOffTime * (TimeParaGranularity + 1) + 0.5 * (ADVExtraDelay - WEEExtraDelay)) * GPMC_FCLK \text{ period}$$

$$G = (CSWrOffTime - WEOOffTime * (TimeParaGranularity + 1) + 0.5 * (CSEExtraDelay - WEEExtraDelay)) * GPMC_FCLK \text{ period}$$

$$H = WrCycleTime * (1 + TimeParaGranularity) * GPMC_FCLK \text{ period}$$

$$I = ((OEOnTime - CSOnTime) * (TimeParaGranularity + 1) + 0.5 * (OEEExtraDelay - CSEExtraDelay)) * GPMC_FCLK \text{ period}$$

$$J = ((RdAccessTime - OEOFFTime) * (TimeParaGranularity + 1) - 0.5 * OEEExtraDelay) * GPMC_FCLK \text{ period}$$

$$K = (OEOFFTime - OEOnTime) * (1 + TimeParaGranularity) * GPMC_FCLK \text{ period}$$

$$L = RdCycleTime * (1 + TimeParaGranularity) * GPMC_FCLK \text{ period}$$

$$M = (CSRdOffTime - OEOFFTime * (TimeParaGranularity + 1) + 0.5 * (CSEExtraDelay - OEEExtraDelay)) * GPMC_FCLK \text{ period}$$

[Figure 12-213](#) shows a simplified example of command latch cycle timing where formulas are associated with signal waves.



gpmc-048

**Figure 12-213. NAND Command Latch Cycle Timing Simplified Example**

#### 12.4.3.5.6.1.2 Synchronous NOR Flash Timing Parameters Formulas

This section lists all formulas to calculate synchronous NOR timing parameters. This is the case when *GPMC\_CONFIG1[11-10]* DEVICETYPE = 0x0 and when READTYPE or WRITETYPE are set to synchronous mode. [Table 12-234](#) describes the synchronous NOR formulas.

**Table 12-234. Synchronous NOR Formulas Description**

| Configuration Parameter | Unit | Description                                                         |
|-------------------------|------|---------------------------------------------------------------------|
| A                       | ns   | Pulse duration – nCS low                                            |
| B                       | ns   | Delay time – address bus valid to CLK first edge                    |
|                         |      | Delay time – nBE0 / nBE1 valid to CLK first edge                    |
| C                       | ns   | Pulse duration – nBE0 / nBE1 low                                    |
| D                       | ns   | Delay time – CLK rising edge to nBE0 / nBE1 invalid                 |
|                         |      | Delay time – CLK rising edge to nADV/ALE invalid                    |
| E                       | ns   | Delay time – CLK rising edge to nCS invalid                         |
|                         |      | Delay time – CLK rising edge to nOE/nRE invalid                     |
| F                       | ns   | Delay time – CLK rising edge to nCS transition                      |
| G                       | ns   | Delay time – CLK rising edge to nADV/ALE transition                 |
| H                       | ns   | Delay time – CLK rising edge to nOE/nRE transition                  |
| I                       | ns   | Delay time – CLK rising edge to nWE transition                      |
| J                       | ns   | Delay time – CLK rising edge to A[16-1]/D[15-0] data bus transition |
|                         |      | Delay time – CLK rising edge to nBE0 / nBE1 transition              |
| K                       | ns   | Pulse duration – nADV/ALE low                                       |
| L                       | ns   | Delay time – WAIT invalid to first data latching CLK edge           |

The configuration parameters are calculated through the following formulas. For more information, see the device-specific Datasheet.

1. For single read accesses:

$$A = (\text{CSRDOFFTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC_FCLK period}$$

$$C = \text{RDCYCLETIME} * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC_FCLK period}$$

$$D = (\text{RDCYCLETIME} - \text{RDACCESSTIME}) * \text{GPMC_FCLK period}$$

$$E = (\text{CSRDOFFTIME} - \text{RDACCESSTIME}) * \text{GPMC_FCLK period}$$

2. For burst read accesses (where n is the page burst access number):
 
$$A = (\text{CSRDOFFTIME} - \text{CSONTIME} + (n - 1) * \text{PAGEBURSTACCESSTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK period}$$

$$C = (\text{RDCYCLETIME} + (n - 1) * \text{PAGEBURSTACCESSTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK period}$$

$$D = (\text{RDCYCLETIME} - (\text{RDACCESSTIME} + (n - 1) * \text{PAGEBURSTACCESSTIME})) * \text{GPMC\_FCLK period}$$

$$E = (\text{CSRDOFFTIME} - (\text{RDACCESSTIME} + (n - 1) * \text{PAGEBURSTACCESSTIME})) * \text{GPMC\_FCLK period}$$
3. For burst write accesses (where n is the page burst access number):
 
$$A = (\text{CSWROFFTIME} - \text{CSONTIME} + (n - 1) * \text{PAGEBURSTACCESSTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK period}$$

$$C = (\text{WRCYCLETIME} + (n - 1) * \text{PAGEBURSTACCESSTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK period}$$

$$D = (\text{WRCYCLETIME} - (\text{RDACCESSTIME} + (n - 1) * \text{PAGEBURSTACCESSTIME})) * \text{GPMC\_FCLK period}$$

$$E = (\text{CSWROFFTIME} - (\text{RDACCESSTIME} + (n - 1) * \text{PAGEBURSTACCESSTIME})) * \text{GPMC\_FCLK period}$$
4. For all accesses:
 

For nCS falling edge (chip-select activated):

  - Case where  $\text{GPMC\_CONF/G1\_i}[1-0]$   $\text{GPMCFCLKDIVIDER} = 0x0$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$
  - Case where  $\text{GPMCFCLKDIVIDER} = 0x1$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$ , when (CLKACTIVATIONTIME and CSONTIME are odd) or (CLKACTIVATIONTIME and CSONTIME are even)  
 $F = (1 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK period}$  otherwise.
  - Case where  $\text{GPMCFCLKDIVIDER} = 0x2$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$ , when (CSONTIME – CLKACTIVATIONTIME) is a multiple of 3  
 $F = (1 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK period}$ , when (CSONTIME – CLKACTIVATIONTIME – 1) is a multiple of 3  
 $F = (2 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK period}$ , when (CSONTIME – CLKACTIVATIONTIME – 2) is a multiple of 3

For nCS rising edge (chip-select deactivated) in reading mode:

  - Case where  $\text{GPMC\_CONF/G1\_i}[1-0]$   $\text{GPMCFCLKDIVIDER} = 0x0$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$
  - Case where  $\text{GPMCFCLKDIVIDER} = 0x1$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$ , when (CLKACTIVATIONTIME and CSRDOFFTIME are odd) or (CLKACTIVATIONTIME and CSRDOFFTIME are even)  
 $F = (1 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK period}$  otherwise.
  - Case where  $\text{GPMCFCLKDIVIDER} = 0x2$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$ , when (CSRDOFFTIME – CLKACTIVATIONTIME) is a multiple of 3  
 $F = (1 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK period}$ , when (CSRDOFFTIME – CLKACTIVATIONTIME – 1) is a multiple of 3  
 $F = (2 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK period}$ , when (CSRDOFFTIME – CLKACTIVATIONTIME – 2) is a multiple of 3

For nCS rising edge (chip-select deactivated) in writing mode:

  - Case where  $\text{GPMC\_CONF/G1\_i}[1-0]$   $\text{GPMCFCLKDIVIDER} = 0x0$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$
  - Case where  $\text{GPMCFCLKDIVIDER} = 0x1$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$ , when (CLKACTIVATIONTIME and CSWROFFTIME are odd) or (CLKACTIVATIONTIME and CSWROFFTIME are even)  
 $F = (1 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK period}$  otherwise.
  - Case where  $\text{GPMCFCLKDIVIDER} = 0x2$ :  
 $F = 0.5 * \text{CSEXTRADELAY} * \text{GPMC\_FCLK period}$ , when (CSWROFFTIME – CLKACTIVATIONTIME) is a multiple of 3

$F = (1 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{CSWROFFTIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3

$F = (2 + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{CSWROFFTIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nADV falling edge (nADV activated):

- Case where  $\text{GPMC\_CONF/G1\_I}[1-0]$  GPMCFCLKDIVIDER = 0x0:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period
- Case where GPMCFCLKDIVIDER = 0x1:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period, when (CLKACTIVATIONTIME and ADVONTIME are odd) or (CLKACTIVATIONTIME and ADVONTIME are even)  
 $G = (1 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period otherwise.
- Case where GPMCFCLKDIVIDER = 0x2:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{ADVONTIME} - \text{CLKACTIVATIONTIME})$  is a multiple of 3  
 $G = (1 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{ADVONTIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3  
 $G = (2 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{ADVONTIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nADV rising edge (nADV deactivated) in reading mode:

- Case where  $\text{GPMC\_CONF/G1\_I}[1-0]$  GPMCFCLKDIVIDER = 0x0:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period
- Case where GPMCFCLKDIVIDER = 0x1:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period, when (CLKACTIVATIONTIME and ADVRDOFFTIME are odd) or (CLKACTIVATIONTIME and ADVRDOFFTIME are even)  
 $G = (1 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period otherwise.
- Case where GPMCFCLKDIVIDER = 0x2:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{ADVRDOFFTIME} - \text{CLKACTIVATIONTIME})$  is a multiple of 3  
 $G = (1 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{ADVRDOFFTIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3  
 $G = (2 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{ADVRDOFFTIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nADV rising edge (nADV deactivated) in writing mode:

- Case where  $\text{GPMC\_CONF/G1\_I}[1-0]$  GPMCFCLKDIVIDER = 0x0:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period
- Case where GPMCFCLKDIVIDER = 0x1:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period, when (CLKACTIVATIONTIME and ADVWROFFTIME are odd) or (CLKACTIVATIONTIME and ADVWROFFTIME are even)  
 $G = (1 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period otherwise.
- Case where GPMCFCLKDIVIDER = 0x2:  
 $G = 0.5 * \text{ADVEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{ADVWROFFTIME} - \text{CLKACTIVATIONTIME})$  is a multiple of 3  
 $G = (1 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{ADVWROFFTIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3  
 $G = (2 + 0.5 * \text{ADVEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{ADVWROFFTIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nOE falling edge (nOE activated):

- Case where  $\text{GPMC\_CONF/G1\_I}[1-0]$  GPMCFCLKDIVIDER = 0x0:  
 $H = 0.5 * \text{OEEXTRADELAY} * \text{GPMC\_FCLK}$  period
- Case where GPMCFCLKDIVIDER = 0x1:  
 $H = 0.5 * \text{OEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when (CLKACTIVATIONTIME and OEONTIME are odd) or (CLKACTIVATIONTIME and OEONTIME are even)

- $H = (1 + 0.5 * \text{OEEXTRADELAY}) * \text{GPMC\_FCLK}$  period otherwise.
- Case where  $\text{GPMCFCLKDIVIDER} = 0x2$ :  
 $H = 0.5 * \text{OEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{OEONTIME} - \text{CLKACTIVATIONTIME})$  is a multiple of 3  
 $H = (1 + 0.5 * \text{OEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{OEONTIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3  
 $H = (2 + 0.5 * \text{OEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{OEONTIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nOE rising edge (nOE deactivated):

- Case where  $\text{GPMC\_CONFIG1\_I}[1-0] \text{GPMCFCLKDIVIDER} = 0x0$ :  
 $H = 0.5 * \text{OEEXTRADELAY} * \text{GPMC\_FCLK}$  period
- Case where  $\text{GPMCFCLKDIVIDER} = 0x1$ :  
 $H = 0.5 * \text{OEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{CLKACTIVATIONTIME} \text{ and } \text{OEOFETIME} \text{ are odd}) \text{ or } (\text{CLKACTIVATIONTIME} \text{ and } \text{OEOFETIME} \text{ are even})$   
 $H = (1 + 0.5 * \text{OEEXTRADELAY}) * \text{GPMC\_FCLK}$  period otherwise.
- Case where  $\text{GPMCFCLKDIVIDER} = 0x2$ :  
 $H = 0.5 * \text{OEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{OEOFETIME} - \text{CLKACTIVATIONTIME})$  is a multiple of 3  
 $H = (1 + 0.5 * \text{OEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{OEOFETIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3  
 $H = (2 + 0.5 * \text{OEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{OEOFETIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nWE falling edge (nWE activated):

- Case where  $\text{GPMC\_CONFIG1\_I}[1-0] \text{GPMCFCLKDIVIDER} = 0x0$ :  
 $I = 0.5 * \text{WEEXTRADELAY} * \text{GPMC\_FCLK}$  period
- Case where  $\text{GPMCFCLKDIVIDER} = 0x1$ :  
 $I = 0.5 * \text{WEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{CLKACTIVATIONTIME} \text{ and } \text{WEONTIME} \text{ are odd}) \text{ or } (\text{CLKACTIVATIONTIME} \text{ and } \text{WEONTIME} \text{ are even})$   
 $I = (1 + 0.5 * \text{WEEXTRADELAY}) * \text{GPMC\_FCLK}$  period otherwise.
- Case where  $\text{GPMCFCLKDIVIDER} = 0x2$ :  
 $I = 0.5 * \text{WEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{WEONTIME} - \text{CLKACTIVATIONTIME})$  is a multiple of 3  
 $I = (1 + 0.5 * \text{WEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{WEONTIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3  
 $I = (2 + 0.5 * \text{WEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{WEONTIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nWE rising edge (nWE deactivated):

- Case where  $\text{GPMC\_CONFIG1\_I}[1-0] \text{GPMCFCLKDIVIDER} = 0x0$ :  
 $I = 0.5 * \text{WEEXTRADELAY} * \text{GPMC\_FCLK}$  period
- Case where  $\text{GPMCFCLKDIVIDER} = 0x1$ :  
 $I = 0.5 * \text{WEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{CLKACTIVATIONTIME} \text{ and } \text{WEOFETIME} \text{ are odd}) \text{ or } (\text{CLKACTIVATIONTIME} \text{ and } \text{WEOFETIME} \text{ are even})$   
 $I = (1 + 0.5 * \text{WEEXTRADELAY}) * \text{GPMC\_FCLK}$  period otherwise.
- Case where  $\text{GPMCFCLKDIVIDER} = 0x2$ :  
 $I = 0.5 * \text{WEEXTRADELAY} * \text{GPMC\_FCLK}$  period, when  $(\text{WEOFETIME} - \text{CLKACTIVATIONTIME})$  is a multiple of 3  
 $I = (1 + 0.5 * \text{WEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{WEOFETIME} - \text{CLKACTIVATIONTIME} - 1)$  is a multiple of 3  
 $I = (2 + 0.5 * \text{WEEXTRADELAY}) * \text{GPMC\_FCLK}$  period, when  $(\text{WEOFETIME} - \text{CLKACTIVATIONTIME} - 2)$  is a multiple of 3

For nADV low pulse duration:

- Read operation:

- $K = (\text{ADVRDOFFTIME} - \text{ADVONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period
- Write operation:  
 $K = (\text{ADWWROFFTIME} - \text{ADVONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period

For WAIT invalid to first data latching GPMC output clock edge:

- $L = \text{WAITMONITORINGTIME} * (\text{GPMCFCLKDIVIDER} + 1) * \text{GPMC\_FCLK}$  period + GPMC output clock period

Figure 12-214 shows a simplified example of a synchronous NOR single read where formulas are associated with signal waves.



gpmc-046

Figure 12-214. Synchronous NOR Single Read Simplified Example

#### 12.4.3.5.6.1.3 Asynchronous NOR Flash Timing Parameters Formulas

This section lists all the formulas to calculate asynchronous NOR timing parameters. This is the case when  $\text{GPMC\_CONFIG1\_i}[11-10]$  DEVICETYPE = 0x0 and when READTYPE or WRITETYPE are set to asynchronous mode. Table 12-235 describes the asynchronous NOR formulas.

Table 12-235. Asynchronous NOR Formulas Description

| Configuration Parameter | Unit | Description                                                    |
|-------------------------|------|----------------------------------------------------------------|
| A                       | ns   | Pulse duration – nCS low                                       |
| B                       | ns   | Delay time – nCS valid to nADV/ALE invalid                     |
| C                       | ns   | Delay time – nCS valid to nOE/nRE invalid (single read)        |
| D                       | ns   | Pulse duration – address bus valid - 2nd, 3rd and 4th accesses |
| E                       | ns   | Delay time – nCS valid to nWE valid                            |
| F                       | ns   | Delay time – nCS valid to nWE invalid                          |
| G                       | ns   | Address invalid duration between two successive R/W accesses   |
| H                       | ns   | Setup time – read data valid before nOE/nRE high               |

**Table 12-235. Asynchronous NOR Formulas Description (continued)**

| Configuration Parameter | Unit | Description                                            |
|-------------------------|------|--------------------------------------------------------|
| I                       | ns   | Delay time – nCS valid to nOE/nRE invalid (burst read) |
| J                       | ns   | Delay time – address bus valid to nCS valid            |
|                         |      | Delay time – data bus valid to nCS valid               |
|                         |      | Delay time – nBE0 / nBE1 valid to nCS valid            |
| K                       | ns   | Delay time – nCS valid to nADV/ALE valid               |
| L                       | ns   | Delay time – nCS valid to nOE/nRE valid                |
| M                       | ns   | Delay time – nCS valid to first data latching edge     |
| N                       | ns   | Pulse duration – nBE0 / nBE1 valid time                |
| O                       | ns   | Delay time – nCS valid to nADV/ALE valid               |

The configuration parameters are calculated through the following formulas. These formulas are not exhaustive. For more information, see the device-specific Datasheet.

- nCS low pulse:
  - For single read:  $A = (\text{CSRDOFFTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period
  - For burst read:  $A = (\text{CSRDOFFTIME} - \text{CSONTIME} + (N - 1) * \text{PAGEBURSTACCESSTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period, where  $N$  = page burst access number
  - For single write:  $A = (\text{CSWROFFTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period
  - For burst write:  $A = (\text{CSWROFFTIME} - \text{CSONTIME} + (N - 1) * \text{PAGEBURSTACCESSTIME}) * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period, where  $N$  = page burst access number
- nCS valid to nADV/ALE invalid delay:
  - For reading:  $B = ((\text{ADVRDOFFTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{ADVEXTRADELAY} - \text{CSEXTRADELAY})) * \text{GPMC\_FCLK}$  period
  - For writing:  $B = ((\text{ADVWROFFTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{ADVEXTRADELAY} - \text{CSEXTRADELAY})) * \text{GPMC\_FCLK}$  period
- $C = (\text{OEOFFTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{OEEXTRADELAY} - \text{CSEXTRADELAY}) * \text{GPMC\_FCLK}$  period
- $D = \text{PAGEBURSTACCESSTIME} * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period
- $E = ((\text{WEONTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{WEEXTRADELAY} - \text{CSEXTRADELAY})) * \text{GPMC\_FCLK}$  period
- $F = ((\text{WEOFFTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{WEEXTRADELAY} - \text{CSEXTRADELAY})) * \text{GPMC\_FCLK}$  period
- $G = \text{CYCLE2CYCLEDELAY} * \text{GPMC\_FCLK}$  period
- $H = ((\text{OEOFFTIME} - \text{RDACCESSTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * \text{OEEXTRADELAY}) * \text{GPMC\_FCLK}$  period
- $I = ((\text{OEOFFTIME} + (N - 1) * \text{PAGEBURSTACCESSTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{OEEXTRADELAY} - \text{CSEXTRADELAY})) * \text{GPMC\_FCLK}$  period, where  $N$  = page burst access number
- $J = (\text{CSONTIME} * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK}$  period
- $K = ((\text{ADVONTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{ADVEXTRADELAY} - \text{CSEXTRADELAY})) * \text{GPMC\_FCLK}$  period
- $L = ((\text{OEONTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) + 0.5 * (\text{OEEXTRADELAY} - \text{CSEXTRADELAY})) * \text{GPMC\_FCLK}$  period
- $M = ((\text{RDACCESSTIME} - \text{CSONTIME}) * (\text{TIMEPARAGRANULARITY} + 1) - 0.5 * \text{CSEXTRADELAY}) * \text{GPMC\_FCLK}$  period
- nBE0 /nBE1 pulse:
  - For single read:  $N = \text{RDCYCLETIME} * (\text{TIMEPARAGRANULARITY} + 1) * \text{GPMC\_FCLK}$  period

For burst read:  $N = (RDCYCLETIME + (N - 1) * PAGEBURSTACCESSTIME) * (TIMEPARAGRANULARITY + 1) * GPMC_FCLK$  period, where  $N = \text{page burst access number}$

For burst write:  $N = (WRCYCLETIME + (N - 1) * PAGEBURSTACCESSTIME) * (TIMEPARAGRANULARITY + 1) * GPMC_FCLK$  period, where  $N = \text{page burst access number}$

- $O = ((WRCYCLETIME + (N - 1) * PAGEBURSTACCESSTIME - CSONTIME) * (TIMEPARAGRANULARITY + 1) + 0.5 * (\text{ADVEXTRADELAY} - \text{CSEXTRADELAY})) * GPMC_FCLK$  period

Figure 12-215 shows a simplified example of an asynchronous NOR single write where formulas are associated with signal waves.



**Figure 12-215. Asynchronous NOR Single Write Simplified Example**

#### Note

Write multiple access is not supported in asynchronous mode. If WRITEMULTIPLE is enabled with WRITETYPE as asynchronous, the GPMC processes single asynchronous accesses.

#### 12.4.4 Error Location Module (ELM)

This section describes the Error Location Module (ELM) for the device.

##### 12.4.4.1 ELM Overview

The ELM extracts error addresses from generated syndrome polynomials.

The ELM is used with the GPMC. Syndrome polynomials generated on-the-fly when reading a NAND flash page and stored in GPMC registers are passed to the ELM. A host processor can then correct the data block by flipping the bits to which the ELM error-location outputs point.

When reading from NAND flash memories, some level of error-correction is required. In the case of NAND modules with no internal correction capability, sometimes referred to as *bare NANDs*, the correction process is delegated to the memory controller. ELM can be also used to support parallel NOR flash or NAND flash.

The General-Purpose Memory Controller (GPMC) probes data read from an external NAND flash and uses this to compute checksum-like information, called syndrome polynomials, on a per-block basis. Each syndrome polynomial gives a status of the read operations for a full block, including 512 bytes of data, parity bits, and an optional spare-area data field, with a maximum block size of 1023 bytes. Computation is based on a Bose-Chaudhuri-Hocquenghem (BCH) algorithm. The ELM extracts error addresses from these syndrome polynomials.

Based on the syndrome polynomial value, the ELM can detect errors, compute the number of errors, and give the location of each error bit. The actual data is not required to complete the error-correction algorithm. Errors can be reported anywhere in the NAND flash block, including in the parity bits.

The maximum acceptable number of errors that can be corrected depends on a programmable configuration parameter. 4-, 8-, and 16-bit error-correction levels are supported. The ELM depends on a static and fixed definition of the generator polynomial for each error-correction level that corresponds to the generator polynomials defined in the GPMC (there are three fixed polynomial for the three correction error levels). A larger number of errors than the programmed error-correction level may be detected, but the ELM cannot correct them all. The offending block is then tagged as *uncorrectable* in the associated computation exit status register. If the computation is successful, that is, if the number of errors detected does not exceed the maximum value authorized for the chosen correction capability, the exit status register contains the information on the number of detected errors.

When the error-location process completes, an interrupt is triggered to inform the software that its status can be checked. The number of detected errors and their locations in the NAND block can be retrieved from the module through register accesses.

Figure 12-216 shows the ELM0 module overview.



**Figure 12-216. ELM0 Overview**

#### 12.4.4.1.1 ELM Features

The ELM has the following features:

- 4, 8, and 16 bits per 512-byte block error-location, based on BCH algorithms
- Eight simultaneous processing contexts
- Page-based and continuous modes
- Interrupt generation on error-location process completion:
  - When the full page has been processed in page mode
  - For each syndrome polynomial in continuous mode.

#### 12.4.4.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

#### Note

Some features may not be available. See *Module Integration* for more information.

---

#### 12.4.4.2 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.4.4.3 ELM Functional Description

The ELM0 module is hereinafter referred to as ELM.

The ELM is designed around the error-location engine, which handles the computation based on the input syndrome polynomials.

The ELM maps the error-location engine to a standard interconnect interface by using a set of registers to control inputs and outputs.

##### 12.4.4.3.1 ELM Software Reset

To perform a software reset, set the ELM\_SYSCONFIG[1] SOFTRESET bit to 1. The ELM\_SYSSTATUS[0] RESETDONE bit indicates that the software reset is complete when its value is 1. When the software reset completes, the ELM\_SYSCONFIG[1] SOFTRESET bit is automatically reset.

##### 12.4.4.3.2 ELM Power Management

---

##### Note

Some of the ELM features described in this section may not be supported on this family of devices. For more information, see *Unsupported Features*.

---

Table 12-236 describes the power-management features available to the ELM.

**Table 12-236. Local Power-Management Features**

| Feature          | Registers                      | Description                                                                                                             |
|------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| Clock autogating | ELM_SYSCONFIG[0] AUTOGATING    | This bit allows a local power optimization inside the module by gating the ELM_FICLK clock upon the interface activity. |
| Idle modes       | ELM_SYSCONFIG[4-3] SIDLEMODE   | Force-idle, no-idle, and smart-idle modes are available.                                                                |
| Clock activity   | ELM_SYSCONFIG[8] CLOCKACTIVITY | The clock can be switched off or maintained.                                                                            |

##### 12.4.4.3.3 ELM Interrupt Requests

Table 12-237 lists the event flags, and their masks, that can cause module interrupts asserting the signal.

**Table 12-237. ELM Events**

| Event Flag                   | Event Mask                       | Description                                        |
|------------------------------|----------------------------------|----------------------------------------------------|
| ELM_IRQSTATUS[8] PAGE_VALID  | ELM_IRQENABLE[8] PAGE_MASK       | Page interrupt                                     |
| ELM_IRQSTATUS[7] LOC_VALID_7 | ELM_IRQENABLE[7] LOCATION_MASK_7 | Error-location interrupt for syndrome polynomial 7 |
| ELM_IRQSTATUS[6] LOC_VALID_6 | ELM_IRQENABLE[6] LOCATION_MASK_6 | Error-location interrupt for syndrome polynomial 6 |
| ELM_IRQSTATUS[5] LOC_VALID_5 | ELM_IRQENABLE[5] LOCATION_MASK_5 | Error-location interrupt for syndrome polynomial 5 |
| ELM_IRQSTATUS[4] LOC_VALID_4 | ELM_IRQENABLE[4] LOCATION_MASK_4 | Error-location interrupt for syndrome polynomial 4 |
| ELM_IRQSTATUS[3] LOC_VALID_3 | ELM_IRQENABLE[3] LOCATION_MASK_3 | Error-location interrupt for syndrome polynomial 3 |
| ELM_IRQSTATUS[2] LOC_VALID_2 | ELM_IRQENABLE[2] LOCATION_MASK_2 | Error-location interrupt for syndrome polynomial 2 |
| ELM_IRQSTATUS[1] LOC_VALID_1 | ELM_IRQENABLE[1] LOCATION_MASK_1 | Error-location interrupt for syndrome polynomial 1 |
| ELM_IRQSTATUS[0] LOC_VALID_0 | ELM_IRQENABLE[0] LOCATION_MASK_0 | Error-location interrupt for syndrome polynomial 0 |

#### 12.4.4.3.4 ELM Processing Initialization

ELM\_LOCATION\_CONFIG global setting parameters must be set before using the error-location engine. The ELM\_LOCATION\_CONFIG[1-0] ECC\_BCH\_LEVEL bit field defines the error-correction level used (4-, 8-, or 16-bit error correction). The ELM\_LOCATION\_CONFIG[26-16] ECC\_SIZE bit field defines the maximum buffer length beyond which the engine processing no longer looks for errors.

Software can choose to use the ELM in continuous mode or page mode. If all ELM\_PAGE\_CTRL[i] SECTOR\_i bits (i is the syndrome polynomial number, where i = 0 to 7) are reset, continuous mode is used. In any other case, page mode is implicitly selected.

- Continuous mode: Each syndrome polynomial is processed independently. Results for a syndrome can be retrieved and acknowledged at any time, regardless of the status of the other seven processing contexts.
- Page mode: Syndrome polynomials are grouped into atomic entities: only one page can be processed at any given time, even if all eight contexts are not used for this page. Unused contexts are lost and cannot be affected to any other processing. The full page must be acknowledged and cleared before moving to the next page.

For completion interrupts to be generated correctly, all ELM\_IRQENABLE[i] LOCATION\_MASK\_i bits (where i = 0 to 7) must be forced to 0 when in page mode, and set to 1 in continuous mode. Additionally, the ELM\_IRQENABLE[8] PAGE\_MASK bit must be set to 1 when in page mode.

Software initiates error-location processing by writing a syndrome polynomial into one of the eight possible register sets. Each of these register sets includes seven registers: ELM\_SYNDROME\_FRAGMENT\_0\_i to ELM\_SYNDROME\_FRAGMENT\_6\_i. The first six registers can be written in any order, but ELM\_SYNDROME\_FRAGMENT\_6\_i must be written last because it includes the validity bit, which instructs the ELM that this syndrome polynomial must be processed (the ELM\_SYNDROME\_FRAGMENT\_6\_i[16] SYNDROME\_VALID bit).

As soon as one validity bit is asserted (ELM\_SYNDROME\_FRAGMENT\_6\_i[16] SYNDROME\_VALID = 0x1, where i = 0 to 7), error-location processing can start for the corresponding syndrome polynomial. The associated ELM\_LOCATION\_STATUS\_i and ELM\_ERROR\_LOCATION\_0\_i to ELM\_ERROR\_LOCATION\_15\_i registers (where i = 0 to 7) are not reset. Software must not consider them until the corresponding ELM\_IRQSTATUS[i] LOC\_VALID\_i bit is set.

#### 12.4.4.3.5 ELM Processing Sequence

While the error-location engine is busy processing one syndrome polynomial, further syndrome polynomials can be written. They are processed when the current processing completes.

The engine completes early when:

- No error is detected; that is, when the ELM\_LOCATION\_STATUS\_i[8] ECC\_CORRECTABLE bit is set to 1 and the ELM\_LOCATION\_STATUS\_i[4-0] ECC\_NB\_ERRORS bit field is set to 0x0.
- Too many errors are detected; that is, when the ELM\_LOCATION\_STATUS\_i[8] ECC\_CORRECTABLE bit is set to 0 while the ELM\_LOCATION\_STATUS\_i[4-0] ECC\_NB\_ERRORS bit field is set with the value output by the error-location engine. The reported number of errors is not ensured if ECC\_CORRECTABLE is 0.

If the engine completes early, the associated error-location registers ELM\_ERROR\_LOCATION\_0\_i to ELM\_ERROR\_LOCATION\_15\_i (where i = 0 to 7) are not updated.

In all other cases, the engine goes through the entire error-location process. Each time an error location is found, it is logged in the associated ECC\_ERROR\_LOCATION bit field. The first error detected is logged in the ELM\_ERROR\_LOCATION\_0\_i[12-0] ECC\_ERROR\_LOCATION bit field; the second is logged in the ELM\_ERROR\_LOCATION\_1\_i[12-0] ECC\_ERROR\_LOCATION bit field, and so on.

Table 12-238 describes the ELM\_LOCATION\_STATUS\_i value decoding.

Table 12-238. ELM\_LOCATION\_STATUS\_i Value Decoding

| ECC_CORRECTA<br>BLE Value | ECC_NB_ERRORS<br>Value | Status | Number of Errors<br>Detected | Action Required |
|---------------------------|------------------------|--------|------------------------------|-----------------|
|---------------------------|------------------------|--------|------------------------------|-----------------|

**Table 12-238. ELM\_LOCATION\_STATUS\_i Value Decoding (continued)**

|   |          |        |               |                                                                                                      |
|---|----------|--------|---------------|------------------------------------------------------------------------------------------------------|
| 1 | 0        | OK     | 0             | None                                                                                                 |
| 1 | $\neq 0$ | OK     | ECC_NB_ERRORS | Correct the data buffer read based on the ELM_ERROR_LOCATION_0_i to ELM_ERROR_LOCATION_15_i results. |
| 0 | Any      | Failed | Unknown       | Software-dependent                                                                                   |

#### 12.4.4.3.6 ELM Processing Completion

When the processing for a given syndrome polynomial completes, its ELM\_SYNDROME\_FRAGMENT\_6\_i[16] SYNDROME\_VALID bit is reset. It must not be set again until the exit status registers, ELM\_LOCATION\_STATUS\_i (where  $i = 0$  to 7) for this processing are checked. Failure to comply with this rule leads to potential loss of the first polynomial process data output.

The error-location engine signals the process completion to the ELM. When this event is detected, the corresponding ELM\_IRQSTATUS[i] LOC\_VALID\_i bit (where  $i = 0$  to 7) is set. The processing exit status is available from the associated ELM\_LOCATION\_STATUS\_i register, and error locations are stored in order in the ECC\_ERROR\_LOCATION bit fields. Software must read only valid error-location registers based on the number of errors detected and located.

Immediately after the error-location engine completes, a new syndrome polynomial can be processed, if any is available, as reported by the ELM\_SYNDROME\_FRAGMENT\_6\_i[16] SYNDROME\_VALID bit, depending on the configured error-correction level. If several syndrome polynomials are available, a round-robin arbitration is used to select one for processing.

In continuous mode (that is, all bits in ELM\_PAGE\_CTRL are reset), an interrupt is triggered whenever a ELM\_IRQSTATUS[i] LOC\_VALID\_i bit is asserted. Software must read the ELM\_IRQSTATUS register to determine which polynomial is processed and retrieve the exit status and error locations (ELM\_LOCATION\_STATUS\_i and ELM\_ERROR\_LOCATION\_0\_i to ELM\_ERROR\_LOCATION\_15\_i). When done, software must clear the corresponding ELM\_IRQSTATUS[i] LOC\_VALID\_i bit by setting it to 1. Other status bits must be set to 0 so that other interrupts are not unintentionally cleared. When using this mode, the ELM\_IRQSTATUS[8] PAGE\_VALID interrupt is never triggered.

In page mode, the module does not trigger interrupts for the processing completion of each polynomial because the ELM\_IRQENABLE[i] LOCATION\_MASK\_i bits are cleared. A page is defined using the ELM\_PAGE\_CTRL register. Each SECTOR\_i bit set means the corresponding polynomial i is part of the page processing. A page is fully processed when all tagged polynomials have been processed, as logged in the ELM\_IRQSTATUS[i] LOC\_VALID\_i bits. The module triggers an ELM\_IRQSTATUS[8] PAGE\_VALID interrupt whenever it detects that the full page has been processed. To make sure the next page can be correctly processed, all status bits in the ELM\_IRQSTATUS register must be cleared by using a single atomic-write access.

#### Note

Do not modify page setting parameters in the ELM\_PAGE\_CTRL register unless the engine is idle, no polynomial input is valid, and all interrupts have been cleared.

Because no polynomial-level interrupt is triggered in page mode, polynomials cleared in the ELM\_PAGE\_CTRL[i] SECTOR\_i bits (where  $i = 0$  to 7) are processed as usual, but are essentially ignored. Software must manually poll the ELM\_IRQSTATUS bits to check for their status.

#### 12.4.4.4 ELM Basic Programming Model

##### 12.4.4.4.1 ELM Low-Level Programming Model

###### 12.4.4.4.1.1 Processing Initialization

**Table 12-239. ELM Processing Initialization**

| Step                                                                           | Register/Bit Field/Programming Model                                            | Value     |
|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------|
| Resets the module.                                                             | ELM_SYSCONFIG[1] SOFTRESET                                                      | 0x1       |
| Wait until reset is done.                                                      | ELM_SYSSTATUS[0] RESETDONE                                                      | 0x1       |
| Configure the target interface power management.                               | ELM_SYSCONFIG[4-3] SIDLEMODE                                                    | Set value |
| Defines the error-correction level used.                                       | ELM_LOCATION_CONFIG[1-0] ECC_BCH_LEVEL                                          | Set value |
| Defines the maximum buffer length.                                             | ELM_LOCATION_CONFIG[26-16] ECC_SIZE                                             | Set value |
| Sets the ELM in continuous mode or page mode.                                  | ELM_PAGE_CTRL                                                                   | Set value |
| <b>IF</b> continuous mode is used:                                             | All ELM_PAGE_CTRL[i] SECTOR_i (where i = 0 to 7)                                | 0x0       |
| Enable interrupt for syndrome polynomial i.                                    | ELM_IRQENABLE[i] LOCATION_MASK_i                                                | 0x1       |
| <b>ELSE</b> (page mode is used):                                               | One syndrome polynomial i is set ELM_PAGE_CTRL[i] SECTOR_i (where i = 0 to 7)   | 0x1       |
| Disable all interrupts for syndrome polynomial and enable PAGE_MASK interrupt. | All ELM_IRQENABLE[i] LOCATION_MASK_i = 0x0 and ELM_IRQENABLE[8] PAGE_MASK = 0x1 | Set value |
| <b>ENDIF</b>                                                                   |                                                                                 | Set value |
| Set the input syndrome polynomial i.                                           | ELM_SYNDROME_FRAGMENT_0_i                                                       | Set value |
|                                                                                | ELM_SYNDROME_FRAGMENT_1_i                                                       | Set value |
|                                                                                | ELM_SYNDROME_FRAGMENT_5_i                                                       | Set value |
|                                                                                | ELM_SYNDROME_FRAGMENT_6_i                                                       | Set value |
| Initiates the computation process.                                             | ELM_SYNDROME_FRAGMENT_6_i[16] SYNDROME_VALID                                    | 0x1       |

###### 12.4.4.4.1.2 Read Results

The engine goes through the entire error-location process and results can be read. Table 12-240 and Table 12-241 describe the processing completion for continuous and page modes, respectively.

**Table 12-240. ELM Processing Completion for Continuous Mode**

| Step                                                                                                                                                   | Register/Bit Field/Programming Model                                                                      | Value |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------|
| Wait until process is complete for syndrome polynomial i:                                                                                              |                                                                                                           |       |
| Wait until the interrupt is generated, or poll the status register.                                                                                    |                                                                                                           |       |
| Read for which i the error-location process is complete.                                                                                               | ELM_IRQSTATUS[i] LOC_VALID_i                                                                              | 0x1   |
| <b>IF</b> the process fails (too many errors):                                                                                                         | ELM_LOCATION_STATUS_i[8] ECC_CORRECTABLE                                                                  | 0x0   |
| It is software dependant.                                                                                                                              |                                                                                                           |       |
| <b>ELSE</b> (process successful, the engine completes):                                                                                                | ELM_LOCATION_STATUS_i[8] ECC_CORRECTABLE                                                                  | 0x1   |
| Read the number of errors.                                                                                                                             | ELM_LOCATION_STATUS_i[4-0] ECC_NB_ERRORS                                                                  |       |
| Read the error-location bit addresses for syndrome polynomial i of the ECC_NB_ERRORS first registers. Software must correct errors in the data buffer. | ELM_ERROR_LOCATION_0_i[12-0] ECC_ERROR_LOCATION<br>ELM_ERROR_LOCATION_1_i[12-0] ECC_ERROR_LOCATION<br>... |       |
|                                                                                                                                                        | ELM_ERROR_LOCATION_15_i[12-0] ECC_ERROR_LOCATION                                                          |       |
| <b>ENDIF</b>                                                                                                                                           |                                                                                                           |       |
| Clear the corresponding i interrupt.                                                                                                                   | ELM_IRQSTATUS[i] LOC_VALID_i                                                                              | 0x1   |

A new syndrome polynomial can be processed after the end of processing (

ELM\_SYNTHESIS\_FRAGMENT\_6\_i[16] SYNDROME\_VALID = 0x0) and after the exit status register check (ELM\_LOCATION\_STATUS\_i

**Table 12-241. ELM Processing Completion for Page Mode**

| Step                                                                                                                       | Register/Bit Field/Programming Model                                                                      | Value |
|----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------|
| Wait until process is complete for syndrome polynomial i:                                                                  |                                                                                                           |       |
| Wait until the interrupt is generated, or poll the status register.                                                        |                                                                                                           |       |
| Wait for page completed interrupt:<br>All error locations are valid.                                                       | ELM_IRQSTATUS[8] PAGE_VALID                                                                               | 0x1   |
| <b>Repeat</b> the following actions the necessary number of times. That is, once for each valid defined block in the page. |                                                                                                           |       |
| Read the process exit status.                                                                                              | ELM_LOCATION_STATUS_i[8] ECC_CORRECTABLE                                                                  |       |
| <b>IF</b> the process fails (too many errors):                                                                             | ELM_LOCATION_STATUS_i[8] ECC_CORRECTABLE                                                                  | 0x0   |
| It is software dependent.                                                                                                  |                                                                                                           |       |
| <b>ELSE</b> (process successful, the engine completes):                                                                    | ELM_LOCATION_STATUS_i[8] ECC_CORRECTABLE                                                                  | 0x1   |
| Read the number of errors.                                                                                                 | ELM_LOCATION_STATUS_i[4-0] ECC_NB_ERRORS                                                                  |       |
| Read the error-location bit addresses for syndrome polynomial i of the ECC_NB_ERRORS first registers.                      | ELM_ERROR_LOCATION_0_i[12-0] ECC_ERROR_LOCATION<br>ELM_ERROR_LOCATION_1_i[12-0] ECC_ERROR_LOCATION<br>... |       |
|                                                                                                                            | ELM_ERROR_LOCATION_15_i[12-0] ECC_ERROR_LOCATION                                                          |       |
| <b>ENDIF</b>                                                                                                               |                                                                                                           |       |
| <b>End Repeat</b>                                                                                                          |                                                                                                           |       |
| Clear the ELM_IRQSTATUS register.                                                                                          | ELM_IRQSTATUS                                                                                             | 0x1FF |

#### 12.4.4.4.1.3

Next page can be correctly processed after a page is fully processed, when all tagged polynomials have been processed (ELM\_IRQSTATUS[i] LOC\_VALID\_i = 0x1 for all syndrome polynomials i used in the page).

#### 12.4.4.4.2 Use Case: ELM Used in Continuous Mode

In this example, the ELM is programmed for an 8-bit error-correction capability in continuous mode (see [Table 12-242](#)). After reading a 528-byte NAND flash sector (512B data plus 16B spare area) with a 16-bit interface, a nonzero polynomial syndrome is reported from the GPMC (polynomial syndrome 0 is used in the ELM):

- P = 0xA16ABE115E44F767BFB0D0980.

**Table 12-242. Use Case: Continuous Mode**

| Step                                                                    | Register/Bit Field/Programming Model                                                                                                                                         | Value                                                |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| Reset the module.                                                       | ELM_SYSCONFIG[1] SOFTRESET                                                                                                                                                   | 0x1                                                  |
| Wait until reset is done.                                               | ELM_SYSSTATUS[0] RESETDONE                                                                                                                                                   | 0x1                                                  |
| Configure the target interface power management:<br>Smart idle is used. | ELM_SYSCONFIG[4-3] SIDLEMODE                                                                                                                                                 | 0x2                                                  |
| Define the error-correction level used: 8 bits.                         | ELM_LOCATION_CONFIG[1-0] ECC_BCH_LEVEL                                                                                                                                       | 0x1                                                  |
| Define the maximum buffer length: 528 bytes (2 × 528 = 1056).           | ELM_LOCATION_CONFIG[26-16] ECC_SIZE                                                                                                                                          | 0x420                                                |
| Set the ELM in continuous mode.                                         | ELM_PAGE_CTRL                                                                                                                                                                | 0                                                    |
| Enable interrupt for syndrome polynomial 0.                             | ELM_IRQENABLE[0] LOCATION_MASK_0                                                                                                                                             | 0x1                                                  |
| Set the input syndrome polynomial 0.                                    | ELM_SYNTHESIS_FRAGMENT_0_i (where i = 0)<br>ELM_SYNTHESIS_FRAGMENT_1_i (where i = 0)<br>ELM_SYNTHESIS_FRAGMENT_2_i (where i = 0)<br>ELM_SYNTHESIS_FRAGMENT_3_i (where i = 0) | 0xFB0D0980<br>0xE44F767B<br>0x16ABE115<br>0x0000000A |

**Table 12-242. Use Case: Continuous Mode (continued)**

| Step                                                                                                                                                                              | Register/Bit Field/Programming Model                                                                                                                                                     | Value                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Initiate the computation process.                                                                                                                                                 | <i>ELM_SYNTHESIS_FRAGMENT_6_i[16]</i> SYNDROME_VALID<br>(where i = 0)                                                                                                                    | 0x1                              |
| Wait until process is complete for syndrome polynomial 0:<br>is generated or poll the status register.                                                                            |                                                                                                                                                                                          |                                  |
| Read that error-location process is complete for syndrome polynomial 0.                                                                                                           | <i>ELM_IRQSTATUS[0]</i> LOC_VALID_0                                                                                                                                                      | 0x1                              |
| Read the process exit status:<br>All errors were successfully located.                                                                                                            | <i>ELM_LOCATION_STATUS_i[8]</i> ECC_CORRECTABLE (where i = 0)                                                                                                                            | 0x1                              |
| Read the number of errors:<br>Four errors detected.                                                                                                                               | <i>ELM_LOCATION_STATUS_i[4-0]</i> ECC_NB_ERRORS (where i = 0)                                                                                                                            | 0x4                              |
| Read the error-location bit addresses for syndrome polynomial 0 of the first four registers:<br>Errors are located in the data buffer at decimal addresses 431, 1062, 1909, 3452. | <i>ELM_ERROR_LOCATION_0_i</i> (where i = 0)<br><i>ELM_ERROR_LOCATION_1_i</i> (where i = 0)<br><i>ELM_ERROR_LOCATION_2_i</i> (where i = 0)<br><i>ELM_ERROR_LOCATION_3_i</i> (where i = 0) | 0x1AF<br>0x426<br>0x775<br>0xD7C |
| Clear the corresponding interrupt for polynomial 0.                                                                                                                               | <i>ELM_IRQSTATUS[0]</i> LOC_VALID_0                                                                                                                                                      | 0x1                              |

The NAND flash data in the sector are seen as a polynomial of degree 4223 (number of bits in a 528 byte buffer minus 1), with each data bit being a coefficient in the polynomial. When reading from a NAND flash using the GPMC module, computation of the polynomial syndrome assumes that the first NAND word read at address 0x0 contains the highest-order coefficient in the message. Furthermore, in the 16-bit NAND word, bits are ordered from bit 7 to bit 0, and then from bit 15 to bit 8. Based on this convention, an address table of the data buffer can be built. NAND memory addresses in [Table 12-243](#) are given in decimal format.

**Table 12-243. 16-Bit NAND Sector Buffer Address Map**

| NAND<br>Memory<br>Address | Message Bit Addresses in Memory Word |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
|---------------------------|--------------------------------------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
|                           | 15                                   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| 0                         | 4215                                 | 4214 | 4213 | 4212 | 4211 | 4210 | 4209 | 4208 | 4223 | 4222 | 4221 | 4220 | 4219 | 4218 | 4217 | 4216 |
| 1                         | 4175                                 | 4174 | 4173 | 4172 | 4171 | 4170 | 4169 | 4168 | 4183 | 4182 | 4181 | 4180 | 4179 | 4178 | 4177 | 4176 |
| ...                       |                                      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 47                        | 3463                                 | 3462 | 3461 | 3460 | 3459 | 3458 | 3457 | 3456 | 3471 | 3470 | 3469 | 3468 | 3467 | 3466 | 3465 | 3464 |
| 48                        | 3447                                 | 3446 | 3445 | 3444 | 3443 | 3442 | 3441 | 3440 | 3455 | 3454 | 3453 | 3452 | 3451 | 3450 | 3449 | 3448 |
| 49                        | 3431                                 | 3430 | 3429 | 3428 | 3427 | 3426 | 3425 | 3424 | 3439 | 3438 | 3437 | 3436 | 3435 | 3434 | 3433 | 3432 |
| 50                        | 3415                                 | 3414 | 3413 | 3412 | 3411 | 3410 | 3409 | 3408 | 3423 | 3422 | 3421 | 3420 | 3419 | 3418 | 3417 | 3416 |
| ...                       |                                      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 255                       | 135                                  | 134  | 133  | 132  | 131  | 130  | 129  | 128  | 143  | 142  | 141  | 140  | 139  | 138  | 137  | 136  |
| 256                       | 119                                  | 118  | 117  | 116  | 115  | 114  | 113  | 112  | 127  | 126  | 125  | 124  | 123  | 122  | 121  | 120  |
| 257                       | 103                                  | 102  | 101  | 100  | 99   | 98   | 97   | 96   | 111  | 110  | 109  | 108  | 107  | 106  | 105  | 104  |
| 258                       | 87                                   | 86   | 85   | 84   | 83   | 82   | 81   | 80   | 95   | 94   | 93   | 92   | 91   | 90   | 89   | 88   |
| 259                       | 71                                   | 70   | 69   | 68   | 67   | 66   | 65   | 64   | 79   | 78   | 77   | 76   | 75   | 74   | 73   | 72   |
| 260                       | 55                                   | 54   | 53   | 52   | 51   | 50   | 49   | 48   | 63   | 62   | 61   | 60   | 59   | 58   | 57   | 56   |
| 261                       | 39                                   | 38   | 37   | 36   | 35   | 34   | 33   | 32   | 47   | 46   | 45   | 44   | 43   | 42   | 41   | 40   |
| 262                       | 23                                   | 22   | 21   | 20   | 19   | 18   | 17   | 16   | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   |
| 263                       | 7                                    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    |

The table can now be used to determine which bits in the buffer were incorrect and must be flipped. In this example, the first bit to be flipped is bit 4 from the 49th byte read from memory. It is up to the processor to

correctly map this word to the copied buffer and flip this bit. The same process must be repeated for all detected errors.

#### 12.4.4.4.3 Use Case: ELM Used in Page Mode

In this example, the ELM module is programmed for a 16-bit error-correction capability in page mode (see [Table 12-244](#)). After reading a 528-byte NAND flash sector (512B data plus 16B spare area) with a 16-bit interface, four non-zero polynomial syndromes are reported from the GPMC (polynomial syndrome 0, 1, 2, and 3 are used in the ELM):

- P0 = 0xE8B0 12ADD5A318E05BE B0693DB28330B5CC A329AA05E0B718EF
- P1 = 0xBAD0 49A0D932C22E6669 0948DF08BE093336 79C6BA10E5F935EB
- P2 = 0x69D9 B86ABCD5EC3697FA A6498FEE54556EA0 1579EF7D60BA3189
- P3 = 0x0

**Table 12-244. Use Case: Page Mode**

| Step                                                                              | Register/Bit Field/Programming Model           | Value      |
|-----------------------------------------------------------------------------------|------------------------------------------------|------------|
| Reset the module                                                                  | <i>ELM_SYS CONFIG[1]</i> SOFTRESET             | 0x1        |
| Wait until reset is done.                                                         | <i>ELM_SYS CONFIG[0]</i> RESETDONE             | 0x1        |
| Configure the target interface power management:<br>Smart idle is used.           | <i>ELM_SYS CONFIG[4-3]</i> SIDLEMODE           | 0x2        |
| Define the error-correction level used: 16 bits                                   | <i>ELM_LOCATION_CONFIG[1-0]</i> ECC_BCH_LEVEL  | 0x2        |
| Define the maximum buffer length: 528 bytes                                       | <i>ELM_LOCATION_CONFIG[26-16]</i> ECC_SIZE     | 0x420      |
| Set the ELM in page mode (four blocks in a page)                                  | <i>ELM_PAGE_CTRL[0]</i> SECTOR_0               | 0x1        |
|                                                                                   | <i>ELM_PAGE_CTRL[1]</i> SECTOR_1               | 0x1        |
|                                                                                   | <i>ELM_PAGE_CTRL[2]</i> SECTOR_2               | 0x1        |
|                                                                                   | <i>ELM_PAGE_CTRL[3]</i> SECTOR_3               | 0x1        |
| Disable all interrupts for syndrome polynomial and<br>enable PAGE_MASK interrupt. | <i>ELM_IRQENABLE</i>                           | 0x100      |
| Set the input syndrome polynomial 0.                                              | <i>ELM_SYNDROME_FRAGMENT_0_i</i> (where i = 0) | 0xE0B718EF |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_1_i</i> (where i = 0) | 0xA329AA05 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_2_i</i> (where i = 0) | 0x8330B5CC |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_3_i</i> (where i = 0) | 0xB0693DB2 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_4_i</i> (where i = 0) | 0x318E05BE |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_5_i</i> (where i = 0) | 0x12ADD5A  |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_6_i</i> (where i = 0) | 0xE8B0     |
| Set the input syndrome polynomial 1.                                              | <i>ELM_SYNDROME_FRAGMENT_0_i</i> (where i = 1) | 0xE5F935EB |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_1_i</i> (where i = 1) | 0x79C6BA10 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_2_i</i> (where i = 1) | 0xBE093336 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_3_i</i> (where i = 1) | 0x0948DF08 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_4_i</i> (where i = 1) | 0xC22E6669 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_5_i</i> (where i = 1) | 0x49A0D932 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_6_i</i> (where i = 1) | 0xBAD0     |
| Set the input syndrome polynomial 2.                                              | <i>ELM_SYNDROME_FRAGMENT_0_i</i> (where i = 2) | 0x60BA3189 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_1_i</i> (where i = 2) | 0x1579EF7D |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_2_i</i> (where i = 2) | 0x54556EA0 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_3_i</i> (where i = 2) | 0xA6498FEE |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_4_i</i> (where i = 2) | 0xEC3697FA |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_5_i</i> (where i = 2) | 0xB86ABCD5 |
|                                                                                   | <i>ELM_SYNDROME_FRAGMENT_6_i</i> (where i = 2) | 0x69D9     |

Table 12-244. Use Case: Page Mode (continued)

| Step                                                                                             | Register/Bit Field/Programming Model                                                                                                                                                                                                                                                                                                                                                   | Value                                         |
|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| Set the input syndrome polynomial 3.                                                             | <i>ELM_SYNTHESIS_FRAGMENT_0_i</i> (where $i = 3$ )<br><i>ELM_SYNTHESIS_FRAGMENT_1_i</i> (where $i = 3$ )<br><i>ELM_SYNTHESIS_FRAGMENT_2_i</i> (where $i = 3$ )<br><i>ELM_SYNTHESIS_FRAGMENT_3_i</i> (where $i = 3$ )<br><i>ELM_SYNTHESIS_FRAGMENT_4_i</i> (where $i = 3$ )<br><i>ELM_SYNTHESIS_FRAGMENT_5_i</i> (where $i = 3$ )<br><i>ELM_SYNTHESIS_FRAGMENT_6_i</i> (where $i = 3$ ) | 0x0<br>0x0<br>0x0<br>0x0<br>0x0<br>0x0<br>0x0 |
| Initiate the computation process for syndrome polynomial 0                                       | <i>ELM_SYNTHESIS_FRAGMENT_6_i[16]</i> <i>SYNTHESIS_VALID</i> (where $i = 0$ )                                                                                                                                                                                                                                                                                                          | 0x1                                           |
| Initiate the computation process for syndrome polynomial 1                                       | <i>ELM_SYNTHESIS_FRAGMENT_6_i[16]</i> <i>SYNTHESIS_VALID</i> (where $i = 1$ )                                                                                                                                                                                                                                                                                                          | 0x1                                           |
| Initiate the computation process for syndrome polynomial 2                                       | <i>ELM_SYNTHESIS_FRAGMENT_6_i[16]</i> <i>SYNTHESIS_VALID</i> (where $i = 2$ )                                                                                                                                                                                                                                                                                                          | 0x1                                           |
| Initiate the computation process for syndrome polynomial 3                                       | <i>ELM_SYNTHESIS_FRAGMENT_6_i[16]</i> <i>SYNTHESIS_VALID</i> (where $i = 3$ )                                                                                                                                                                                                                                                                                                          | 0x1                                           |
| Wait until process is complete for syndrome polynomial 0, 1, 2, and 3:                           |                                                                                                                                                                                                                                                                                                                                                                                        |                                               |
| Wait until the interrupt is generated or poll the status register.                               |                                                                                                                                                                                                                                                                                                                                                                                        |                                               |
| Wait for page completed interrupt:<br>All error locations are valid.                             | <i>ELM_IRQSTATUS[8]</i> <i>PAGE_VALID</i>                                                                                                                                                                                                                                                                                                                                              | 0x1                                           |
| Read the process exit status for syndrome polynomial 0:<br>All errors were successfully located. | <i>ELM_LOCATION_STATUS_i[8]</i> <i>ECC_CORRECTABLE</i> (where $i = 0$ )                                                                                                                                                                                                                                                                                                                | 0x1                                           |
| Read the process exit status for syndrome polynomial 1:<br>All errors were successfully located. | <i>ELM_LOCATION_STATUS_i[8]</i> <i>ECC_CORRECTABLE</i> (where $i = 1$ )                                                                                                                                                                                                                                                                                                                | 0x1                                           |
| Read the process exit status for syndrome polynomial 2:<br>All errors were successfully located. | <i>ELM_LOCATION_STATUS_i[8]</i> <i>ECC_CORRECTABLE</i> (where $i = 2$ )                                                                                                                                                                                                                                                                                                                | 0x1                                           |
| Read the process exit status for syndrome polynomial 3:<br>All errors were successfully located. | <i>ELM_LOCATION_STATUS_i[8]</i> <i>ECC_CORRECTABLE</i> (where $i = 3$ )                                                                                                                                                                                                                                                                                                                | 0x1                                           |
| Read the number of errors for syndrome polynomial 0:<br>four errors detected.                    | <i>ELM_LOCATION_STATUS_i[4-0]</i> <i>ECC_NB_ERRORS</i> (where $i = 0$ )                                                                                                                                                                                                                                                                                                                | 0x4                                           |
| Read the number of errors for syndrome polynomial 1:<br>two errors detected.                     | <i>ELM_LOCATION_STATUS_i[4-0]</i> <i>ECC_NB_ERRORS</i> (where $i = 1$ )                                                                                                                                                                                                                                                                                                                | 0x2                                           |
| Read the number of errors for syndrome polynomial 2:<br>one error detected.                      | <i>ELM_LOCATION_STATUS_i[4-0]</i> <i>ECC_NB_ERRORS</i> (where $i = 2$ )                                                                                                                                                                                                                                                                                                                | 0x1                                           |
| Read the number of errors for syndrome polynomial 3:<br>no errors detected.                      | <i>ELM_LOCATION_STATUS_i[4-0]</i> <i>ECC_NB_ERRORS</i> (where $i = 3$ )                                                                                                                                                                                                                                                                                                                | 0x0                                           |
| Read the error-location bit addresses for syndrome polynomial 0 of the first four registers:     | <i>ELM_ERROR_LOCATION_0_i</i> (where $i = 0$ )<br><i>ELM_ERROR_LOCATION_1_i</i> (where $i = 0$ )<br><i>ELM_ERROR_LOCATION_2_i</i> (where $i = 0$ )<br><i>ELM_ERROR_LOCATION_3_i</i> (where $i = 0$ )                                                                                                                                                                                   | 0x1FE<br>0x617<br>0x650<br>0xA83              |
| Read the error-location bit addresses for syndrome polynomial 1 of the first two registers:      | <i>ELM_ERROR_LOCATION_0_i</i> (where $i = 1$ )<br><i>ELM_ERROR_LOCATION_1_i</i> (where $i = 1$ )                                                                                                                                                                                                                                                                                       | 0x4<br>0x1036                                 |
| Read the errors location bit addresses for syndrome polynomial 2 of the first registers:         | <i>ELM_ERROR_LOCATION_0_i</i> (where $i = 1$ )                                                                                                                                                                                                                                                                                                                                         | 0x3E8                                         |
| Clear the <i>ELM_IRQSTATUS</i> register.                                                         | <i>ELM_IRQSTATUS</i>                                                                                                                                                                                                                                                                                                                                                                   | 0x1FF                                         |

### 12.4.5 Multi-Media Card Secure Digital (MMCSD) Interface

This section describes the MMCSD modules in the device.

#### 12.4.5.1 MMCSD Overview

This device contains one or more MMCSD module instances. Each MMCSD instance includes one MMCSD Host Controller.

An instance supports either an 8-bit or 4-bit wide data bus.

A host controller can support eMMC and/or SD/SDIO. See the device specific datasheet for interfaces supported by the controller.

The MMCSD Host Controller provides an interface to eMMC 5.1 (embedded Multi-Media Card), SD 4.10 (Secure Digital), and SDIO 4.0 (Secure Digital IO) devices. The MMCSD Host Controller deals with MMC/SD/SDIO protocol at transmission level, data packing, adding cyclic redundancy checks (CRCs), start/end bit insertion, and checking for syntactical correctness.

The MMCSD Host Controller provides accessibility to external MMC/SD/SDIO devices using a Programmed IO method or DMA data transfer method. In programmed IO method, the device CPU transfers data using the Buffer Data Port register (MMCSDi\_DATA\_PORT). In DMA data transfer method, the MMCSD Host Controller can read or write memory without device CPU intervention.

Figure 12-217 shows the MMCSDi module overview (where i represents a valid instance of MMCSD in a domain. Consult the device specific datasheet for available domains and instances).



A. i represents a valid instance of MMCSD in a domain.

**Figure 12-217. MMCSDi Module Overview**

#### 12.4.5.1.1 MMCSD Features

Each MMCSD Host Controller supports:

- Integrated DMA controller supporting SD Advanced DMA - ADMA2 and ADMA3 (for more information about ADMA support, see [Section 12.4.5.4.4, Advanced DMA](#))
- System Bus Interface:
  - 64-bit data width (host interface)
  - 64-bit address
  - Clock asynchronous to MMCSD clock (MMCI\_CLK)
  - Little endian only
- Configuration Bus Interface:
  - 32-bit data width (target interface)
  - Linear incrementing addressing mode
  - 32-bit aligned accesses only
  - Little endian only
- Muxing of other LVCMOS interfaces onto the MMCSD interface at the SoC level (See the device specific datasheet for supported interfaces, if applicable)

MMCSD Host Controller - eMMC interface (See the device specific datasheet for supported instances):

- Multi-Media Card Support:
  - eMMC Electrical Standard 5.1 (JESD84-B51)
  - Backward compatible with earlier eMMC standards
  - Legacy MMC SDR:
    - 3.3/1.8 V, 8-bit bus width, 0-25 MHz, 25 MBps
    - 3.3/1.8 V, 4-bit bus width, 0-25 MHz, 12.5 MBps
    - 3.3/1.8 V, 1-bit bus width, 0-25 MHz, 3.125 MBps
  - High Speed SDR:
    - 3.3/1.8 V, 8-bit bus width, 0-50 MHz, 50 MBps
    - 3.3/1.8 V, 4-bit bus width, 0-50 MHz, 25 MBps
    - 3.3/1.8 V, 1-bit bus width, 0-50 MHz, 6.25 MBps
  - High Speed DDR:
    - 3.3/1.8 V, 8-bit bus width, 0-50 MHz, 100 MBps
    - 3.3/1.8 V, 4-bit bus width, 0-50 MHz, 50 MBps
  - HS200 SDR:
    - 1.8 V, 0-200 MHz, 8-bit bus width, 200 MBps
    - 1.8 V, 0-200 MHz, 4-bit bus width, 100 MBps

MMCSD Host Controller - SD/SDIO interface (See the device specific datasheet for supported instances):

- Secure Digital Card Support:
  - Backward compatible with earlier SD card specifications
  - SD Host Controller Standard Specification 4.10 and SD Physical Layer Specification v3.01
  - SDIO Specification v3.00
  - Default Speed mode: 3.3 V signaling, frequency up to 25 MHz, up to 12.5 MBps
  - High Speed mode: 3.3 V signaling, frequency up to 50 MHz, up to 25 MBps
  - SDR12: UHS-I 1.8 V signaling, frequency up to 25 MHz, up to 12.5 MBps
  - SDR25: UHS-I 1.8 V signaling, frequency up to 50 MHz, up to 25 MBps
  - SDR50: UHS-I 1.8 V signaling, frequency up to 100 MHz, up to 50 MBps
  - DDR50: UHS-I 1.8 V signaling, frequency up to 50 MHz, up to 50 MBps

#### 12.4.5.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### 12.4.5.2 MMCSD Environment

The MMCSD instance is hereinafter referred to as MMCSDi module.

This section describes the MMCSDi external connections (environment).

The MMCSD (see the device specific datasheet for supported instances) can be used for connection to 1, 4, or 8-bit devices (dedicated for connection to eMMC devices). The MMCSD (see the device specific datasheet for supported instances) can be used for connection to 1 or 4-bit devices (dedicated for connection to SD or SDIO devices). For each MMCSD an integrated UHS-I PHY provides interface to external device.

**Figure 12-218** shows the MMCSDi (where i represents a valid instance of MMCSD in a domain. See the device specific datasheet for available domains and MMCSD instances) connected to MMC, SD, or SDIO device.



- A. x=7 for MMCSD (8-bit wide data bus); x=3 for MMCSD (4-bit wide data bus)
- B. Used for HS400 mode (See the device specific datasheet for valid instances)
- C. Used for PHY Calibration Resistor (See the device specific datasheet for valid instances)

**Figure 12-218. MMCSDi Connected to MMC, SD, or SDIO Device**

**Table 12-245** describes the MMCSDi I/O signals.

**Table 12-245. MMCSDi I/O Signals**

| Module Pin <sup>(4)</sup> | Device Level Signal                                    | I/O <sup>(1)</sup> | Description              |
|---------------------------|--------------------------------------------------------|--------------------|--------------------------|
| MMCSDi <sup>(3)</sup>     |                                                        |                    |                          |
| CLK                       | MMC <sup>i</sup> <sub>(3)</sub> _CLK                   | O                  | External Clock           |
| CMD                       | MMC <sup>i</sup> <sub>(3)</sub> _CMD                   | I/O                | Command Line             |
| DAT[x:0] <sup>(5)</sup>   | MMC <sup>i</sup> <sub>(3)</sub> _DAT[x:0]              | I/O                | Data Signals             |
| DS                        | MMC <sup>i</sup> <sub>(3)</sub> _DS                    | I                  | Data Strobe              |
| CALPAD                    | MMC <sup>i</sup> <sub>(3)</sub> _CALPAD <sup>(2)</sup> | A                  | PHY Calibration Resistor |
| WP                        | MMC <sup>i</sup> <sub>(3)</sub> _SDWP                  | I                  | SD Card Write Protect    |
| CD                        | MMC <sup>i</sup> <sub>(3)</sub> _SDCD                  | I                  | SD Card Detect           |

(1) I = Input; O = Output; HiZ = High Impedance; A = Analog

(2) An external  $10\text{ k}\Omega \pm 1\%$  resistor must be connected between this pin and VSS. No external voltage should be applied to this pin.

(3) i represents an MMC instance. See the device datasheet for available domains and MMC instances.

(4) Some pins may not be pinned out or relevant to this device. See the device datasheet for specifics.

(5) x=7 for MMCSD (8-bit wide data bus); x=3 for MMCSD (4-bit wide data bus)

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), refer to the device-specific Datasheet.

#### 12.4.5.2.1 Protocol and Data Format

The bus protocol between the MMCSD Host Controller and the card is message-based. Each message is represented by one of the following parts:

- Command: A command starts an operation. The command is transferred serially from the MMCSD Host Controller to the card on the CMD line.
- Response: A response is an answer to a command. The response is sent from the card to the MMCSD Host Controller. It is transferred serially on the CMD line.
- Data: Data are transferred from the MMCSD Host Controller to the card or from the card to the MMCSD Host Controller using the data lines.
- Busy: The DAT[0] signal is maintained low by the card as far as it is programming the data received.
- CRC status: The CRC result is sent by the card through the DAT[0] line when executing a write transfer. In the case of transmission error, occurring on any of the active data lines, the card sends a negative CRC status on DAT[0]. In the case of successful transmission, over all active data lines, the card sends a positive CRC status on DAT[0] and starts the data programming procedure.

##### 12.4.5.2.1.1 Protocol

There are two types of data transfer:

- Sequential operation
- Block-oriented operation

There are specific commands for each type of operation (sequential or block-oriented).

For information about commands and programming sequences supported by the MMC, SD, and SDIO devices, see the *Multi-Media Card System Specification*, *SD Memory Card Specifications*, and *SDIO Card Specification (Part E1)*.

[Figure 12-219](#) and [Figure 12-220](#) show how sequential operations are defined. Sequential operation is only for 1-bit transfer and initiates a continuous data stream. The transfer terminates when a stop command follows on the CMD line.

---

#### Note

Stream commands are supported only by MMCs.

---



**Figure 12-219. Sequential Read Operation (MMCs Only)**



**Figure 12-220. Sequential Write Operation (MMCs Only)**

Figure 12-221 and Figure 12-222 show how multiple block-oriented operations are defined. A multiple block-oriented operation sends a data block plus CRC bits. The transfer terminates when a stop command follows on the CMD line. These operations are available for all kinds of devices (MMC, SD, SDIO).



**Figure 12-221. Multiple Block Read Operation**

mmcsd-008



mmcsd-009

**Figure 12-222. Multiple Block Write Operation With Card Busy Signal**

#### Note

- The card busy signal is not always generated by the card. Refer to [Figure 12-221](#) and [Figure 12-222](#), that show a particular case.
- Software must perform a software reset (see `MMCSD0_SOFTWARE_RESET` / `MMCSD1_SOFTWARE_RESET` register) after a data time-out to ensure that `MMCI_CLK` is stopped.
- For multiblock transfer, and especially for MMC devices, a transfer can be aborted without using a stop command. If a `CMD23` is used before data transfer to define the number of blocks that will be transferred, then the transfer stops automatically after the last block (if the MMCs supports this feature).

#### 12.4.5.2.1.2 Data Format

##### 12.4.5.2.1.2.1 Coding Scheme for Command Token

Command tokens always start with 0 and end with 1. The second bit is a transmitter bit: 1 for a host command. The content is the command index (coded by 6 bits) and an argument (for example, an address), coded by 32 bits. The content is protected by 7-bit CRC checksum (see [Figure 12-223](#)).



**Figure 12-223. Command Token Format**

##### 12.4.5.2.1.2.2 Coding Scheme for Response Token

Response tokens always start with 0 and end with 1. The second bit is a transmitter bit: 0 for a card response. The content is different for each type of response (R1, R2, R3, R4, and R5, R6, R7 [for SD]) and the content is protected by 7-bit CRC checksum (see [Figure 12-224](#) and [Figure 12-225](#)). Depending on the type of commands sent to the card, the `MMCSD0_COMMAND` / `MMCSD1_COMMAND` register must be configured differently to

avoid false CRC or index errors to be flagged on command response (see [Table 12-246](#)). For more information about response types, see the *Multi-Media Card System Specification*, *SD Memory Card Specifications*, and *SDIO Card Specification (Part E1)*.



**Figure 12-224. Response Token Format (R1/R1b, R3, R4, R5/R5b, R6, R7)**



**Figure 12-225. Response Token Format (R2)**

**Table 12-246. Relationship Between Configuration and Name of Response Type**

| Response Type<br>MMCSD0_COMMAND[1-0]<br>RESP_TYPE_SEL /<br>MMCSD1_COMMAND[1-0]<br>RESP_TYPE_SEL | Index Check Enable<br>MMCSD0_COMMAND[4]<br>CMD_INDEX_CHK_ENA /<br>MMCSD1_COMMAND[4]<br>CMD_INDEX_CHK_ENA | CRC Check Enable<br>MMCSD0_COMMAND[3]<br>CMD_CRC_CHK_ENA /<br>MMCSD1_COMMAND[3]<br>CMD_CRC_CHK_ENA | Name of Response Type         |
|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-------------------------------|
| 00                                                                                              | 0                                                                                                        | 0                                                                                                  | No response                   |
| 01                                                                                              | 0                                                                                                        | 1                                                                                                  | R2                            |
| 10                                                                                              | 0                                                                                                        | 0                                                                                                  | R3 (R4 for SD cards)          |
| 10                                                                                              | 1                                                                                                        | 1                                                                                                  | R1, R6, R5, (R7 for SD cards) |
| 11                                                                                              | 1                                                                                                        | 1                                                                                                  | R1b, R5b                      |

#### 12.4.5.2.1.2.3 Coding Scheme for Data Token

Data tokens always start with 0 and end with 1 (see [Figure 12-226](#) through [Figure 12-228](#)).



**Figure 12-226. Data Token Format for 1-Bit Transfers**



**Figure 12-227. Data Token Format for 4-Bit Transfers**



**Figure 12-228. Data Token Format for 8-Bit Transfers**

#### 12.4.5.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.4.5.4 MMCSD Functional Description

##### 12.4.5.4.1 Block Diagram

Figure 12-229 shows the MMCSDi module block diagram (where i represents a valid instance of MMCSD in a domain).



**Figure 12-229. MMCSDi Module Block Diagram**

##### Basic Blocks:

- MMCSD Host Controller:** The MMCSD Host Controller is situated in the MMCSD Subsystem and provides accessibility to external MMC/SD/SDIO devices using a Programmed IO method or DMA data transfer method.
- UHS-I PHY:** The integrated UHS-I PHY provides an interface between the MMCSD Host Controller and external MMC/SD/SDIO devices.
- MMCSDi Interface:** The MMCSDi Interface includes all used interface pins (for more information, see [Table 12-245](#)).
- Host Port:** Provides a 64-bit wide read/write interface between the device and the MMCSD Subsystem internal SRAM.
- Target Port:** Provides a 32-bit wide interface between the device and the MMCSD Subsystem and MMCSD Host Controller parts.
- MMCSD Host Controller Registers:** This block includes set of all MMCSD Host Controller registers.
- MMCSD Subsystem and PHY Registers:** This block implements memory-mapped registers at the MMCSD Subsystem level and memory-mapped registers to control and program the MMCSD PHY.
- ECC Aggregator:** The ECC Aggregator block facilitates aggregating and reporting internal SRAM ECC errors (for more information, see [ECC Support](#)).
- Internal SRAM with ECC:** The internal SRAM block is used for data storage during read/write transactions.
- DMA Controller:** Manages the data transfer between the device memory and the MMCSD Subsystem internal SRAM.

- System Clocks: There are asynchronous relationship between the interface (system) clock and functional clock (for more information, see *MMCSD Clocks*).
- System Reset: The reset to the MMCSD Subsystem provides reset to the all MMCSD Subsystem parts (for more information, see *MMCSD Clocks*).
- Interrupts: The MMCSD Subsystem sources one MMCSD Host Controller interrupt and four ECC Aggregator interrupts (for more information, see *MMCSD Hardware Requests* and *Interrupt Requests*).

For more information about all MMCSD registers, see *MMCSD Registers*.

The MMCSD Host Controller can use a Programmed IO method (PIO) or DMA data transfer method to access external MMC/SD/SDIO devices.

The target port is used for device CPU access to the MMCSD Host Controller register set. The MMCSD Host Controller register set provides the communication between the device CPU and the MMCSD Host Controller. In PIO method the device CPU transfers data using the MMCSD0\_DATA\_PORT / MMCSD1\_DATA\_PORT register. The data flow from the device memory to the external MMC/SD/SDIO device (and vice versa) is through the target port, the MMCSD0\_DATA\_PORT / MMCSD1\_DATA\_PORT register in the MMCSD Host Controller, and the PHY.

The host port is used for connection to the DMA controller (for more information about ADMA support, see *Advanced DMA* and *MMCSD0\_CAPABILITIES / MMCSD1\_CAPABILITIES* register). In DMA data transfer method the DMA controller uses the host port to transfer data between the device memory and the MMCSD Subsystem internal SRAM. The other side of the internal SRAM is connected to the MMCSD Host Controller. The data flow from the device memory to the external MMC/SD/SDIO device (and vice versa) is through the host port, internal SRAM, MMCSD Host Controller, and the PHY. The DMA controller manages the read/write operations from/to the internal SRAM without device CPU intervention.

#### **12.4.5.4.2 Interrupt Requests**

Each MMCSD instance sources one active high level MMCSD Host Controller interrupt and four active high level ECC Aggregator interrupts (see *Module Integration*). The MMCSD Host Controller interrupt is generated based on the bit values in the MMCSD0\_NORMAL\_INTR\_STS / MMCSD1\_NORMAL\_INTR\_STS and MMCSD0\_NORMAL\_INTR\_STS\_ENA / MMCSD1\_NORMAL\_INTR\_STS\_ENA registers. The ECC Aggregator interrupts are generated based on the ECC errors - single and double bit errors (for more information about ECC Aggregator interrupts, see *ECC Support*).

#### **12.4.5.4.3 ECC Support**

The Error Correcting Code (ECC) is a mechanism for providing increased system reliability via reduction of memory software errors by allowing single bit errors to be detected and corrected (SEC) and double bit errors to be detected (DED).

There are two SRAM memories (transmit SRAM and receive SRAM) within each MMCSD instance. These two memories are ECC protected.

The SEC logic detects and corrects a single bit error (single bit error per ECC word or per ECC data segment). The DED logic only detects (does not correct) double errors (double bit errors per ECC word or per ECC data segment).

#### **12.4.5.4.3.1 ECC Aggregator**

There are two SRAMs (each with size 4 KB - 512 words × 64-bit) in each MMCSD Subsystem. One SRAM dedicated for transmit and one SRAM dedicated for receive operations.

Figure 12-230 shows the ECC Aggregator block diagram.



mmcsd-018

**Figure 12-230. ECC Aggregator Block Diagram**

**Note**

For more information about ECC Aggregator Registers, refer to *MMCSD Registers*.

**12.4.5.4.4 Advanced DMA**

The MMCSD modules support SD Advanced DMA – ADMA2 and ADMA3.

**Note**

For more information, refer to the SD Association specification titled "*SD Host Controller Simplified Specification, Part A2, Version 4.10*".

## 12.4.5.5 MMCSD Programming Guide

### 12.4.5.5.1 Sequences

This section defines basic sequence flow chart divided into several sub sequences.

#### Note

UHSII is not supported. For more information, see *Not Supported Features*.

"Wait for interrupts" is used in the flow chart. This means the Host Driver waits until specified interrupts are asserted. If already asserted, then fall through that step in the flow chart. Timeout checking shall be always required to detect no interrupt generated but this is not described in the flow chart.

This specification uses the double box like [Figure 12-231](#), (the step (1) in [Figure 12-235](#)), it means that the other flows, which already are shown, shall be performed. Therefore, the interrupt may be included in the other flows.



mmcsd-019

**Figure 12-231. Double Box Notation**

#### 12.4.5.5.1.1 SD Card Detection



mmcsd-020

**Figure 12-232. SD Card Detect Sequence**

The flow chart for detecting a SD card is shown in [Figure 12-232](#).

Each step is executed as follows:

To enable interrupt for card detection, write 1 to the following bits:

- MMCSD0\_NORMAL\_INTR\_STS\_ENA[6] CARD\_INSERTION
- MMCSD0\_NORMAL\_INTR\_SIG\_ENA[6] CARD\_INSERTION

- MMCSD0\_NORMAL\_INTR\_STS\_ENA[7] CARD\_REMOVAL
- MMCSD0\_NORMAL\_INTR\_SIG\_ENA[7] CARD\_REMOVAL

(1) When the Host Driver detects the card insertion or removal, clear its interrupt statuses. If Card Insertion interrupt is generated, write 1 to MMCSD0\_NORMAL\_INTR\_STS\_ENA[6] CARD\_INSERTION bit. If Card Removal interrupt is generated, write 1 to MMCSD0\_NORMAL\_INTR\_STS\_ENA[7] CARD\_REMOVAL bit.

(2) Check MMCSD0\_PRESENTSTATE[16] CARD\_INSERTED bit. In the case where MMCSD0\_PRESENTSTATE[16] CARD\_INSERTED bit is 1, the Host Driver can supply the power and the clock to the SD card. In the case where MMCSD0\_PRESENTSTATE[16] CARD\_INSERTED bit is 0, the other executing processes of the Host Driver shall be immediately closed.

If miniSD adaptor is used for standard SD slot and miniSD card is inserted or extracted from the adaptor, card detect interrupt may not be generated. When host does not receive response to any commands, miniSD card is extracted or in idle state, the host should try to re-initialize the card. In this case, all card information shall be re-loaded.

#### 12.4.5.5.1.2 SD Clock Control

##### 12.4.5.5.1.2.1 Internal Clock Setup Sequence



mmcsd-021

**Figure 12-233. Internal Clock Setup Sequence**

The sequence for supplying SD Clock to a SD card is described in [Figure 12-233](#). From Version 4.10, MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit is added. This sequence is also applicable to prior versions which do not support MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit.

(1) Calculate a divisor to determine SD Clock frequency for legacy IF or RCLK frequency for UHS-II IF by reading MMCSD0\_CAPABILITIES[15-8] BASE\_CLK\_FREQ and MMCSD0\_CAPABILITIES[55-48] CLOCK\_MULTIPLIER bit fields. If non-zero value is set to MMCSD0\_CAPABILITIES[55-48] CLOCK\_MULTIPLIER bit field, Programmable Clock Mode can be used (for more information, see MMCSD0\_CLOCK\_CONTROL[5] CLKGEN\_SEL bit). If MMCSD0\_CAPABILITIES[15-8] BASE\_CLK\_FREQ bit field is 00 0000b, the Host System shall provide this information to the Host Driver by another method.

(2) Set MMCSD0\_CLOCK\_CONTROL[15-8] SDCLK\_FRQSEL bit field and MMCSD0\_CLOCK\_CONTROL[5] CLKGEN\_SEL bit in accordance with the calculated result of step (1).

If MMCSD0\_HOST\_CONTROL2[15] PRESET\_VALUE\_ENA bit is set, these bits are set by Host Controller automatically as specified in the Preset Value register (MMCSD0\_PRESET\_VALUE0 - MMCSD0\_PRESET\_VALUE10).

(3) Set MMCSD0\_CLOCK\_CONTROL[0] INT\_CLK\_ENA bit.

(4) Check MMCSD0\_CLOCK\_CONTROL[1] INT\_CLK\_STABLE bit. Repeat this step until this status is 1. Clock will be stable in shorter time but timeout of this loop is defined as 150 ms.

(5) Set MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit. This step does not affect Host Controllers which do not support MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit.

(6) If MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit is supported, PLL locked may be checked by this status (if MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit is not supported, this status is supposed to indicate 1 by step (3)). Clock will be stable in shorter time but timeout of this loop is defined as 150 ms.

#### 12.4.5.5.1.2.2 SD Clock Supply and Stop Sequence



**Figure 12-234. SD Clock Supply and Stop Sequence**

The flow chart for stopping the SD Clock is shown in [Figure 12-234](#). The Host Driver shall not stop the SD Clock when a SD transaction is occurring on the SD Bus -- namely, when either MMCSD0\_PRESENTSTATE[1] INHIBIT\_DAT or MMCSD0\_PRESENTSTATE[0] INHIBIT\_CMD bit is set to 1.

(1) Setup Internal Clock (see [Figure 12-233](#)). Then set MMCSD0\_CLOCK\_CONTROL[2] SD\_CLK\_ENA bit to 1. Then, the Host Controller starts supplying the SD Clock.

(2) Set MMCSD0\_CLOCK\_CONTROL[2] SD\_CLK\_ENA bit to 0. Then, the Host Controller stops supplying the SD Clock. Internal Clock is still oscillating.

#### 12.4.5.5.1.2.3 SD Clock Frequency Change Sequence



mmcsd-023

**Figure 12-235. SD Clock Change Sequence**

The sequence for changing SD Clock frequency is shown in [Figure 12-235](#).

- (1) Execute the SD Clock Stop Sequence (see [Figure 12-234](#)). If SD Clock supply to card is already stopped, skip this step.
- (2) Clear MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit to 0. If MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit is not supported, this step has no effect and may be skipped.
- (3) When MMCSD0\_HOST\_CONTROL2[15] PRESET\_VALUE\_ENA bit is set to 0, change clock parameters in the MMCSD0\_CLOCK\_CONTROL register. When MMCSD0\_HOST\_CONTROL2[15] PRESET\_VALUE\_ENA bit is set to 1, select Bus Speed Mode as described.
- (4) Set MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit to 1. If MMCSD0\_CLOCK\_CONTROL[3] PLL\_ENA bit is not supported, this step has no effect and may be skipped.
- (5) Wait until MMCSD0\_CLOCK\_CONTROL[1] INT\_CLK\_STABLE bit is set to 1. Clock will be stable in shorter time but timeout of this loop is defined as 150 ms. SD Clock Supply Sequence is required to provide clock to device (see [Figure 12-234](#)).

#### 12.4.5.5.1.3 SD Bus Power Control

The sequence for controlling the SD Bus Power is described in [Figure 12-236](#).



mmcsd-024

**Figure 12-236. SD Bus Power Control Sequence**

- (1) By reading the MMCSD0\_CAPABILITIES register, get the support voltage of the Host Controller.
- (2) Set MMCSD0\_POWER\_CONTROL[3-1] SD\_BUS\_VOLTAGE bit field with maximum voltage that the Host Controller supports.
- (3) Set MMCSD0\_POWER\_CONTROL[0] SD\_BUS\_POWER bit to 1.
- (4) Get the OCR value of all function internal of SD card.
- (5) Judge whether SD Bus voltage needs to be changed or not. In case where SD Bus voltage needs to be changed, go to step (6). In case where SD Bus voltage does not need to be changed, go to "End".
- (6) Set MMCSD0\_POWER\_CONTROL[0] SD\_BUS\_POWER bit to 0 for clearing this bit. The card requires voltage rising from 0 volt to detect it correctly. The Host Driver shall

clear MMCSD0\_POWER\_CONTROL[0] SD\_BUS\_POWER bit before changing voltage by setting MMCSD0\_POWER\_CONTROL[3-1] SD\_BUS\_VOLTAGE bit field.

(7) Set MMCSD0\_POWER\_CONTROL[3-1] SD\_BUS\_VOLTAGE bit field.

(8) Set MMCSD0\_POWER\_CONTROL[0] SD\_BUS\_POWER to 1.

**Note:** Step (2) and step (3) can be executed at same time. And also, step (7) and step (8) can be executed at same time.

#### 12.4.5.5.1.4 Changing Bus Width



mmcsd-025

**Figure 12-237. Change Bus Width Sequence**

The sequence for changing bit mode on SD Bus is shown in [Figure 12-237](#).

(1) Set MMCSD0\_NORMAL\_INTR\_STS\_ENA[8] CARD\_INTERRUPT bit to 0 for masking incorrect interrupts that may occur while changing the bus width.

(2) In case of SD memory only card, go to step (4). In case of other card, go to step (3).

(3) Set "IENM" of the CCCR in a SDIO or SD combo card to 0 by CMD52.

(4) Change the bus width mode for a SD card. SD Memory Card bus width is changed by ACMD6 and SDIO card bus width is changed by setting Bus Width of Bus Interface Control register in CCCR.

(5) In case of changing to 4-bit mode, set MMCSD0\_HOST\_CONTROL1[1] DATA\_WIDTH bit to 1. In another case (1-bit mode), set this bit to 0.

(6) In case of SD memory only card, go to the "End". In case of other card, go to step (7).

(7) Set "IENM" of the CCCR in a SDIO or SD combo card to 1 by CMD52.

(8) Set MMCSD0\_NORMAL\_INTR\_STS\_ENA[8] CARD\_INTERRUPT bit to 1.

Note that if the card is locked, bus width cannot be changed. Unlock the card is required before changing bus width.

#### 12.4.5.1.5 Timeout Setting on DAT Line



**Figure 12-238. Timeout Setting Sequence**

In order to detect timeout errors on DAT line, the Host Driver shall execute the following two steps before any SD transaction. For more information regarding SD transactions:

(1) Calculate a divisor to detect timeout errors by reading MMCSD0\_CAPABILITIES[5-0] TIMEOUT\_CLK\_FREQ bit field and MMCSD0\_CAPABILITIES[7] TIMEOUT\_CLK\_UNIT bit. If MMCSD0\_CAPABILITIES[5-0] TIMEOUT\_CLK\_FREQ bit field is 00 0000b, the Host System shall provide this information to the Host Driver by another method.

(2) Set MMCSD0\_TIMEOUT\_CONTROL[3-0] COUNTER\_VALUE bit field in accordance with the value from step (1) above.

#### 12.4.5.1.6 Card Initialization and Identification (for SD I/F)

[Figure 12-239](#) and [Figure 12-240](#) shows initialization and card identification sequence for the Standard Capacity SD Memory Card (SDSC), the High Capacity SD Memory Card (SDHC) and the Extended Capacity SD Memory Card (SDXC) that was based on the Physical Layer Version 3.01. Refer to the latest sequence.



**Figure 12-239. Card Initialization and Identification (1)**



mmcsd-028

**Figure 12-240. Card Initialization and Identification (2)**

- (1) SD Bus mode is selected by CMD0 (Keep Pin 1 to high during CMD0 execution).
- (2) New CMD8 shall be issued after CMD0 to support High Capacity SD Memory Card.

(3) Voltage check command enables the Hosts to support future low voltage specification. However, at this time, only one voltage is defined. Legacy cards and Not SD cards do not respond to CMD8. In this case, set F8 to 0 (F8 is CMD8 valid flag used in step (11)) and go to Step (5). Only Version 2.00 or higher cards can respond to CMD8. The host needs to check whether CRC of the response is valid and whether VHS and check pattern in the argument are equal to VCA and check pattern in the response. Passing all these checks results in CMD8 response OK. In this case, set F8 to 1 and go to step (5). If one of the checks is failed, go to step (4).

(4) Initialization is stopped by CMD8 fails. The Host Driver should retry step (1) to (3) one more time (this is not described in the figure).

(5) SDIO OCR is available by issuing CMD5 with setting voltage window (bit 23 to 0) in the argument to 0. SDIO initialization is not started.

(6) No response means the card does not have SDIO function. Set SDIO flag to 0 and go to step (11). If the card responds to CMD5 and the response is OK, go to step (7). If the response is error, set SDIO flag to 0 and go to step (10). SDIO flag indicates whether SDIO functions are initialized or not.

(7) The SDIO portion starts initialization by CMD5 with setting the supply voltage to the voltage window. UHS-I supported host sets S18R to 1. If the supplied voltage is not matched with voltage window of card, the card goes into inactive state and does not return the response.

(8) If no response or error response is received, set SDIO flag to 0 and go to step (10). If good response is received, go to step (9).

(9) Check busy status in the response. If busy is released, set SDIO flag to 1 and go to step (10). Repeat from step (7) while busy is indicated. Detecting timeout of 1 second exits the loop. In this case, set SDIO flag to 0 and go to step (10).

(10) Good response in this step means that all responses received at (6) and (8) are valid. When response is good, MP (memory present) flag in the response can be checked. If the response valid and MP = 0, go to step (28). Otherwise, go to step (11).

(11) Check F8 flag set in step (3). If CMD8 is executed correctly (F8 = 1), go to step (19). Otherwise, go to step (12).

(12) OCR is available by issuing ACMD41 with the voltage window (bit 23 to 0) in the argument is set to 0. Memory initialization is not started. The response of CMD55 (ACMD41) may indicate illegal command error due to some SD cards do not recognize CMD8. The Host Driver should ignore this error or issue CMD0 before ACMD41 to clear this error status.

(13) If response of CMD55 is not received, the card is not SD cards and goes to (17). If the card responds to CMD55, it may also respond to CMD41. If the responses of ACMD41 are OK, go to Step (14). Otherwise, go to step (28). Locked card can be detected by the card status in the response of CMD55.

(14) The memory portion starts initialization by issuing ACMD41 with setting the supply voltage to the voltage window. If the supplied voltage is not matched with voltage window of card, the card goes into inactive state and does not return the response.

(15) If no response or error response is received, go to step (28). If good response is received, go to step (16).

(16) Check busy status in the response. If busy is released, go to step (18). Repeat from step (14) while busy is indicated. The interval of ACMD41 shall be less than 50 ms. Detecting timeout of 1 second exits the loop and go to step (28).

(17) The host recognizes that the card is not SD memory card and quits SD card initialization.

(18) The host recognizes that the card is Version 1.xx Standard Capacity SD Memory Card. Go to Step (30).

(19) OCR is available by issuing ACMD41 with setting the voltage window (bit 23 to 0) in the argument is set to 0. Memory initialization is not started. Setting of HCS does not affect this operation.

- (20) If the card responds to CMD55, it may also respond to CMD41. If the responses of ACMD41 are OK, go to Step (21). Otherwise, go to step (28). Locked card can be detected by the card status in the response of CMD55.
- (21) The memory portion starts initialization by Issuing ACMD41 with setting the supply voltage to the voltage window. UHS-I supported host sets S18R to 1. If the host can supply more than 150mA, XPC is set to 1. HCS in the argument is set to 1, which indicates supporting High Capacity Memory Card. If the supplied voltage is not matched with voltage window of card, the card goes into inactive state and does not return the response.
- (22) If no response or error response is received, go to step (28). If good response is received, go to step (23).
- (23) Check busy status in the response. If busy is released, go to step (24). Repeat from step (21) while busy is indicated. The interval of ACMD41 shall be less than 50 ms. Detecting timeout of 1 second exits the loop and go to step (28).
- (24) CCS in the response is valid after busy is released. If CCS = 0, it indicates the Standard Capacity SD Memory Card and go to step (25). If CCS = 1, it indicates the High Capacity SD Memory Card or Extended Capacity Memory Card and go to Step (26).
- (25) The host recognizes that the card is Ver2.00 or Ver3.00 Standard Capacity SD Memory Card. Optimal functions defined in Version 2.00 or higher are available. Go to Step (32).
- (26) The host recognizes that the card is the High Capacity SD Memory Card or Extended Capacity Memory Card.
- (27) Perform the signal voltage switch procedure and go to step (32).
- (28) Check SDIO flag. If SDIO = 1, go to step (28). Otherwise, go to step (31).
- (29) The host recognizes that the card is SDIO only card and go to step (30).
- (30) Perform the signal voltage switch procedure and go to step (33).
- (31) The host recognizes that the card is unusable.
- (32) In case of memory card, CMD2 is issued to get CID and Go to Step (31).
- (33) CMD3 is issued to get RCA. If the RCA number is 0, the Host should issue CMD3 again.

**12.4.5.5.1.6.1 Signal Voltage Switch Procedure (for UHS-I)**


mmcsd-029

**Figure 12-241. Signal Voltage Switch Procedure**

- (1) If S18A of CMD5 or S18A of ACMD41 is set to 1, signal voltage switch is performed according to the following steps. Otherwise, exits from this procedure.
- (2) Issue CMD11.
- (3) Check response and if an error is detected, go to step (12).
- (4) Stop providing SD clock to the card.
- (5) Check DAT[3:0] level. If the level is 0000b, the card is ready to start voltage switch sequence. Otherwise, go to (12) to quit the sequence.
- (6) Set MMCSD0\_HOST\_CONTROL2[3] V1P8\_SIGNAL\_ENA bit.
- (7) Wait 5 ms. 1.8 V voltage regulator shall be stable within this period.
- (8) If MMCSD0\_HOST\_CONTROL2[3] V1P8\_SIGNAL\_ENA bit is cleared by Host Controller, go to step (12).
- (9) Provide SD Clock to the card again.
- (10) Wait 1 ms.
- (11) Check DAT[3:0] level. If the level is 1111b, switch to 1.8 V signal level is completed successfully. Otherwise, go to (12).
- (12) If an error occurs during voltage switch procedure, stop providing the power to the card. In this case, Host Driver should retry initialization procedure by setting S18R to 0 at step (7) and (21) in [Figure 12-239](#) and [Figure 12-240](#).

#### **12.4.5.5.1.7 SD Transaction Generation**

This section describes the sequences how to generate and control various kinds of SD transactions. SD transactions are classified into three cases:

- (1) Transactions that do not use the DAT line.
- (2) Transactions that use the DAT line only for the busy signal.
- (3) Transactions that use the DAT line for transferring data.

In this specification the first and the second case's transactions are classified as "Transaction Control without Data Transfer using DAT Line", the third case's transaction is classified as "Transaction Control with Data Transfer using DAT Line". Refer to the latest SD Physical Layer Specification and SDIO Specification for more detail about SD commands specification.

##### **12.4.5.1.7.1 Transaction Control without Data Transfer Using DAT Line**

In this section, the sequence for how to issue SD Command and how to complete SD Command is explained. [Figure 12-242](#) shows the sequence to issue a SD Command and [Figure 12-243](#) shows the sequence to finalize a SD Command.

###### **12.4.5.1.7.1.1 The Sequence to Issue a SD Command**

The sequence to issue the SD Command is detailed in [Figure 12-242](#).



mmcsd-030

Figure 12-242. SD Command Issue Sequence

- (1) Check MMCSD0\_PRESENTSTATE[0] INHIBIT\_CMD bit. Repeat this step until MMCSD0\_PRESENTSTATE[0] INHIBIT\_CMD bit is 0. That is, when MMCSD0\_PRESENTSTATE[0] INHIBIT\_CMD bit is 1, the Host Driver shall not issue a SD Command.
- (2) If the Host Driver issues a SD Command using DAT lines including busy signal, go to step (3). If without using DAT lines including busy signal, go to step (5).
- (3) If the Host Driver is issuing an abort command, go to step (5). In the case of nonabort command, go to step (4).
- (4) Check MMCSD0\_PRESENTSTATE[1] INHIBIT\_DAT bit. Repeat this step until MMCSD0\_PRESENTSTATE[1] INHIBIT\_DAT bit is set to 0.

(5) Set registers except the MMCSD0\_COMMAND register.

(6) Set the MMCSD0\_COMMAND register.

**Note:** Writing the upper byte [3] in the MMCSD0\_COMMAND register causes the Host Controller to issue a SD command to the SD card.

(7) Perform Command Completion Sequence in accordance.

#### **12.4.5.1.7.1.2 The Sequence to Finalize a Command**

Figure 12-243 shows the sequence to finalize a SD Command when response check is disabled. There is a possibility that some errors (Command Index/End bit/CRC/Timeout Error) occur during this sequence. If response check is enabled, error is indicated by Response Error Interrupt.



mmcsd-031

Figure 12-243. Command Complete Sequence

#### 12.4.5.5.1.7.1.3

(1) If MMCSD0\_TRANSFER\_MODE[8] RESP\_INTR\_DIS bit is set to 1 (response check is enabled), go to step (4) else wait for the Command Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE). If the Command Complete Interrupt has occurred, go to step (2).

(2) Write 1 to MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE bit to clear this bit.

(3) Read the Response register (see MMCSD0\_RESPONSE\_0 - MMCSD0\_RESPONSE\_7) and get necessary information of the issued command.

- (4) Judge whether the command uses the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE) or not. If it uses Transfer Complete, go to step (5). If not, go to step (7).
- (5) Wait for the Transfer Complete Interrupt. If the Transfer Complete Interrupt has occurred, go to step (6).
- (6) Write 1 to MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit to clear this bit.
- (7) Check for errors in Response Data (MMCSD0\_RESPONSE\_0 - MMCSD0\_RESPONSE\_7). If there is no error, go to step (8). If there is an error, go to step (9).
- (8) Return Status of "No Error".
- (9) Return Status of "Response Contents Error".

**Note1:** While waiting for the Transfer Complete interrupt, the Host Driver shall only issue commands that do not use the busy signal.

**Note2:** The Host Driver shall judge the Auto CMD12 complete by monitoring Transfer Complete.

**Note3:** When the last block of un-protected area is read using memory multiple block read command (CMD18), OUT\_OF\_RANGE error may occur even if the sequence is correct. The Host Driver should ignore it. This error will appear in the response of Auto CMD12 or in the response of the next memory command.

#### **12.4.5.5.1.7.2 Transaction Control with Data Transfer Using DAT Line**

Depending on whether DMA (optional) is used or not, there are two execution methods.

In addition, the sequences for SD transfers are classified into following three kinds according to how the number of blocks is specified:

- (1) Single Block Transfer: The number of blocks is specified to the Host Controller before the transfer. The number of blocks specified is always one.
- (2) Multiple Block Transfer: The number of blocks is specified to the Host Controller before the transfer. The number of blocks specified shall be one or more.
- (3) Infinite Block Transfer: The number of blocks is not specified to the Host Controller before the transfer. This transfer is continued until an abort transaction is executed. This abort transaction is performed by CMD12 in the case of a SD memory card and by CMD52 in the case of a SDIO card.

##### **12.4.5.5.1.7.2.1 Not using DMA**

The sequence for not using DMA is shown in [Figure 12-244](#).



mmcsd-032

**Figure 12-244. Transaction Control with Data Transfer Using DAT Line Sequence (Not using DMA)**

- (1) Set the value corresponding to the executed data byte length of one block to the MMCSD0\_BLOCK\_SIZE register.
  - (2) Set the value corresponding to the executed data block count to the MMCSD0\_BLOCK\_COUNT register in accordance with *Determination of Transfer Type*.
  - (3) Set the argument value to Argument register (MMCSD0\_ARGUMENT1\_LO and MMCSD0\_ARGUMENT1\_HI).
  - (4) Set the value to the MMCSD0\_TRANSFER\_MODE register. The Host Driver determines Multi/Single Block Select, Block Count Enable, Data Transfer Direction, Auto CMD12 Enable and DMA Enable in the MMCSD0\_TRANSFER\_MODE register. Multi/Single Block Select and Block Count Enable are determined according to *Determination of Transfer Type*.
- If response check is enabled (MMCSD0\_TRANSFER\_MODE[7] RESP\_ERR\_CHK\_ENA = 1), set MMCSD0\_TRANSFER\_MODE[8] RESP\_INTR\_DIS bit to 1 and select Response Type R1/R5 (MMCSD0\_TRANSFER\_MODE[6] RESP\_TYPE).
- (5) Set the value to MMCSD0\_COMMAND register.
  - Note:** When writing the upper byte [3] of MMCSD0\_COMMAND register, SD command is issued.
  - (6) If response check is enabled, go to step (9) else wait for the Command Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE bit).
  - (7) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE bit for clearing this bit.
  - (8) Read Response register (MMCSD0\_RESPONSE\_0 - MMCSD0\_RESPONSE\_7) and get necessary information of the issued command.
  - (9) In the case where this sequence is for write to a card, go to step (10). In case of read from a card, go to step (14).
  - (10) Then wait for Buffer Write Ready Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[4] BUF\_WR\_READY).
  - (11) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS\_ENA[4] BUF\_WR\_READY bit for clearing this bit.
  - (12) Write block data (in according to the number of bytes specified at the step (1)) to MMCSD0\_DATA\_PORT register.
  - (13) Repeat until all blocks are sent and then go to step (18).
  - (14) Then wait for the Buffer Read Ready Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[5] BUF\_RD\_READY).
  - (15) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS\_ENA[5] BUF\_RD\_READY bit for clearing this bit.
  - (16) Read block data (in according to the number of bytes specified at the step (1)) from the MMCSD0\_DATA\_PORT register.
  - (17) Repeat until all blocks are received and then go to step (18).
  - (18) If this sequence is for Single or Multiple Block Transfer, go to step (19). In case of Infinite Block Transfer, go to step (21).
  - (19) Wait for Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE).
  - (20) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit for clearing this bit.
  - (21) Perform the sequence for Abort Transaction in accordance with [Section 12.4.5.5.1.8, Abort Transaction](#).

**Note:** Step (1) and Step (2) can be executed at same time. Step (4) and Step (5) can be executed at same time.

#### 12.4.5.5.1.7.2.2 Using SDMA

The sequence for using SDMA is shown in [Figure 12-245](#).



mmcsd-033

**Figure 12-245. Transaction Control with Data Transfer Using DAT Line Sequence (Using SDMA)**

- (1) Data location of system memory is set to the SDMA System Address register if MMCSD0\_HOST\_CONTROL2[12] HOST\_VER40\_ENA = 0 or set to the MMCSD0\_ADMA\_SYS\_ADDRESS register if MMCSD0\_HOST\_CONTROL2[12] HOST\_VER40\_ENA = 1.
- (2) Set the value corresponding to the executed data byte length of one block in the MMCSD0\_BLOCK\_SIZE register.
- (3) Set the value corresponding to the executed data block count in the MMCSD0\_BLOCK\_COUNT register in accordance with *Determination of Transfer Type*.
- (4) Set the argument value to the Argument register (MMCSD0\_ARGUMENT1\_LO and MMCSD0\_ARGUMENT1\_HI).
- (5) Set the value to the MMCSD0\_TRANSFER\_MODE register. The Host Driver determines Multi/Single Block Select, Block Count Enable, Data Transfer Direction, Auto CMD12 Enable and DMA Enable in the

MMCSD0\_TRANSFER\_MODE register. Multi/Single Block Select and Block Count Enable are determined according to *Determination of Transfer Type*. If response check is enabled (MMCSD0\_TRANSFER\_MODE[7] RESP\_ERR\_CHK\_ENA = 1), set MMCSD0\_TRANSFER\_MODE[8] RESP\_INTR\_DIS bit to 1 and select Response Type R1/R5.

(6) Set the value to the MMCSD0\_COMMAND register.

**Note:** When writing to the upper byte [3] of the MMCSD0\_COMMAND register, the SD command is issued and SDMA is started.

(7) If response check is enabled, go to step (10) else wait for the Command Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE bit).

(8) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE bit to clear this bit.

(9) Read Response register (MMCSD0\_RESPONSE\_0 - MMCSD0\_RESPONSE\_7) and get necessary information of the issued command.

(10) Wait for the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE) and DMA Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[3] DMA\_INTERRUPT).

(11) If MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit is set to 1, go to Step

(14) else if MMCSD0\_NORMAL\_INTR\_STS\_ENA[3] DMA\_INTERRUPT bit is set to 1, go to Step

(12). The MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit is higher priority than the MMCSD0\_NORMAL\_INTR\_STS\_ENA[3] DMA\_INTERRUPT bit.

(12) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS\_ENA[3] DMA\_INTERRUPT bit to clear this bit.

(13) Set the next system address of the next data position to the System Address register (MMCSD0\_ADMA\_SYS\_ADDRESS) and go to Step (10).

(14) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit and MMCSD0\_NORMAL\_INTR\_STS\_ENA[3] DMA\_INTERRUPT bit to clear this bit.

**Note:** Step (2) and Step (3) can be executed simultaneously. Step (5) and Step (6) can also be executed simultaneously.

#### **12.4.5.5.1.7.2.3 Using ADMA**

The sequence for using ADMA is shown in [Figure 12-246](#).



mmcsd-034

**Figure 12-246. Transaction Control with Data Transfer Using DAT Line Sequence (Using ADMA)**

- (1) Create Descriptor table for ADMA in the system memory.
- (2) Set the Descriptor address for ADMA in the MMCSD0\_ADMA\_SYS\_ADDRESS register.
- (3) Set the value corresponding to the executed data byte length of one block in the MMCSD0\_BLOCK\_SIZE register.
- (4) Set the value corresponding to the executed data block count in the MMCSD0\_BLOCK\_COUNT register in accordance with *Determination of Transfer Type*.
- (5) Set the argument value to the Argument register (MMCSD0\_ARGUMENT1\_LO and MMCSD0\_ARGUMENT1\_HI).
- (6) Set the value to the MMCSD0\_TRANSFER\_MODE register. The Host Driver determines Multi/Single Block Select, Block Count Enable, Data Transfer Direction, Auto CMD12 Enable and DMA Enable in the MMCSD0\_TRANSFER\_MODE register. Multi/Single Block Select and Block Count Enable are determined according to *Determination of Transfer Type*. If response check is enabled (MMCSD0\_TRANSFER\_MODE[7]

RESP\_ERR\_CHK\_ENA = 1), set MMCSD0\_TRANSFER\_MODE[8] RESP\_INTR\_DIS bit to 1 and select Response Type R1/R5 (MMCSD0\_TRANSFER\_MODE[6] RESP\_TYPE).

(7) Set the value to the MMCSD0\_COMMAND register.

**Note:** When writing to the upper byte [3] of the MMCSD0\_COMMAND register, the SD command is issued and DMA is started.

(8) If response check is enabled, go to step (11) else wait for the Command Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE bit).

(9) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS[0] CMD\_COMPLETE bit to clear this bit.

(10) Read Response register (MMCSD0\_RESPONSE\_0 - MMCSD0\_RESPONSE\_7) and get necessary information of the issued command.

(11) Wait for the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE) and ADMA Error Interrupt (MMCSD0\_ADMA\_ERR\_STATUS[1-0] ADMA\_ERR\_STATE).

(12) If MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit is set to 1, go to Step (13) else if MMCSD0\_ADMA\_ERR\_STATUS[1-0] ADMA\_ERR\_STATE bit field is set to 1, go to Step (14).

(13) Write 1 to the MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit to clear this bit.

(14) Write 1 to the MMCSD0\_ADMA\_ERR\_STATUS[1-0] ADMA\_ERR\_STATE bit field to clear this bit.

(15) Abort ADMA operation. SD card operation should be stopped by issuing abort command. If necessary, the Host Driver checks MMCSD0\_ADMA\_ERR\_STATUS register to detect why ADMA error is generated.

**Note:** Step (3) and Step (4) can be executed simultaneously. Step (6) and Step (7) can also be executed simultaneously.

#### **12.4.5.5.1.8 Abort Transaction**

An abort transaction is performed by issuing CMD12 for a SD memory card and by issuing CMD52 for a SDIO card. There are two cases where the Host Driver needs to do an Abort Transaction. The first case is when the Host Driver stops Infinite Block Transfers. The second case is when the Host Driver stops transfers while a Multiple Block Transfer is executing.

There are two ways to issue an Abort Command. The first is an asynchronous abort. The second is a synchronous abort. In an asynchronous abort sequence, the Host Driver can issue an Abort Command at any time unless MMCSD0\_PRESENTSTATE[0] INHIBIT\_CMD bit is set to 1. In a synchronous abort, the Host Driver shall issue an Abort Command after the data transfer stopped by using MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit.

##### **12.4.5.5.1.8.1 Asynchronous Abort**

The sequence for Asynchronous Abort is shown in [Figure 12-247](#).



mmcsd-035

**Figure 12-247. Asynchronous Abort Sequence**

(1) Issue Abort Command in accordance.

(2) Set both MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit and MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit to 1 to do software reset.

(3) Check MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit and MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit. If both MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit and MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit are 0, go to "End". If either MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit or MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit is 1, go to step (3).

#### 12.4.5.5.1.8.2 Synchronous Abort



mmcsd-036

**Figure 12-248. Synchronous Abort Sequence**

- (1) Set the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit to 1 to stop SD transactions.
- (2) Wait for the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE).
- (3) Set the MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE bit to 1 to clear this bit.
- (4) Issue the Abort Command
- (5) Set both MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit and MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit to 1 to do software reset.
- (6) Check both MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit and MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit. If both MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit and MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit are 0, go to "End". If either MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit or MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit is 1, go to step (6).

#### 12.4.5.5.1.9 Changing Bus Speed Mode

This section describes the sequence for switching the bus speed mode: Default Speed, High Speed mode and UHS-I mode. The switch command (CMD6) is used to change memory card bus speed mode. The EHS bit (SDIO Version 2.00) or BSS[2-0] bits (SDIO Version 3.00) in the CCCR register is used to change the bus speed mode for SDIO card. In case of Combo card, either of the switch method changes both memory and IO bus speed mode. This means the first switch is effective. Refer to the Physical Layer Specification Version 3.0x and the SDIO Specification Version 3.00 for more information about switching bus speed. [Figure 12-249](#) shows the sequence for switching bus speed mode for Combo Card. Note that if the card is locked, bus width cannot be changed. Unlock the card is required before changing bus width.



mmcsd-037

**Figure 12-249. Changing Bus Speed Mode**

- (1) The Host Driver checks if the card supports memory. If not supported, go to (5).
- (2) Issue CMD6 with mode 1 to change bus speed mode (Default, High Speed mode or UHS-I mode).
- (3) Check the response of CMD6. If the card does not supports CMD6 (no response) or bus speed is not changed successfully, go to step (5). In this case, the card is in Default Speed mode.
- (4) The Host Driver changes the Host Controller bus speed mode to the same mode.

- (5) The Host Driver checks if the card supports SDIO. If not supported, go to the end.
- (6) Issue CMD52 to write EHS bit or BSS[2-0] bits in CCCR to change bus speed mode (the same bus speed mode of (2) shall be set).
- (7) If EHS or BSS[2-0] are not changed successfully, go to the end.
- (8) The Host Driver changes the Host Controller bus speed to the same mode. In case of Combo card, bus speed is already changed at step (4) and this step does not affect changing bus speed.

#### 12.4.5.5.1.10 Error Recovery


mmcsd-038

**Figure 12-250. Error Report and Recovery**

Figure 12-250 shows concept of error report and its recovery. The Host Controller has 2 interrupt status registers. If an error occurs in the SD Bus transaction, one of the bits is set in the MMCSD0\_ERROR\_INTR\_STS register. If the function errors occur in the SDIO card, the card interrupt informs these function errors and the Card interrupt is set in the MMCSD0\_NORMAL\_INTR\_STS\_ENA register (the Card Interrupt is used to inform not only error statuses but also normal information. For example, to inform function ready). The Card Driver shall do function error recovery because the Host Driver does not know how to control the function. In the case that function error occurs due to SD Bus error, SD Bus error recovery is required before function error recovery. Abort command is used to recover SD Bus, and then the Host Driver should save error statuses related to SD Bus errors before issuing abort command and transfer these statuses to the Card Driver. These statuses may be used to recover function error. Following explanations are related to SD Bus error recovery. This specification does not specify the function error recovery.

When an error occurs during data transfer in 2L-HD UHS-II mode, there will be the case that Host Controller cannot drive D0 lane in input mode due to DIR LSS for retrieving lane direction is not detected. In this case, Host Driver cannot issue abort command for recovery. Then if DIR LSS is not detected, Host Controller sets MMCSD0\_UHS2\_ERR\_INTR\_STS[17] DEADLOCK\_TIMEOUT bit. Host Driver should execute power cycle if MMCSD0\_UHS2\_ERR\_INTR\_STS[17] DEADLOCK\_TIMEOUT bit is detected to recover from this error. Furthermore, if this type of error is detected several times in 2L-HD, Host Driver should use FD mode rather than using 2L-HD.

#### Implementation Note:

If the Card Driver cannot recover the function errors, the Host Driver should try following methods.

##### (9) Using IOEx for SDIO card

IOEx may be used as the reset per function basis. Sequence is as follows:

Clear IOEx = 0 and wait until IORx = 0 and then set IOEx = 1 again. SDIO may be recovered when IORx = 1.

##### (10) Using reset command for memory and SDIO card Re-initialization sequence is required.

(11) Off and on power supply for the SD Bus.

The card may be recovered by the power on reset. Re-initialization sequence is required.

The two cases where the Host Driver needs the "Error Recovery" sequence are classified as follows:

(1) Error Interrupt Recovery:

If error interrupt is indicated by the MMCSD0\_ERROR\_INTR\_STS register, the Host Driver shall apply this sequence.

(2) Auto CMD12 Error Recovery:

If there are errors in Auto CMD12, the Host Driver shall apply this sequence. In terms of Return Status, Auto CMD12 Error Recovery is classified into 4 cases. It is shown in [Figure 12-251](#). If error occurs during memory write transfer, strongly recommend using ACMD22 and then in the following recovery sequence, retry to send remaining blocks not written.



mmcsd-039

**Figure 12-251. Return Status of Auto CMD12 Error Recovery**

Implementation Note:

Abort command is used to recover from SD Bus error. SDIO transaction abort using CMD52 returns response but in the case of memory transaction abort using CMD12, response returns depending on the memory card state. If no response returns after issue CMD12, the Host Driver should check card state using CMD13. If the state is "tran" in the CURRENT\_STATE, consider CMD12 is successful.

Implementation Note:

The following sequence is one possible error recovery flow. There may be another methods, sometimes using interrupts or polling. It can be possible to use another flows, based on Host System requirements.

In these error recovery sequences, return statuses for the next sequence. When the Host Controller cannot issue the next command due to SD Bus error, the error recovery sequences return "Non-recoverable" status. In this case, the Host System may cut off power to the SD Bus and then power on SD Bus and initialize both the Host Controller and the SD card again.

**12.4.5.5.1.10.1 Error Interrupt Recovery**


mmcsd-040

**Figure 12-252. Error Interrupt Recovery Sequence (1)**



mmcsd-041

Figure 12-253. Error Interrupt Recovery Sequence (2)

- (1) Disable the Error Interrupt Signal (MMCSD0\_ERROR\_INTR\_SIG\_ENA).
- (2) Check bits D03-00 in the MMCSD0\_ERROR\_INTR\_STS register. If one of these bits (D03-00) is set to 1, go to step (3). If none are set to 1 (all are 0), go to step (5).
- (3) Set MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit to 1.

- (4) Check MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit. If MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit is 0, go to step (5). If it is 1, go to step (4).
- (5) Check bits D06-04 in the MMCSD0\_ERROR\_INTR\_STS register. If one of these bits (D06-04) is set to 1, go to step (6). If none are set to 1 (all are 0), go to step (8).
- (6) Set MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit to 1 for software reset of the DAT line.
- (7) Check MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit. If MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit is 0, go to step (8). If it is 1, go to step (7).
- (8) Save previous error status.
- (9) Clear previous error status with setting them to 1.
- (10) Issue Abort Command.
- (11) MMCSD0\_PRESENTSTATE[1] INHIBIT\_DAT bit and MMCSD0\_PRESENTSTATE[0] INHIBIT\_CMD bit. Repeat this step until both MMCSD0\_PRESENTSTATE[1] INHIBIT\_DAT bit and MMCSD0\_PRESENTSTATE[0] INHIBIT\_CMD bit are set to 0.
- (12) Check bits D03-00 in the MMCSD0\_ERROR\_INTR\_STS register for Abort Command. If one of these bits is set to 1, go to step (16). If none of these bits are set to 1 (all are 0), go to step (13).
- (13) Check MMCSD0\_ERROR\_INTR\_STS[4] DATA\_TIMEOUT bit. If this bit is set to 1, go to step (16). If it is 0, go to step (14).
- (14) Wait for more than 40 us.
- (15) By monitoring the DAT [3:0] Line Signal Level in the MMCSD0\_PRESENTSTATE register, judge whether the level of the DAT line is low or not. If one or more DAT lines are low, go to step (16). If the DAT lines are high, go to step (17).
- (16) Return Status of "Non-recoverable Error".
- (17) Return Status of "Recoverable Error".
- (18) Enable the Error Interrupt Signal (MMCSD0\_ERROR\_INTR\_SIG\_ENA).

### **12.4.5.5.1.10.2 Auto CMD12 Error Recovery**



**Figure 12-254. Auto CMD12 Error Recovery**

The sequence for Auto CMD12 Error Recovery is shown in [Figure 12-254](#). Following four cases A-D shall be covered.

- A: An error occurred in CMD\_wo\_DAT, but not in the SD memory transfer.
  - B: An error occurred in CMD\_wo\_DAT, and also occurred in the SD memory transfer.
  - C: An error did not occur in CMD\_wo\_DAT, but an error occurred in the SD memory transfer.
  - D: CMD\_wo\_DAT was not issued, and an error occurred in the SD memory transfer.

- (1) Check MMCSD0\_AUTOCMD\_ERR\_STS[0] ACMD12\_NOT\_EXEC bit. If this bit is set to 1, go to step (2). If this bit is set to 0, go to step (6). In addition, the Host Driver shall define PCMD flag, which changes to 1 if MMCSD0\_AUTOCMD\_ERR\_STS[0] ACMD12\_NOT\_EXEC bit is set to 1.
- (2) Wait for Error Interrupt Recovery for CMD\_wo\_DAT.
- (3) Check "Return Status". In the case of "Non-recoverable Error", go to step (16). In the case of "Recoverable Error", go to step (4).
- (4) Issue CMD12 .
- (5) If the CMD line errors occur for the CMD12 (one of D03-00 is set in the MMCSD0\_ERROR\_INTR\_STS register), "Return Status" is "Non-recoverable Error" and go to step (16). If not CMD line error and busy timeout error occur (D04 is set in the MMCSD0\_ERROR\_INTR\_STS register), "Return Status" is "Recoverable Error" and go to step (11). Otherwise, "Return Status" is "No error" and go to step (17).
- (6) Set MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit to 1 for software reset of the CMD line.
- (7) Check MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit. If MMCSD0\_SOFTWARE\_RESET[1] SWRST\_FOR\_CMD bit is 0, go to step (8). If it is 1, go to step (7).
- (8) Issue CMD12 . Acceptance of CMD12 depends on the state of the card. CMD12 may make the card to return to tran state. If the card is already in tran state, the card does not response to CMD12.
- (9) Check "Return Status" for CMD12. If "Return Status" returns "Non-recoverable Error", go to step (16). In the case of "Recoverable Error" or "No error", go to step (10).
- (10) Check the MMCSD0\_AUTOCMD\_ERR\_STS[0] ACMD12\_NOT\_EXEC bit. If this bit is 0, go to step (11). If it is 1, go to step (14).
- (11) Set MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit to 1 for software reset of the DAT line.
- (12) Check MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit. If MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit is 0, go to step (13). If it is 1, go to step (12).
- (13) Check the PCMD flag. If PCMD is 1, go to step (18). If it is 0, go to step (19).
- (14) Set MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit to 1 for software reset of the DAT line.
- (15) Check MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit. If MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit is 0, go to step (20). If it is 1, go to step (15).
- (16) Return Status of "Non-recoverable Error".
- (17) Return Status that an error has occurred in CMD\_wo\_DAT, but not in the SD memory transfer.
- (18) Return Status that an error has occurred in both CMD\_wo\_DAT, and the SD memory transfer.
- (19) Return Status that an error has not occurred in CMD\_wo\_DAT, but has occurred in the SD memory transfer.
- (20) Return Status that CMD\_wo\_DAT has not been issued, and an error has occurred in the SD memory transfer.

#### **12.4.5.1.11 Wakeup Control (Optional)**

After the Host System goes into standby mode, the Host System can resume from standby via a wakeup event initiated by one of the following three events:

- (1) Interrupt from a SD card: If an SD card interrupt occurs, the Host System can resume from standby mode. If the Host System uses this wakeup factor, SD Bus power shall be kept on.
- (2) Insertion of SD card: If a SD card is inserted, the Host System can resume from standby mode.
- (3) Removal of SD card: If a SD card is removed, the Host System can resume from standby mode.

The sequence for preparing wakeup before the Host System goes into standby mode is shown in [Figure 12-255](#).



mmcsd-043

**Figure 12-255. Wakeup Control before Standby Mode**

- (1) Set MMCSD0\_HOST\_CONTROL1[1] DATA\_WIDTH bit to 0.
- (2) Execute SD Clock Stop Sequence as described in [Section 12.4.5.5.1.2.2, SD Clock Supply and Stop Sequence](#).
- (3) Clear the MMCSD0\_NORMAL\_INTR\_STS register and the MMCSD0\_NORMAL\_INTR\_SIG\_ENA register, and then set the enable bits of each wakeup event factor to 1 in the MMCSD0\_WAKEUP\_CONTROL register and set the bits of MMCSD0\_ERROR\_INTR\_STS\_ENA register to use wakeup.

The sequence for wakeup once in standby mode is shown in [Figure 12-256](#).



mmcsd-044

**Figure 12-256. Wakeup from Standby**

- (1) Wait for wakeup event.

(2) Set the enable bits of each wakeup event factor to 0 in the MMCSD0\_WAKEUP\_CONTROL register and then clear event statuses in the MMCSD0\_NORMAL\_INTR\_STS register. If necessary, set the MMCSD0\_NORMAL\_INTR\_SIG\_ENA register.

(3) Execute SD Clock Supply Sequence (see [Section 12.4.5.5.1.2.2, SD Clock Supply and Stop Sequence](#)).

(4) Set the SD Bus width (see [Section 12.4.5.5.1.4, Changing Bus Width](#)).

#### **12.4.5.5.1.12 Suspend/Resume (Optional, Not Supported from Version 4.00)**

If a SD card supports suspend and resume functionality, then the Host Controller can initiate suspend and resume. It is necessary for both the Host Controller and the SD card to support the function of "Read Wait". ADMA operation does not support this function.

**12.4.5.5.1.12.1 Suspend Sequence**


mmcsd-045

**Figure 12-257. The Sequence for Suspend**

(1) Set MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit to 1 to stop the SD transaction.

(2) Wait for an Interrupt. If MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT bit is set to 0 and MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit is set to 1, go to step (8). If MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT bit is set to 1, go to step (3).

- (3) Set MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT bit to 1 to clear this bit.
- (4) Wait for the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS\_ENA[1] XFER\_COMPLETE).
- (5) Issue the Suspend Command in accordance with [Section 12.4.5.5.1.7.1, Transaction Control without Data Transfer Using DAT Line](#).
- (6) Check the BS value of the response data. If BS is 0, go to step (7). If BS is 1, go to step (10).
- (7) Save the register.
- (8) Set MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit to 1 to clear this bit.
- (9) Set MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit to 0 to clear this bit.
- (10) Check the BR value of the response data. If BR is 1, go to step (11). If BR is 0, go to step (13).
- (11) Issues the command to cancel the previous suspend command in accordance with [Section 12.4.5.5.1.7.1, Transaction Control without Data Transfer Using DAT Line](#).
- (12) Check the BS value of the response data. If BS is 0, go to step (7). If BS is 1, go to step (13).
- (13) Set MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit to 1 to clear this bit.
- (14) Set MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit to 1 to continue the transaction. At the same time, write 0 to MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit to clear this bit.

| Conditions                  |                             |                        | Suspend/Resume Function |                     |
|-----------------------------|-----------------------------|------------------------|-------------------------|---------------------|
| Host Suspend/Resume Support | Card Suspend/Resume Support | Card Read Wait Support | Write Suspend/Resume    | Read Suspend/Resume |
| Not supported               | Don't care                  | Don't care             | Cannot be used          | Cannot be used      |
| Supported                   | Not supported               | Don't care             | Cannot be used          | Cannot be used      |
| Supported                   | Supported                   | Not supported          | Can be used             | Cannot be used      |
| Supported                   | Supported                   | Supported              | Can be used             | Can be used         |

mmcsd-046

**Figure 12-258. Suspend/Resume Condition**

#### 12.4.5.5.1.12.2 Resume Sequence



mmcsd-047

**Figure 12-259. The Sequence for Resume**

- (1) Restore the register .
- (2) Issue the Resume Command .
- (3) Check the DF value of the response data. If DF is 0, go to step (4). If DF is 1, go to "End".
- (4) Set MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit to 1 for software reset of the DAT line.
- (5) Check MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit. If MMCSD0\_SOFTWARE\_RESET[2] SWRST\_FOR\_DAT bit is 0, go to "End". If it is 1, go to step (5).

#### 12.4.5.5.1.12.3 Stop At Block Gap/Continue Timing for Read Transaction

The timing of Stop At Block Gap Request and Continue Request. The Transfer Complete interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE) is always generated by setting MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit where data transfer is stopped. However, generation of the Block Gap Event interrupt (MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT) is dependent on whether the last data block is sent or not. Block Gap Event is not generated if all data blocks are transferred (the last block is transferred). It is not necessary to enable Block Gap Event interrupt. The status can be checked when transfer complete interrupt is detected. It is not necessary to use Continue Request (MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE) if Block Gap Event status is not set because there is no further data to be transferred. If Read Wait is not supported, Host Controller stops SD Clock at the block gap.

Implementation Note:

The MMCSD0\_BLOCK\_GAP\_CONTROL[2] RDWAIT\_CTRL, MMCSD0\_PRESENTSTATE[2] DATA\_LINE\_ACTIVE, MMCSD0\_PRESENTSTATE[9] RD\_XFER\_ACTIVE bits shall be set and cleared by the Host Controller.

The MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit shall be set and cleared by the Host Driver. The MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit shall be set by the Host Driver and be cleared by the Host Controller. The MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT bit and MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit shall be set by the Host Controller and be cleared by the Host Driver.



mmcsd-048

**Figure 12-260. Wait Read Transfer by Stop At Block Gap Request**

The Host Controller can accept a Stop At Block Gap Request (MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP) when all the following conditions are met.

- (1) It is at the block gap.
- (2) The Host Controller can assert read wait or it is already asserted.
- (3) The MMCSD0\_BLOCK\_GAP\_CONTROL[2] RDWAIT\_CTRL bit is set to 1.

After accepting the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit:

- (1) Clear MMCSD0\_PRESENTSTATE[2] DATA\_LINE\_ACTIVE bit and generate the Block Gap Event Interrupt (MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT).
- (2) After all valid data has been read (No valid read data remains in the Host Controller), clear the MMCSD0\_PRESENTSTATE[9] RD\_XFER\_ACTIVE bit and generate the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE).
- (3) After accepting MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit, clear the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit.



mmcsd-049

**Figure 12-261. Stop At Block Gap Request is Not Accepted at the Last Block of the Read Transfer**

If the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit is set to 1 during the last block transfer, the Host Controller shall not accept the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit and stops the transaction normally. The Block Gap Event Interrupt (MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT) is not generated. When the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE) is generated, and if the MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT bit status is not set to 1, the driver shall clear the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit.



mmcsd-050

**Figure 12-262. Continue Read Transfer by Continue Request**

To restart a stopped data transfer, set the MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit to 1 (the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit shall be set to 0).

After accepting the MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit:

- (1) Release MMCSD0\_BLOCK\_GAP\_CONTROL[2] RDWAIT\_CTRL bit (if the data block can accept the next data).
- (2) Set the MMCSD0\_PRESENTSTATE[2] DATA\_LINE\_ACTIVE bit and the MMCSD0\_PRESENTSTATE[9] RD\_XFER\_ACTIVE bit.
- (3) The MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit is automatically cleared by (2).

The end of the read transfer is specified by data length.

- (1) Clear the MMCSD0\_PRESENTSTATE[2] DATA\_LINE\_ACTIVE bit and do not generate the Block Gap Event Interrupt (MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT bit).

(2) After all valid data has been read (No valid read data remains in the Host Controller), clear the MMCSD0\_PRESENTSTATE[9] RD\_XFER\_ACTIVE bit and generate the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit).

#### 12.4.5.1.12.4 Stop At Block Gap/Continue Timing for Write Transaction



mmcisd-051

**Figure 12-263. Wait Write Transfer by Stop At Block Gap Request**

The Host Controller can accept the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit when matches all following conditions:

(1) It is at the block gap.

(2) No valid write data remains in the Host Controller.

After accepting the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit.

(1) Clear the MMCSD0\_PRESENTSTATE[8] WR\_XFER\_ACTIVE bit and generate the Block Gap Event Interrupt (MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT bit).

(2) After the busy signal is released, clear the MMCSD0\_PRESENTSTATE[2] DATA\_LINE\_ACTIVE bit and generate the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit).

(3) After accepting the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit), clear the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit.



mmcisd-052

**Figure 12-264. Stop At Block Gap Request is Not Accepted at the Last Block of the Write Transfer**

If the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit is set to 1 during the last block transfer, the Host Controller shall not accept the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit and terminates the transaction normally. The Block Gap Event Interrupt (MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVENT) is not generated. When the Transfer

Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE) is generated, and if the MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVEN bit is not set to 1, the driver shall clear the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit.



**Figure 12-265. Continue Write Transfer by Continue Request**

To restart a stopped data transfer, set the MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit to 1 (the MMCSD0\_BLOCK\_GAP\_CONTROL[0] STOP\_AT\_BLK\_GAP bit shall be set to 0).

After accepting the MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit:

(1) Set the MMCSD0\_PRESENTSTATE[2] DATA\_LINE\_ACTIVE bit and MMCSD0\_PRESENTSTATE[8] WR\_XFER\_ACTIVE bit.

(2) The MMCSD0\_BLOCK\_GAP\_CONTROL[1] CONTINUE bit is automatically cleared by (1).

The end of transfer is specified by data length.

(1) Clear the MMCSD0\_PRESENTSTATE[8] WR\_XFER\_ACTIVE bit, and do not generate the (MMCSD0\_NORMAL\_INTR\_STS[2] BLK\_GAP\_EVEN).

(2) After the busy signal is released, clear the MMCSD0\_PRESENTSTATE[2] DATA\_LINE\_ACTIVE bit and generates the Transfer Complete Interrupt (MMCSD0\_NORMAL\_INTR\_STS[1] XFER\_COMPLETE bit).

### 12.4.5.5.2 Driver Flow Sequence

#### Note

UHSII is not supported. For more information, see *Not Supported Features*.

#### 12.4.5.5.2.1 Host Controller Setup and Card Detection

##### 12.4.5.5.2.1.1 Host Controller Setup Sequence

Figure 12-266 and Table 12-247 show a Host Controller setup sequence.



mmcsd-054

**Figure 12-266. Host Controller Setup Sequence**

**Table 12-247. Host Controller Setup Sequence**

| Step | Description                                                                                                                                                        |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Set parameters for all Host Controller version. Set the MMCSD0_POWER_CONTROL[3-1] SD_BUS_VOLTAGE and MMCSD0_TIMEOUT_CONTROL[3-0] COUNTER_VALUE bit fields.         |
| 2    | Read the MMCSD0_HOST_CONTROLLER_VER[7-0] SPEC_VER_NUM bit field.                                                                                                   |
| 3    | If Specification Version number (MMCSD0_HOST_CONTROLLER_VER[7-0] SPEC_VER_NUM) is less than version 3, go to step (4), if it is version 3 or later go to step (5). |
| 4    | Set the MMCSD0_CLOCK_CONTROL register using 8-bit Divided Clock mode.                                                                                              |

**Table 12-247. Host Controller Setup Sequence (continued)**

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | Set Version 3 parameters. The MMCSD0_CLOCK_CONTROL register is sets in 10-bit Divided Clock Mode or Programmable Clock Mode. If Clock Multiplier in the MMCSD0_CAPABILITIES register is not zero, Programmable Clock Mode should be used. If Preset Value is used, set Preset Values of SD I/F Modes in the Preset Value register (MMCSD0_PRESET_VALUE0 - MMCSD0_PRESET_VALUE10) and set the MMCSD0_HOST_CONTROL2[15] PRESET_VALUE_ENA bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6    | If Specification Version number (MMCSD0_HOST_CONTROLLER_VER[7-0] SPEC_VER_NUM) is version 4, go to step (7), if it is less than version 4, exits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7    | Set Version 4 parameters. Set the MMCSD0_HOST_CONTROL2[12] HOST_VER40_ENA bit to 1. If the MMCSD0_CAPABILITIES[27] ADDR_64BIT_SUPPORT_V4 bit is set to 1, set the MMCSD0_HOST_CONTROL2[13] BIT64_ADDRESSING bit to 1. If UHS-II Support is set to 1 and 1.8 V VDD2 Support is set to 1 in the MMCSD0_CAPABILITIES register, set SD Bus Voltage Select for VDD2 to 1.8 V mode in the MMCSD0_POWER_CONTROL register, set preset value for UHS-II Mode to Preset Value register (MMCSD0_PRESET_VALUE0 - MMCSD0_PRESET_VALUE10) and set Timeout Counter Value for CMD_RES and Timeout Counter Value for Deadlock in the MMCSD0_UHS2_TIMER_CONTROL register based on Timeout Clock Frequency and Timeout Clock Unit in the MMCSD0_CAPABILITIES register. If Asynchronous Interrupt Support in the MMCSD0_CAPABILITIES register is set to 1, set Asynchronous Interrupt Enable to 1 in the MMCSD0_HOST_CONTROL2 register. |

#### 12.4.5.5.2.1.2 Card Interface Detection Sequence

This procedure is invoked by the Card Insertion interrupt. [Figure 12-267](#) and [Table 12-248](#) show a card interface detection sequence.


**Figure 12-267. Card Interface Detection Sequence**
**Table 12-248. Card Interface Detection Sequence**

| Step | Description                                                                                                                                                                                                                                                                          |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Set Internal Clock Enable to 1 in the MMCSD0_CLOCK_CONTROL register.                                                                                                                                                                                                                 |
| 2    | Wait until Internal Clock Stable is set to 1 in the MMCSD0_CLOCK_CONTROL register.                                                                                                                                                                                                   |
| 3    | If Host Supports UHS-II, go to step (4) else go to step (12).                                                                                                                                                                                                                        |
| 4    | Try to initialize a card to UHS-II mode. Set UHS-II Interface Enable to 1 in the MMCSD0_HOST_CONTROL2 register, set SD Bus Power for VDD1 and SD Bus Power for VDD2 to 1 in the MMCSD0_POWER_CONTROL register, and set UHS Mode Select to 111b in the MMCSD0_HOST_CONTROL2 register. |

Table 12-248. Card Interface Detection Sequence (continued)

| Step | Description                                                                                                                                                                                                                                                  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | Wait power ramp up time. It is dependent on a Host System.                                                                                                                                                                                                   |
| 6    | Set SD Clock Enable to 1 in the MMCSD0_CLOCK_CONTROL register.                                                                                                                                                                                               |
| 7    | Wait 200 $\mu$ s to check a card supports UHS-II mode.                                                                                                                                                                                                       |
| 8    | Check STB.L Detection in the MMCSD0_PRESENTSTATE register. If UHS-II IF is detected, go to step (9). If UHS-II IF is not detected, go to step (11).                                                                                                          |
| 9    | Wait until Lane Synchronization in the MMCSD0_PRESENTSTATE register is set to 1 (PHY Initialization is completed).                                                                                                                                           |
| 10   | Perform UHS-II initialization.                                                                                                                                                                                                                               |
| 11   | Perform card power cycle.                                                                                                                                                                                                                                    |
| 12   | Try to initialize a card to SD 4-bit mode. Set UHS-II Interface Enable to 0 in the MMCSD0_HOST_CONTROL2 register, set SD Bus Power for VDD1 to 1 in the MMCSD0_POWER_CONTROL register, and set UHS Mode Select to 000b in the MMCSD0_HOST_CONTROL2 register. |
| 13   | Wait power ramp up time. It is dependent on a Host System.                                                                                                                                                                                                   |
| 14   | Set SD Clock Enable to 1 in the MMCSD0_CLOCK_CONTROL register.                                                                                                                                                                                               |
| 15   | Perform SD 4-bit mode initialization. Refer to <a href="#">Section 12.4.5.5.1.6, Card Initialization and Identification (for SD I/F)</a> .                                                                                                                   |

#### 12.4.5.5.2.2 Boot Operation

The boot operation sequence is shown in [Figure 12-268](#).


mmcsd-056

**Figure 12-268. Boot Operation Sequence**

#### 12.4.5.5.2.2.1 Normal Boot Operation: (For Legacy eMMC 5.0)

The Host driver writes the boot timeout value into MMCSD0\_BOOT\_TIMEOUT\_CONTROL register as per the eMMC4.3+ spec.

When the Host driver sets the "BOOT\_ENABLE" to 1 in MMCSD0\_BLOCK\_GAP\_CONTROL register and "DATA\_XFER\_DIR" bit to "1" in MMCSD0\_TRANSFER\_MODE register, the Host controller drives the CMD line to "0" for boot operation.

If the Host controller is configured to wait for boot acknowledgement from the eMMC4.3+ device, the controller receives the boot acknowledgement and asserts the "RCV\_BOOT\_ACK" interrupt to the driver

(MMCSD0\_NORMAL\_INTR\_STS[13] RCV\_BOOT\_ACK). If the Host controller doesn't receive the boot acknowledgement from the device within the timeout value, the Host controller will assert the data timeout error interrupt (MMCSD0\_ERROR\_INTR\_STS[4] DATA\_TIMEOUT).

After servicing the boot acknowledge interrupt or data timeout error interrupt, the driver programs the MMCSD0\_BOOT\_TIMEOUT\_CONTROL register with boot data timeout value.

The eMMC4.3+ device starts sending the boot data on the data line and Host controller sends the same to system whenever a block of data is received from device. The Host controller terminates the boot operation when the programmed number of blocks is transferred to the System. The Driver can writes "BOOT\_ENABLE" as "0" in MMCSD0\_BLOCK\_GAP\_CONTROL register.

The boot operation can also be terminated in between the boot transfer (the Driver can set the "BOOT\_ENABLE" as "0" anytime to disable the boot operation). After the boot termination, the Host controller asserts soft reset for CMD line and DATA line internally once the driver clears the BOOT\_COMPLETE interrupt (MMCSD0\_NORMAL\_INTR\_STS[14] BOOT\_COMPLETE), to reset all the state machines to idle state.

There is no need to perform error recovery sequence in case data timeout interrupt occurs during boot operation (ignore sending abort command, soft reset and just clear the timeout interrupt and proceed with the boot flow).

If the device sends wrong acknowledgement to the Host, the Host controller will assert Data CRC Error interrupt (MMCSD0\_ERROR\_INTR\_STS[5] DATA\_CRC) on the Driver. In this case, the Host driver has to stop the boot mode operation by setting "BOOT\_ENABLE" as "0" in MMCSD0\_BLOCK\_GAP\_CONTROL register and write soft reset for CMD and data line.

If the device sends end bit as "0" in acknowledgement to the Host, the Host controller will assert Data End Bit Error interrupt (MMCSD0\_ERROR\_INTR\_STS[6] DATA\_ENDBIT) on the Driver.

The Host driver stops the boot mode operation by setting "BOOT\_ENABLE" as "0" in MMCSD0\_BLOCK\_GAP\_CONTROL register and write soft reset for CMD and data line.

**Note:** Enable the MMCSD0\_BLOCK\_GAP\_CONTROL[7] BOOT\_ACK\_ENA bit during boot operation. If failed, the controller will not wait for boot acknowledge from the card and send out data CRC error when the card sends boot acknowledgement first and followed by boot data.

#### **12.4.5.5.2.2 Alternate Boot Operation (For Legacy eMMC 5.0):**

The Host driver writes the boot timeout value as per the eMMC4.3+ spec into MMCSD0\_BOOT\_TIMEOUT\_CONTROL register.

If the "ALT\_BOOT\_MODE" and "BOOT\_ENABLE" is set to 1 in MMCSD0\_BLOCK\_GAP\_CONTROL register and "DATA\_XFER\_DIR" bit is set to 1 in MMCSD0\_TRANSFER\_MODE register, the host controller drives the CMD0 (0xFFFFFFFFFA) on the CMD line.

The system shall wait for command complete interrupt before "RCV\_BOOT\_ACK" interrupt (MMCSD0\_NORMAL\_INTR\_STS[13] RCV\_BOOT\_ACK).

If the Host controller is configured to wait for boot acknowledgement from the eMMC4.3+ device, the controller receives the boot acknowledgement and asserts the "RCV\_BOOT\_ACK" interrupt to the driver.

The eMMC4.3+ device starts sending the boot data on the data line and Host controller sends the same to system whenever a block of data is received from device. The System needs to send CMD0 to inform the device about the boot operation complete. The system shall program MMCSD0\_COMMAND register with argument "00000000h" for the CMD0 and waits for command complete.

The Host controller terminates the boot operation when the programmed number of blocks are transferred to the System and the Driver shall send CMD0 to eMMC card and then program "BOOT\_ENABLE" as "0" in MMCSD0\_BLOCK\_GAP\_CONTROL register.

The boot operation can be terminated at any time (the Driver can send CMD0 and set the "BOOT\_ENABLE" as "0" anytime to disable the boot operation). After the boot termination, all state machines in the Host controller need to move to IDLE state. The Host controller asserts the soft reset for CMD and data line internally when the

driver clears the BOOT\_COMPLETE interrupt (MMCSD0\_NORMAL\_INTR\_STS[14] BOOT\_COMPLETE) and all the state machine goes to the idle state.

If the Host controller doesn't receive the acknowledgement from the device with in timeout value the Host controller will assert the data timeout error interrupt (MMCSD0\_ERROR\_INTR\_STS[4] DATA\_TIMEOUT).

The driver programs the MMCSD0\_BOOT\_TIMEOUT\_CONTROL register with boot data timeout value.

There is no need to perform error recovery sequence in case of data timeout interrupt as mentioned above. If the device sends wrong acknowledgement to the Host, then Host controller will assert Data CRC Error interrupt to the Driver (MMCSD0\_ERROR\_INTR\_STS[5] DATA\_CRC). The Host driver has to stop the boot mode operation by setting "ALT\_BOOT\_MODE" and "BOOT\_ENABLE" as "0" in MMCSD0\_BLOCK\_GAP\_CONTROL register and write soft reset for CMD and data line.

If the device sends end bit as "0" in acknowledgement to the Host, the Host controller asserts Data End Bit Error interrupt (MMCSD0\_ERROR\_INTR\_STS[6] DATA\_ENDBIT) on the Driver. The Host driver stops the boot mode operation by setting "ALT\_BOOT\_MODE" and "BOOT\_ENABLE" as "0" in MMCSD0\_BLOCK\_GAP\_CONTROL register and write soft reset for CMD and data line.

**Note:** Enable the MMCSD0\_BLOCK\_GAP\_CONTROL[7] BOOT\_ACK\_ENA bit during boot operation . If failed, the controller will not wait for boot acknowledge from the card and send out data CRC error when the card sends boot acknowledgement first and followed by boot data.

#### **12.4.5.2.2.3 Boot Code Chunk Read Operation (For Legacy eMMC 5.0):**

The following figure explains the boot code read done as chunks of data (the Driver can read the boot data as 2K, 4K, 1K and 8K etc. instead of 128K at a time



mmcisd-057

**Figure 12-269. Boot Code Access Flow Diagram (1)**



mmcsd-058

**Figure 12-270. Boot Code Access Flow Diagram (2)**

#### 12.4.5.5.2.3 Retuning procedure (For Legacy Interface)

##### 12.4.5.5.2.3.1 Sampling Clock Tuning

The SD bus can be operating in high clock frequency mode and then the data window from the card on CMD and DAT[3:0] lines gets smaller. The position of the data window will vary depending on the card and host system implementation. Therefore, the Host Controller shall support a tuning circuit when SDR104 or SDR50.

The Host Controller shall support a tuning circuit when SDR104 or SDR50 (if Use Tuning for SDR50 is set to 1 in the MMCSD0\_CAPABILITIES register) is supported by executing the tuning procedure and adjusting the sampling clock. Execute Tuning and Sampling Clock Select in the MMCSD0\_HOST\_CONTROL2 register are used to control the tuning circuit.

See [MMC SW Tuning Algorithm](#) for more information.

##### 12.4.5.5.2.3.2 Tuning Sequence

The [Figure 12-271](#) defines sampling clock tuning procedure supported by Host Controller. In default, for lower frequency operation, fixed sampling clock is used to receive signals on CMD and DAT[3:0]. Before using

SDR104, sampling clock tuning is required. Start of sampling clock tuning is requested by setting Execute Tuning to 1 and Sampling Clock Select to 0.



Figure 12-271. MMCSD Clock Tuning

Host driver issue CMD19 repeatedly until the host controller resets Execute Tuning to 0. Host Controller resets Execute Tuning to 0 when tuning is completed or tuning is not completed within 40 times. Host Driver can abort this loop by 40 times CMD19 issue or 150 ms time-out.

If tuning is completed successfully, Host Controller set Sampling Clock Select to 1 and this means the Host Controller start to use tuned sampling clock. If tuning is failed, Host Controller keeps Sampling Clock Select to 0. By writing Sampling Clock Select to 0, sampling clock is switched from tuned sampling clock to fixed sampling clock. Re-tuning time would be smaller than the first tuning time. CMD19 response errors are not indicated while tuning is performed.

The clock tuning tap delay values are selected using Variable sampling point detection. Fixed tap delay value is used for fixed tuning clock method.

#### 12.4.5.5.2.3.3 Re-Tuning Modes

The re-tuning timing is specified by two methods: Re-Tuning Request generated by Host Controller and expiration of a re-tuning timer prepared by Host Driver.

(1) Re-Tuning Mode 1 The host controller does not have any internal logic to detect when the re-tuning needs to be performed. In this case, the Host Driver should maintain all re-tuning timings by using a Re-Tuning Timer. To enable inserting the re-tuning procedure during data transfers, the data length per read/write command shall be limited up to 4 MB.

(2) Re-Tuning Mode 2 The host controller has the capability to indicate the re-tuning timing by Re-Tuning Request during data transfers. Then the data length per read/write command shall be limited up to 4 MB. During non data transfer, re-tuning timing is determined by either Re-Tuning Request or Re-Tuning Timer. If Re-Tuning Request is used, Re-Tuning Timer should be disabled.

#### 12.4.5.5.2.4 Command Queuing Driver Flow Sequence

##### 12.4.5.5.2.4.1 Command Queuing Initialization Sequence

Figure 12-272 and Table 12-249 show a Command Queuing initialization sequence.



mmcsd-060

**Figure 12-272. Command Queuing Initialization Sequence**

**Table 12-249. Command Queuing Initialization Sequence**

| Step | Description                                                                                                                                         |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Initialize and enable Command Queueing in the device.                                                                                               |
| 2    | Configure Task Descriptor size in MMCSD0_CQ_CONFIG register.                                                                                        |
| 3    | Configure MMCSD0_CQ_TDL_BASE_ADDR and MMCSD0_CQ_TDL_BASE_UPBITS registers to point to the memory location allocated to the TDL in host memory.      |
| 4    | Configure CQSST and CQSSBC to control when SEND_QUEUE_STATUS commands are sent to the device by CQE.                                                |
| 5    | Configure MMCSD0_CQ_INTR_COALESCING register to control the interrupt coalescing feature: enable/disable, set interrupt count and timer protection. |
| 6    | Configure MMCSD0_CQ_RESP_ERR_MASK register to control which errors may trigger a RED interrupt (if different from reset values).                    |
| 7    | Write '1' to MMCSD0_CQ_CONFIG register to enable CQE activity.                                                                                      |

**12.4.5.5.2.4.2 Task Issuance Sequence**

Figure 12-273 and Table 12-250 show a task issuance sequence.


**Figure 12-273. Task Issuance Sequence**
**Table 12-250. Task Issuance Sequence**

| Step | Description                                                                                                                                                                                          |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Find an empty transfer request slot by reading the MMCSD0_CQ_TASK_DOOR_BELL register. An empty transfer request slot has its respective bit cleared to '0' in the MMCSD0_CQ_TASK_DOOR_BELL register. |

**Table 12-250. Task Issuance Sequence (continued)**

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | Build a Task Descriptor at the 1st entry of the empty slot. Task Descriptor field values: <ul style="list-style-type: none"> <li>1. Valid = 1, to indicate the descriptor is effective.</li> <li>2. End = 1, as required for Task Descriptors.</li> <li>3. Int = 1, if an interrupt on completion is required. Otherwise, Int = 0.</li> <li>4. Act = b101, to indicate a Task Descriptor.</li> <li>5. Data Direction = 1 for read commands, and 0 for write commands.</li> <li>6. Priority = 1 for high priority, and 0 for simple requests.</li> <li>7. QBR = 1 if Queue Barrier functionality is required. 0 otherwise.</li> <li>8. Forced Programming, Context ID, Tag Request, Reliable Write, Block Count, and Block Address programmed according to application requirements.</li> </ul> |
| 3    | Build a Transfer Descriptor at the 2nd entry of the empty slot. Transfer Descriptor field values: <ul style="list-style-type: none"> <li>1. Valid = 1, to indicate the descriptor is effective.</li> <li>2. End = 1, if a TRAN descriptor is used, to indicate the task only has one data buffer. End = 0 if LINK descriptor is used.</li> <li>3. Int = 0. Ignore in Command queueing.</li> <li>4. Act = b100, for TRAN descriptors, pointing directly to the task's single data buffer. Act = 401 b110, for LINK descriptors, point to a scatter/gather list (indirect).</li> <li>5. Address and Length programmed according to the data buffer supplied by the application.</li> </ul>                                                                                                       |
| 4    | If more than one transfer is requested, repeat step 1-3 for all needed transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5    | Set MMCSD0_CQ_TASK_DOOR_BELL register to indicate to the CQE that one or more transfer requests are ready to be sent to the attached device. Host software shall only write a '1' to the bit position that corresponds to new tasks; all other bit positions within MMCSD0_CQ_TASK_DOOR_BELL register should be written with a '0', which indicates no change to their current values.                                                                                                                                                                                                                                                                                                                                                                                                         |

#### **12.4.5.2.4.3 Task Execution and Completion Sequence**

The CQE is responsible for task execution, communication with the device and moving the data to the buffers in the host memory.

Figure 12-274 and Table 12-251 show a task execution and completion sequence.



**Figure 12-274. Task Execution and Completion Sequence**

**Table 12-251. Task Execution and Completion Sequence**

| Step | Description                                                                                                                                                                                                                                             |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Once the tasks are queued on the device side CQE sends CMD13 to determine the queue status. The queue status lets the CQE know which tasks are ready for execution.                                                                                     |
| 2    | The response to CMD13 may indicate no task is ready in which case the CQE is required to send CMD13 again at a later time as controlled CQSST register.                                                                                                 |
| 3    | If a task is ready for execution then the host sends EXECUTE_READ_TASK (CMD46) or EXECUTE_WRITE_TASK (CMD47) to the device with the task id ordering it to execute a task.                                                                              |
| 4    | When the task execution is completed, an interrupt may be generated, if requested, or as determined by Interrupt Coalescing mechanism.                                                                                                                  |
| 5    | The host software reads MMCSDO_CQ_TASK_COMP_NOTIF register to determine which task(s) has(have) been completed. Each bit set in MMCSDO_CQ_TASK_COMP_NOTIF register represents by index which task has completed but hasn't yet been served by software. |
| 6    | For every task completed clear the appropriate MMCSDO_CQ_TASK_COMP_NOTIF register bit.                                                                                                                                                                  |
| 7    | Repeat steps 1-6 for the pending tasks.                                                                                                                                                                                                                 |

#### 12.4.5.2.4.4 Task Discard and Clear Sequence

Figure 12-275 and Table 12-252 show a task discard and clear sequence.



**Figure 12-275. Task Discard and Clear Sequence**

**Table 12-252. Task Discard and Clear Sequence**

| Step | Description                                                                                  |
|------|----------------------------------------------------------------------------------------------|
| 1    | While CQE is enabled write '1' to MMCSD0_CQ_CONTROL[0] HALT_BIT bit to halt CQE.             |
| 2    | Poll on MMCSD0_CQ_INTR_STS[0] HALT_COMPLETE bit.                                             |
| 3    | Read MMCSD0_CQ_TASK_DOOR_BELL register to determine if the task to be discarded is set to 1. |
| 4    | Read MMCSD0_CQ_DEV_PENDING_TASKS register to check if the task is queued in the device.      |
| 5    | Send CMDQ_TASK_MGMT(CMD48) to discard task using the task id as the argument.                |
| 6    | Write '1' to CQCTLCLR[i] to clear task in CQE.                                               |

Table 12-252. Task Discard and Clear Sequence (continued)

| Step | Description                                            |
|------|--------------------------------------------------------|
| 7    | Poll on CQCTL[i] until it is '0'.                      |
| 8    | Write '0' to MMCSD0_CQ_CONTROL register to resume CQE. |

#### 12.4.5.5.2.4.5 Error Detect and Recovery when CQ is enabled

Figure 12-276 and Table 12-253 show an error detect and recovery sequence.



Figure 12-276. Error Detect and Recovery Sequence

Table 12-253. Error Detect and Recovery Sequence

| Step | Description                                                                                                                                                                |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Read eMMC host controller MMCSD0_ERROR_INTR_STS register and determine error is related to CQE.                                                                            |
| 2    | Write '1' to MMCSD0_CQ_CONTROL[0] HALT_BIT bit to halt CQE.                                                                                                                |
| 3    | Wait for MMCSD0_CQ_CONTROL[0] HALT_BIT bit to read '1'. In some error cases, this may not happen, so software should proceed to the next step after a sufficient time-out. |

**Table 12-253. Error Detect and Recovery Sequence (continued)**

| Step | Description                                                                                                                          |
|------|--------------------------------------------------------------------------------------------------------------------------------------|
| 4    | Read MMCSD0_CQ_CMD_RESP_INDEX and MMCSD0_CQ_CMD_RESP_ARG registers to determine last response's index and argument.                  |
| 5    | Read MMCSD0_CQ_TASK_ERR_INFO register to determine the transmitted command's index and the index of the task to which it is related. |
| 6    | Perform error-specific recovery procedure.                                                                                           |
| 7    | Write '0' to MMCSD0_CQ_CONTROL register to resume operation.                                                                         |

## 12.5 Industrial and Control Interfaces

This section describes the industrial and control interfaces in the device.

### 12.5.1 Modular Controller Area Network (MCAN)

This section describes the Modular Controller Area Network (MCAN) modules in the device.

#### 12.5.1.1 MCAN Overview

The Controller Area Network (CAN) is a serial communications protocol which efficiently supports distributed real-time control. CAN has high immunity to electrical interference. In a CAN network, many short messages are broadcast to the entire network, which provides for data consistency in every node of the system.

The MCAN module supports both classic CAN and CAN FD (CAN with Flexible Data-Rate) specifications. CAN FD feature allows high throughput and increased payload per data frame. The classic CAN and CAN FD devices can coexist on the same network without any conflict.

They connect to the physical layer of the CAN network through external (for the device) transceivers. Each MCAN module supports flexible bit rates greater than 1 Mbps and is compliant to ISO 11898-1:2015.

Figure 12-277 shows the MCAN modules overview.



A.  $x = 0$  to number of MCAN in a domain -1

**Figure 12-277. MCAN Modules Overview**

#### 12.5.1.1.1 MCAN Features

Each MCAN module implements the following features:

- Conforms with CAN Protocol 2.0 A, B and ISO 11898-1:2015
- Full CAN FD support (up to 64 data bytes)
- SAE J1939 support
- AUTOSAR support
- Up to 32 dedicated Transmit Buffers
- Configurable Transmit FIFO, up to 32 elements
- Configurable Transmit Queue, up to 32 elements

- Configurable Transmit Event FIFO, up to 32 elements
- Up to 64 dedicated Receive Buffers
- Two configurable Receive FIFOs, up to 64 elements each
- Up to 128 filter elements
- Internal Loopback mode for self-test
- Maskable interrupts, two interrupt lines
- Two clock domains (CAN clock/Host clock)
- Parity/ECC support - Message RAM single error correction and double error detection (SECDED) mechanism
- Local power-down and wakeup support
- Timestamp Counter

#### 12.5.1.1.2 *Unsupported Features*

See the *Module Integration* section for information about unsupported features.

---

##### Note

Some features may not be available. See *Module Integration* for more information.

---

### 12.5.1.2 MCAN Environment

This section describes the MCAN external connections (environment).

CAN network physical layer consists of two-wire differential bus, usually twisted pair, and provides high level of interference immunity. External CAN transceiver IC is needed to access a CAN bus by the MCAN.

Figure 12-278 shows the MCAN typical application.



**Figure 12-278. MCAN Typical Application**

Table 12-254 describes the MCAN I/O signals.

**Table 12-254. MCAN I/O Signals**

| Module Pin                 | Device Level Signal      | I/O <sup>(1)</sup> | Description                                     | Module Pin<br>Reset Value <sup>(1)</sup> |
|----------------------------|--------------------------|--------------------|-------------------------------------------------|------------------------------------------|
| <b>MCANI<sup>(2)</sup></b> |                          |                    |                                                 |                                          |
| RX                         | MCANI <sup>(2)</sup> _RX | I                  | Serial data input from external CAN transceiver | HiZ                                      |
| TX                         | MCANI <sup>(2)</sup> _TX | O                  | Serial data output to external CAN transceiver  | 1                                        |

(1) I = Input; O = Output; HiZ = High Impedance

(2) i represents an MCAN instance. See the device datasheet for available domains and MCAN instances.

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables Pin Attributes and Pin Multiplexing in the device-specific Datasheet.

#### 12.5.1.2.1 CAN Network Basics

- CAN bus is a 2-wire differential bus using Non-Return-to-Zero (NRZ) encoding and has two states:
  - Recessive state (logical 1)
  - Dominant state (logical 0)
- The network is multicontroller. When two or more nodes (ECUs) attempt to transmit at the same time, a non-destructive arbitration technique guarantees messages are sent in order of priority and no messages are lost.
- The message transmission is multicast. Data messages transmitted are identifier based, not address based.
- Content of message is labeled by the identifier that is unique throughout the network (for example: rpm, temperature, position, pressure, and so forth).
- All nodes on network receive the message and each performs an acceptance test on the identifier. If message is relevant, it is processed, otherwise it is ignored.
- The unique identifier also determines the priority of the message (the lower the numerical value of the identifier, the higher the priority is).
- Data is transmitted and received using message frames, consisting of the following basic fields:
  - Arbitration field
  - Control field
  - Data field (up to 8 bytes for Classical CAN and up to 64 bytes for CAN FD)
  - CRC field
  - ACK field

For more information, see *ISO 11898-1:2015: CAN data link layer and physical signaling*.

#### 12.5.1.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.5.1.4 MCAN Functional Description

The MCAN module performs CAN protocol communication according to ISO 11898-1:2015. The bit rate can be programmed to values greater than 1 Mbps. Additional transceiver hardware is required for the connection to the physical layer (CAN bus).

For communication on a CAN network, individual message frames can be configured. The message frames and identifier masks are stored in the Message RAM.

All functions concerning the handling of messages are implemented in the Message Handler.

The register set of the MCAN module can be accessed directly via the module interface. These registers are used to control and configure the CAN core and the Message Handler, and to access the Message RAM.

Figure 12-279 shows the MCAN module block diagram.



mcan-004

**Figure 12-279. MCAN Block Diagram**

The MCAN module blocks description:

- **CAN Core:** the CAN core consists of the CAN protocol controller and the Rx/Tx shift register. It handles all ISO 11898-1:2015 protocol functions and supports 11-bit and 29-bit identifiers.
- **Message Handler:** the Message Handler (Rx Handler and Tx Handler) is a state machine that controls the data transfer between the single-ported Message RAM and the CAN core's Rx/Tx shift register. It also handles the acceptance filtering and the Interrupt/DMA request generation as programmed in the control registers.
- **Message RAM:** the main purpose of the Message RAM is to store Rx/Tx messages, Tx Event elements, and Message ID Filter elements (for more information, see [Section 12.5.1.4.10, Message RAM](#)).
- **Message RAM Interface:** enables connection between the Message RAM and the other blocks in the MCAN module.
- **Registers and Message Object Access:** data consistency is ensured by indirect accesses to the message objects. The interface registers have the same word-length as the Message RAM.

- **Module Interface:** provides connection to the Registers and Message Object Access block and Message RAM Interface block
- **Clocking:** two clocks are provided to the MCAN module: the peripheral synchronous clock (interface clock ICLK) and the peripheral asynchronous clock (functional clock - FCLK). For more information, see *Module Integration*.
- **Extension Interface:** this interface is used for DMA requests signaling (see [Section 12.5.1.4.2.2](#)).

#### 12.5.1.4.1 Module Clocking Requirements

Two clocks are provided to the MCAN module:

- the peripheral synchronous clock (ICLK) as the general module clock source
- and the peripheral asynchronous clock (FCLK) provided to the CAN core for generating the CAN bit timing.

Within the MCAN module there is a synchronization mechanism implemented to ensure safe data transfer between the two clock domains. There is synchronization between the signals from the Host clock domain to the CAN clock domain and vice versa and between the reset signal to the Host clock domain and to the CAN clock domain.

---

#### Note

ICLK must always be higher or equal to FCLK, in order to achieve a stable functionality of the MCAN module. Here, also the frequency shift of the modulated ICLK has to be considered:

$$f_{0, \text{ICLK}} \pm \Delta f_{\text{FM, ICLK}} \geq f_{\text{FCLK}}$$


---

For more information on how to configure the relevant clock source registers, see *Clocking* and the device-specific Datasheet.

#### 12.5.1.4.2 Interrupt and DMA Requests

The MCAN module provides interrupt and DMA requests. They are configured via the Host CPU. The Suspend Mode is requesting or forcing (based on MCANSS\_CTRL[3] DBGSUSP\_FREE bit) the MCAN module to go into initialization mode (see MCAN\_CCCR[0] INIT bit) in which new interrupts and DMA requests will not be issued, that is to prevents the interrupt and DMA requests from propagating to the Host CPU (for more information, see [Section 12.5.1.4.3.8.2, Suspend Mode](#)).

##### 12.5.1.4.2.1 Interrupt Requests

The MCAN module has two interrupt lines. There are 30 internal interrupt sources. Each source can be configured to drive one of the two interrupt lines. The interrupts are 'level high' interrupts.

The MCAN core provides two interrupt requests (for Line 0 and Line 1).

For more information, see the following registers:

- Interrupt Register (MCAN\_IR)
- Interrupt Enable (MCAN\_IE)
- Interrupt Line Select (MCAN\_ILS)
- Interrupt Line Enable (MCAN\_IIE)

The MCAN module is capable of issuing ECC interrupts. After clearing the ECC interrupt source, the application software must also write 1 to EOI register (MCANSS\_ECC\_SEC\_EOI\_REG/MCANSS\_ECCDED\_EOI\_REG). For more information, see *ECC Aggregator*.

The MCAN module supports External Timestamp Counter. When the External Timestamp Counter rolls over it produces an interrupt (see [Section 12.5.1.4.4.1, External Timestamp Counter](#)).

For more information, see the following registers:

- Interrupt Clear Shadow Register (MCANSS\_ICS)
- Interrupt Raw Status Register (MCANSS IRS)
- Interrupt Enable Clear Shadow Register (MCANSS\_IIECS)

- Interrupt Enable Register (MCANSS\_IE)
- Interrupt Enable Status Register (MCANSSIES)
- End Of Interrupt Register (MCANSS\_EOI)
- External Timestamp Prescaler Register (MCANSS\_EXT\_TS\_PRESCALER)
- External Timestamp Unserviced Interrupts Counter Register (MCANSS\_EXT\_TS\_UNSERVICED\_INTR\_CNTR)

For more information about available Interrupt Requests, see *MCAN Hardware Requests*.

#### **12.5.1.4.2.2 DMA Requests**

Functional transmit and Filter DMA requests are generated by the MCAN module based on the signaling in the Extension Interface. The DMA signaling uses a simple DMA request active high pulse.

The active high pulse indicates a pending message is transmitted (see MCAN\_TXBRP). This pulse can be used to transfer another message to the Tx Buffer, which would need to be followed by writing 1 to the corresponding MCAN\_TXBAR[0] AR bit to mark a new Tx message pending transmission.

The Parity on Tx DMA Events is available using an EDC Controller which can be accessed through the ECC Aggregator.

Standard and Extended message filters can be set to issue a pulse when a filter match occurs. These 'Filter Events' can be used to DMA messages from the Rx FIFO. The events are high level single clock cycle pulses (ICLK).

#### **12.5.1.4.3 Operating Modes**

##### **12.5.1.4.3.1 Software Initialization**

Setting the MCAN\_CCCR[0] INIT bit to 1 starts a software initialization. This is done either by software or by a hardware reset, when an uncorrected bit error was detected in the Message RAM, or by going Bus\_Off state. While the MCAN\_CCCR[0] INIT bit is set, the message transfer is stopped and the status of the output TX pin is recessive (high). The counters of the Error Management Logic (EML) are unchanged. Setting the MCAN\_CCCR[0] INIT bit does not change any configuration register. Resetting the MCAN\_CCCR[0] INIT bit finishes the software initialization. After waiting for the occurrence of a sequence of 11 consecutive recessive bits (indication for Bus\_Idle state) the message transfer starts.

Access to the MCAN configuration registers is only enabled when both MCAN\_CCCR[0] INIT and MCAN\_CCCR[1] CCE bits are set (write protection).

The MCAN\_CCCR[1] CCE bit can only be set/reset while the MCAN\_CCCR[0] INIT = 1. The MCAN\_CCCR[1] CCE bit is automatically reset when the MCAN\_CCCR[0] INIT bit is reset.

The following registers are reset when the MCAN\_CCCR[1] CCE bit is set:

- MCAN\_HPM - High Priority Message Status
- MCAN\_RXF0S - Rx FIFO 0 Status
- MCAN\_RXF1S - Rx FIFO 1 Status
- MCAN\_TXFQS - Tx FIFO/Queue Status
- MCAN\_TXBRP - Tx Buffer Request Pending
- MCAN\_TXBTO - Tx Buffer Transmission Occurred
- MCAN\_TXBCF - Tx Buffer Cancellation Finished
- MCAN\_TXEFS - Tx Event FIFO Status

The Timeout Counter value MCAN\_TOCV[15-0] TOC field is preset to the value configured by the MCAN\_TOCC[31-16] TOP field when the MCAN\_CCCR[1] CCE bit is set.

In addition the Tx Handler and Rx Handler are held in idle state while MCAN\_CCCR[1] CCE = 1.

The following registers are only writeable while MCAN\_CCCR[1] CCE = 0

- MCAN\_TXBAR - Tx Buffer Add Request
- MCAN\_TXBCR - Tx Buffer Cancellation Request

MCAN\_CCCR[7] TEST and MCAN\_CCCR[5] MON bits can only be set by the Host CPU while MCAN\_CCCR[0] INIT = 1 and MCAN\_CCCR[1] CCE = 1. Both bits may be reset at any time. The MCAN\_CCCR[6] DAR bit can only be set/reset while MCAN\_CCCR[0] INIT = 1 and MCAN\_CCCR[1] CCE = 1.

Table 12-255 shows the steps to configure the MCAN module.

**Table 12-255. Steps to Configure MCAN Module**

| Step | Operation                              | Description                                                                    | Pseudo Code                                                             |
|------|----------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| 1    | Initialize MCAN_CCCR                   | Set MCAN_CCCR[0] INIT bit and check that it has been set                       | INIT = 1;<br>If INIT ≠ 1, wait until it is                              |
| 2    | Unlock protected registers             | Set MCAN_CCCR[1] CCE bit                                                       | CCE = 1;                                                                |
| 3    | Configure CAN mode                     | Set MCAN_CCCR[8] FDOE bit to CAN FD<br>FDOE = 1 for CAN FD<br>FDOE = 0 for CAN |                                                                         |
| 4    | Configure Bit Rate Switching           | Set MCAN_CCCR[9] BRSE bit                                                      | BRSE = 1 with bit rate switching<br>BRSE = 0 without bit rate switching |
| 5    | Set bit timing                         | Set MCAN_NBTP register                                                         |                                                                         |
| 6    | Lock protected registers               | Clear MCAN_CCCR[1] CCE bit                                                     | CCE = 0;                                                                |
| 7    | Return MCAN module to normal operation | Clear MCAN_CCCR[0] INIT bit and check it has been cleared                      | INIT = 0;<br>If INIT ≠ 0, wait until it is                              |

#### 12.5.1.4.3.2 Normal Operation

Once the MCAN module is initialized and the MCAN\_CCCR[0] INIT bit is reset to zero, the MCAN module synchronizes itself to the CAN bus and is ready for communication. After passing the acceptance filtering, received messages including Message Identifier (ID) and Data Length Code (DLC) are stored into a dedicated Rx Buffer or into Rx FIFO 0/Rx FIFO 1.

For messages to be transmitted dedicated Tx Buffers and/or a Tx FIFO or a Tx Queue can be initialized or updated.

---

#### Note

Automated transmission on reception of remote frames is not supported.

---

#### 12.5.1.4.3.3 CAN FD Operation

The CAN FD standard allows extended frames to be sent, up to 64 data bytes in a single frame at a higher bit rate for the data phase of a frame, up to 8 Mbps. The CAN FD standard introduces the ability to switch from one bit rate to another. Extended Data Length (EDL), as shown in Figure 12-280, sets a data length of up to 8 or up to 64 data bytes. Bit Rate Switching (BRS) indicates whether two bit rates (the data phase is transmitted at a different bit rate to the arbitration phase) are enabled.



\* 17 bit CRC for data fields with up to 16 bytes

mcan-004a

**Figure 12-280. CAN FD Frame**

#### Note

Figure 12-280 presents CAN FD frame according to the Non-ISO CAN FD (legacy) protocol. In the new ISO CAN FD protocol the CRC Field includes additional 5 bits (three stuff bit counter (SBC) bits and two parity bits). With these additional bits, a weakness identified in the error detection scheme chosen by the original protocol is removed. By setting MCAN\_CCCR[15] NISO bit, the ISO or Non-ISO CAN FD format can be chosen. In CAN network ISO CAN FD and non-ISO CAN FD devices should never mix.

There are two variants of CAN FD frame transmission:

- CAN FD frame transmission without bit rate switching
- CAN FD frame transmission where control field, data field, and CRC field are transmitted with a higher bit rate than the beginning and the end of the frame

In the CAN frames FDF = recessive (logical 1) signifies a CAN FD frame, FDF = dominant (logical 0) signifies a Classic CAN frame. In a CAN FD frame, the two bits following FDF - res and BRS, decide whether the bit rate inside of this CAN FD frame is switched. A CAN FD bit rate switch is signified by res = dominant and BRS = recessive. Note that the coding of res = recessive is reserved for future expansion of the protocol.

In case the MCAN module receives a frame with FDF = recessive and res = recessive, it will signal a Protocol Exception Event by setting the MCAN\_PSR[14] EXE bit. When Protocol Exception Handling is enabled (MCAN\_CCCR[12] PXHD = 0), this causes the operation state to change from Receiver (MCAN\_PSR[4-3] ACT = 10) to Integrating (MCAN\_PSR[4-3] ACT = 00) at the next sample point. In case Protocol Exception Handling is disabled (MCAN\_CCCR[12] PXHD = 1), the MCAN will treat a recessive res bit as an form error and will respond with an error frame.

CAN FD operation is enabled by programming the MCAN\_CCCR[8] FDOE bit. In case MCAN\_CCCR[8] FDOE = 1, transmission and reception of CAN FD frames is enabled. Transmission and reception of Classic CAN frames is always possible. Whether a CAN FD frame or a Classic CAN frame is transmitted can be configured via the FDF bit in the respective Tx Buffer element.

With MCAN\_CCCR[8] FDOE = 0, received frames are interpreted as Classic CAN frames, which leads to the transmission of an error frame when receiving a CAN FD frame. When CAN FD operation is disabled, no CAN FD frames are transmitted even if the FDF bit of a Tx Buffer element is set. The MCAN\_CCCR[8] FDOE and MCAN\_CCCR[9] BRSE bits can only be changed while the MCAN\_CCCR[0] INIT and MCAN\_CCCR[1] CCE bits are both set. With MCAN\_CCCR[8] FDOE = 0, the setting of bits FDF and BRS is ignored and frames are transmitted in Classic CAN format.

With MCAN\_CCCR[8] FDOE = 1 and MCAN\_CCCR[9] BRSE = 0, only FDF bit of a Tx Buffer element is evaluated. With MCAN\_CCCR[8] FDOE = 1 and MCAN\_CCCR[9] BRSE = 1, transmission of CAN FD frames with bit rate switching is enabled. All Tx Buffer elements with bits FDF and BRS set are transmitted in CAN FD format with bit rate switching.

A mode change during CAN operation is only recommended under the following conditions:

- The failure rate in the CAN FD data phase is significantly higher than in the CAN FD arbitration phase. In this case disable the CAN FD bit rate switching option for transmissions.
- During system startup all nodes are transmitting Classic CAN messages until it is verified that they are able to communicate in CAN FD format. If this is true, all nodes switch to CAN FD operation.
- Wakeup messages in CAN Partial Networking have to be transmitted in Classic CAN format.
- End-of-line programming in case not all nodes are CAN FD capable. Non CAN FD nodes are held in Silent mode until programming has completed. Then all nodes switch back to Classic CAN communication.

In the CAN FD format, the DLC coding differs from the standard CAN format (see [Table 12-256](#)).

**Table 12-256. DLC Coding**

| DLC                                  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9  | 10 | 11 | 12 | 13 | 14 | 15 |
|--------------------------------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|
| Number of Data Bytes in Standard CAN | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 8  | 8  | 8  | 8  | 8  | 8  | 8  |
| Number of Data Bytes in CAN FD       | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 12 | 16 | 20 | 24 | 32 | 48 | 64 |

For CAN FD frames, the bit timing will be switched inside the frame after the BRS (Bit Rate Switch) bit in case this bit is recessive. In the CAN FD arbitration phase, before the BRS bit, the nominal CAN bit timing (see [Figure 12-281](#)) is used as configured by the Nominal Bit Timing and Prescaler Register MCAN\_NBTP. In the following CAN FD data phase, the data phase bit timing is used as configured by the Data Bit Timing and Prescaler Register MCAN\_DBTP. The bit timing is switched back from the data phase timing at the CRC delimiter or when an error is detected, whichever occurs first.



**Figure 12-281. CAN Bit Timing**

The maximum configurable data phase bit timing depends on the CAN clock frequency (FCLK). Example: with FCLK = 20 MHz and the shortest configurable bit time of  $4 t_q$  (time quanta), the bit rate in the data phase is 5 Mbps.

In both data frame formats, CAN FD and CAN FD with bit rate switching, the value of the ESI (Error Status Indicator) bit depends on transmitter's error state (see MCAN\_PSR[11] RESI bit) monitored at the start of the transmission. If the transmitter has error passive flag the ESI bit is transmitted recessive, else it is transmitted dominant.

#### 12.5.1.4.3.4 Transmitter Delay Compensation

##### 12.5.1.4.3.4.1 Description

When only one CAN FD node is transmitting and all others are receivers the length of the bus line has no impact. When transmitting via the TX pin the MCAN module receives the transmitted data from its local CAN transceiver via the RX pin. The received data is delayed. If the transmitter delay is greater than TSEG1 (time segment before sample point), a bit error is detected.

The MCAN module provides a delay compensation mechanism to compensate the transmitter delay. The compensation mechanism enables transmission with higher bit rates during the CAN FD data phase

independent of the delay of a specific CAN transceiver. Without transmitter delay compensation the bit rate in the data phase is limited by the transmitter delay.

The mechanism enables configurations where the data bit time is shorter than the transmitter delay (it is described in detail in ISO 11898-1:2015). The transmitter delay compensation is enabled by setting the MCAN\_DBTP[23] TDC bit to 1.

The delayed transmit data is compared against the received data at the Secondary Sample Point (SSP) in order to check for bit errors during the data phase of transmitting nodes. If a bit error is detected, the transmitter will react on this bit error at the next following regular sample point. During arbitration phase the delay compensation is always disabled.

The received bit is compared against the transmitted bit at the SSP. The SSP position is defined as the sum of the measured delay from the MCAN's transmit output TX pin through the transceiver to the receive input RX pin plus the transmitter delay compensation offset configured by the MCAN\_TDCR[14-8] TDCO field (see [Figure 12-282](#)). The transmitter delay compensation offset is used to adjust the position of the SSP inside the received bit (example: half of the bit time in the data phase). The position of the SSP is rounded down to the next integer number of mtq.

The actual transmitter delay compensation value can be checked by reading the MCAN\_PSR[22-16] TDCV field. This field is cleared when the MCAN\_CCCR[0] INIT bit is set and is updated at each transmission of CAN FD frame while the MCAN\_DBTP[23] TDC bit is set.



mcan-005

**Figure 12-282. Transmitter Delay Measurement**

#### 12.5.1.4.3.4.2 Transmitter Delay Compensation Measurement

When transmitter delay compensation is enabled (by programming MCAN\_DBTP[23] TDC = 1), the measurement is started within each transmitted CAN FD frame at the falling edge of FDF bit to bit res. The measurement is stopped when this edge is seen at the receive input RX pin of the transmitter. The resolution of this measurement is one mtq (see [Figure 12-282](#)). The mtq (minimum time quantum) dimension is equal to the CAN clock period (FCLK).

The use of a transmitter delay compensation filter window can be enabled by programming MCAN\_TDCR[6-0] TDCF field. This filter feature defines a minimum value for the SSP position to avoid the case in which a dominant glitch inside the received FDF bit ends the delay compensation measurement before the falling edge of the received res bit, resulting in an early taken SSP position. Dominant edges on the RX pin, that would result in an earlier SSP position are ignored for transmitter delay measurement. The measurement is stopped when the SSP position is at least MCAN\_TDCR[6-0] TDCF field and the RX pin is low.

The following boundary conditions have to be considered:

- The sum of the measured delay from the TX pin to the RX pin and the configured transmitter delay compensation offset (MCAN\_TDCR[14-8] TDCO field) has to be less than 6 bit times in the data phase.
- The sum of the measured delay from the TX pin to the RX pin and the configured transmitter delay compensation offset (MCAN\_TDCR[14-8] TDCO) field has to be less or equal 127 mtq. In case this sum exceeds 127 mtq, the maximum value of 127 mtq is used for transmitter delay compensation.
- The data phase ends at the sample point of the CRC delimiter, that stops checking of receive bits at the SSPs.

#### 12.5.1.4.3.5 Restricted Operation Mode

In Restricted Operation Mode the CAN node is able to receive data and remote frames and to give acknowledge to valid frames, but it does not send data frames, remote frames, active error frames, or overload frames.

In case of an error condition or overload condition, it does not send dominant bits, instead it waits for the occurrence of bus idle condition to resynchronize itself to the CAN communication. The receive and transmit error counters (MCAN\_ECR[14-8] REC and MCAN\_ECR[7-0] TEC) are frozen while CAN error logging (MCAN\_ECR[23-16] CEL) is active. The Host CPU can set the MCAN module into Restricted Operation Mode by setting MCAN\_CCCR[2] ASM bit. The bit can only be set by the Host CPU at any time when both MCAN\_CCCR[2] CCE and MCAN\_CCCR[0] INIT bits are set to 1.

The Restricted Operation Mode is automatically entered when the Tx Handler was not able to read data from the Message RAM in time. To leave Restricted Operation Mode, the Host CPU has to reset MCAN\_CCCR[2] ASM bit. This mode can be used in applications that adapt themselves to different CAN bit rates. In this case the application tests different bit rates and leaves the Restricted Operation Mode after it has received a valid frame.

#### Note

The Restricted Operation Mode must not be combined with the Internal Loopback Mode .

#### 12.5.1.4.3.6 Bus Monitoring Mode

Entering Bus Monitoring Mode is done by setting the MCAN\_CCCR[5] MON bit to 1. In this mode (see ISO 11898-1:2015, *Bus Monitoring* section), the MCAN module is able to receive valid data and remote frames, but cannot start a transmission. The MCAN module sends only recessive bits on the CAN bus. If the MCAN module is required to send a dominant bit (ACK bit, overload flag, active error flag), the bit is rerouted internally so that the MCAN module monitors this dominant bit, although the CAN bus may remain in recessive state. In Bus Monitoring Mode the MCAN\_TXBRP register is held in reset state. The Bus Monitoring Mode can be used to analyze the traffic on a CAN bus without affecting it by the transmission of dominant bits. [Figure 12-283](#) shows the connection of the TX and RX signals to the MCAN module in Bus Monitoring Mode.



**Figure 12-283. Connection of Signals in Bus Monitoring Mode**

#### 12.5.1.4.3.7 Disabled Automatic Retransmission (DAR) Mode

According to the CAN Specification (see ISO11898-1:2015, *Recovery Management* section), the MCAN module provides means for automatic retransmission of frames that have lost arbitration or that have been disturbed by errors during transmission. By default automatic retransmission is enabled (see the MCAN\_CCCR[6] DAR bit).

##### 12.5.1.4.3.7.1 Frame Transmission in DAR Mode

In DAR mode all transmissions are automatically cancelled after they started on the CAN bus. A Tx Buffer's Tx Request Pending MCAN\_TXBRP[xx] TRPx bit is reset after successful transmission, when a transmission has not yet been started at the point of cancellation, has been aborted due to lost arbitration, or when an error occurred during frame transmission.

Successful transmission:

- Corresponding Tx Buffer Transmission Occurred MCAN\_TXBTO[xx] TOx bit is set
- Corresponding Tx Buffer Cancellation Finished MCAN\_TXBCF[xx] CFx bit is not set

Successful transmission in spite of cancellation:

- Corresponding Tx Buffer Transmission Occurred MCAN\_TXBTO[xx] TOx bit is set
- Corresponding Tx Buffer Cancellation Finished MCAN\_TXBCF[xx] CFx bit is set

Arbitration lost or frame transmission disturbed:

- Corresponding Tx Buffer Transmission Occurred MCAN\_TXBTO[xx] TOx bit is not set
- Corresponding Tx Buffer Cancellation Finished MCAN\_TXBCF[xx] CFx bit is set

In case of a successful frame transmission, and if storage of Tx events is enabled, a Tx Event FIFO element is written with Event Type ET = 10 (transmission in spite of cancellation).

#### 12.5.1.4.3.8 Power Down (Sleep Mode)

The entering in Power Down mode is controlled via two sources:

- PSC (via clock stop request signal)
- Software (by writing to the MCAN\_CCCR[4] CSR bit)

As long as the clock stop request signal is active, the MCAN\_CCCR[4] CSR bit is read as 1.

When all pending transmission requests have completed, the MCAN module waits until bus idle state is detected. Then the MCAN module sets the MCAN\_CCCR[0] INIT bit to 1 to prevent any further CAN transfers.

The MCAN module acknowledges that it is ready for power down:

- By asserting clock stop acknowledge signal to the PSC (in case of PSC source).
- By setting the MCAN\_CCCR[3] CSA flag bit to 1 (in case of Software source).

In this state, before the clocks are switched off, further register accesses can be made. Now the module clock inputs ICLK and FCLK may be switched off.

To leave power down mode, the application has to turn on the module clocks before resetting the input clock stop request signal respectively the MCAN\_CCCR[4] CSR flag bit. The MCAN will acknowledge this by resetting the output clock stop acknowledge signal respectively the MCAN\_CCCR[3] CSA flag bit. Afterwards, the application can restart CAN communication by resetting the MCAN\_CCCR[0] INIT bit.

Restoring the clocks from clock stop mode, needs to be done according to how the clock stop was initiated:

- If Software asserts the MCAN\_CCCR[3] CSA flag bit, once the MCAN module goes idle, the MCAN\_CCCR[0] INIT bit is set. To get it started again, Software needs to write 0 to the MCAN\_CCCR[0] INIT bit.
- If PSC is issuing a clock stop request, than there are two options for waking up:
  - After removing clock stop request signal, Software would need to write 0 to the MCAN\_CCCR[0] INIT bit, or
  - If the MCANSS\_CTRL[5] AUTOWAKEUP bit is set, than after removing clock stop request signal, an FSM inside the MCAN module will reset the MCAN\_CCCR[0] INIT bit (without Software).

#### 12.5.1.4.3.8.1 External Clock Stop Mode

The MCAN module supports two external clock stop modes:

- Immediate
- Graceful

In a graceful clock stop mode, when the clock stop request is asserted, the MCAN core will respond with clock stop acknowledge when all pending Tx messages have been processed and an Idle line had been detected. The MCAN\_CCCR[0] INIT bit will be set, the MCAN core will go and stay Idle.

The automatic wakeup feature is enabled by setting the MCANSS\_CTRL[5] AUTOWAKEUP and MCANSS\_CTRL[4] WAKEUPREQEN bits to 1 (for more information, see [Section 12.5.1.4.3.8.3, Wakeup request](#)). When external clock stop request is removed and no suspend request is active, a read-modify-write to the MCAN\_CCCR[0] INIT bit is performed to clear it.

#### 12.5.1.4.3.8.2 Suspend Mode

The MCAN module supports two suspend modes:

- Immediate
- Graceful

In a graceful suspend mode (see the MCANSS\_CTRL[3] DBGSUSP\_FREE bit), when the suspend request is asserted, a clock stop request to the MCAN core is performed. The MCAN core will respond with clock stop acknowledge when all pending Tx messages have been processed and an Idle line had been detected. At that point the MCAN\_CCCR[0] INIT bit will be set, the MCAN core will go and stay Idle. The suspend state can be verified by reading MCAN\_CCCR[0] INIT bit.

The automatic wakeup feature is enabled by setting the MCANSS\_CTRL[5] AUTOWAKEUP and MCANSS\_CTRL[4] WAKEUPREQEN bits to 1 (for more information, see [Section 12.5.1.4.3.8.3, Wakeup request](#)). When suspend request is removed, if no external clock stop request is active, a read-modify-write to the MCAN\_CCCR[0] INIT bit is performed to clear it.

During suspend mode the auto-clear feature is disabled. The following register fields have an auto-clear feature:

- MCAN\_ECR[23-16] CEL
- MCAN\_PSR[2-0] LEC
- MCAN\_PSR[10-8] DLEC
- MCAN\_PSR[11] RESI
- MCAN\_PSR[12] RBRS
- MCAN\_PSR[13] RFDF
- MCAN\_PSR[14] PXE

#### 12.5.1.4.3.8.3 Wakeup request

Issuing a clock stop request puts the MCAN module into Power Down mode (Sleep Mode). During transition from IDLE to ACTIVE, if the MCANSS\_CTRL[5] AUTOWAKEUP and MCANSS\_CTRL[4] WAKEUPREQEN bits are enabled, after the MCAN Core respond to the removal of the clock stop request with removing the clock stop acknowledge, a read-modify-write will be issued to clear the MCAN\_CCCR[0] INIT bit and the MCAN core will resume operation.

If the MCANSS\_CTRL[4] WAKEUPREQEN bit is set, the MCAN module provides a wakeup request on the following wakeup event:

- The receive RX pin is dominant (logical 0)

The wakeup request is de-asserted when any of the following conditions occur:

- Clock stop request is removed and clock stop acknowledge is de-asserted
- A reset is applied to the MCAN module

#### 12.5.1.4.3.9 Test Modes

The MCAN\_TEST register write access is enabled by setting the test mode enable MCAN\_CCCR[7] TEST bit to 1. The MCAN\_TEST register allows the configuration of the test modes and test functions.

The CAN transmit TX pin has four output functions. One of those functions can be selected by programming the MCAN\_TEST[6-5] TX field. Additionally to its default function (the serial data output) it can drive the CAN Sample Point signal to monitor the MCAN's bit timing and it can drive constant dominant or recessive values.

The actual value of the CAN receive RX pin can be monitored from MCAN\_TEST[7] RX bit. Both functions can be used to check the CAN bus physical layer. Due to the synchronization mechanism between CAN clock (FCLK) and Host clock (ICKL) domain, there may be a delay of several Host clock periods between writing to the MCAN\_TEST[6-5] TX field until the new configuration is visible at the output TX pin. This applies also when reading input RX pin via the MCAN\_TEST[7] RX bit.

---

#### Note

Test modes should be used for self test only. The software control for TX pin interferes with all CAN protocol functions. It is not recommended to use test modes for application.

---

#### 12.5.1.4.3.9.1 Internal Loopback Mode

The MCAN module can be set into Internal Loopback Mode by programming MCAN\_TEST[4] LBCK and MCAN\_CCCR[5] MON bits to 1. The Internal Loopback Mode is used for a 'Hot Selftest'. The 'Hot Selftest' allows the MCAN module to be tested without affecting a running CAN system connected to the TX and RX pins. In this mode RX pin is disconnected from the MCAN module and TX pin is held recessive. [Figure 12-284](#) shows the connection of the TX and RX pins to the MCAN module in case of Internal Loopback Mode.



**Figure 12-284. Internal Loopback Mode**

#### 12.5.1.4.4 Timestamp Generation

The MCAN module has integrated a 16-bit wrap-around counter for timestamp generation. The timestamp counter prescaler MCAN\_TSCC[19-16] TCP field can be configured to clock the counter in multiples of CAN bit times (1-16). The counter is readable via the MCAN\_TSCV[15-0] TSC field. A write access to the MCAN\_TSCV register resets the counter to zero. When the timestamp counter wraps around the interrupt MCAN\_IR[16] TSW flag is set. On start of a frame reception/transmission the counter value is captured and stored into the timestamp section of an Rx Buffer/Rx FIFO (RXTS[15-0]) or Tx Event FIFO (TXTS[15-0]) element. For more information, see [Section 12.5.1.4.10, Message RAM](#).

#### 12.5.1.4.4.1 External Timestamp Counter

For CAN FD operation mode the MCAN core requires an External Timestamp Counter. An externally generated 16-bit vector may substitute the integrated 16-bit CAN bit time counter (internal timestamp counter) for receive

and transmit timestamp generation. An external 16-bit timestamp counter can be used by programming the MCAN\_TSCC[1-0] TSS field.

The External Timestamp Counter uses the interface clock (ICLK) as a reference clock. The MCAN Core accepts a 16-bit timestamp. A 24-bit prescaler provides a programmable resolution for the timestamp (see MCANSS\_EXT\_TS\_PRESCALER[23-0] PRESCALER bit field). The External Timestamp Counter counter can be enabled or disabled through the MCANSS\_CTRL[6] EXT\_TS\_CNTR\_EN bit. When disabled the counter is reset back to zero. While enabled the counter keeps incrementing. When the timestamp rolls over the MCAN timestamp interrupt is generated.

When the timestamp rolls over the MCANSS\_IRS register is set (see [Figure 12-285](#)). The MCANSS\_IE register can be affected by writing to the MCANSS\_IESS register to set or to the MCANSS\_IACS register to clear. The MCANSS\_IESS register is a shadow register mapped to the same address as the MCANSS\_IE register. The level interrupt is a reflection of both MCANSS\_IRS and MCANSS\_IE being set. The MCANSS\_IES register reflects the level interrupt. When an rollover event occurs the interrupt counter is incremented. Writing to the MCANSS\_IACS register to clear the MCANSS\_IRS register will also decrement the interrupt counter. Writing to the MCANSS\_EOI register will issue another pulse if the interrupt counter is not zero.

The rollover event can be artificially simulated by software through writing to the Interrupt Set Shadow register (MCANSS\_ISS). The MCANSS\_ISS register is a shadow register mapped to the same address as the MCANSS\_IRS register.



**Figure 12-285. External Timestamp Counter Interrupt**

#### 12.5.1.4.5 Timeout Counter

The MCAN module has integrated a 16-bit Timeout Counter. It is used to signal timeout conditions for the Rx FIFO 0, Rx FIFO 1, and Tx Event FIFO Message RAM elements. The Timeout Counter is configured via the MCAN\_TOCC register. It is enabled via the MCAN\_TOCC[0] ETOC bit. The Timeout Counter operates

as down-counter and uses the same prescaler programmed by the MCAN\_TSCH[19-16] TCP field as the Timestamp Counter. The actual counter value can be monitored from the MCAN\_TOCV[15-0] TOC field. The Timeout Counter can be started only when MCAN\_CCCR[0] INIT = 0 and stopped when MCAN\_CCCR[0] INIT = 1 (example: when the MCAN enters Bus\_Off state). The operation mode is selected by the MCAN\_TOCC[2-1] TOS field. When Continuous Mode is selected, the counter starts when MCAN\_CCCR[0] INIT = 0, a write to the MCAN\_TOCV register presets the counter to the value configured by the MCAN\_TOCC[31-16] TOP field and continues down-counting.

In case the Timeout Counter is controlled by one of the FIFOs, an empty FIFO presets the counter to the value configured by the MCAN\_TOCC[31-16] TOP field. Down-counting is started when the first FIFO element is stored. Writing to the MCAN\_TOCV register has no effect. When the counter reaches zero, the interrupt MCAN\_IR[18] TOO flag is set.

In Continuous Mode, the counter is immediately restarted at the value configured by the MCAN\_TOCC[31-16] TOP field.

#### **12.5.1.4.6 ECC Support**

The Message Memory is wrapped in an ECC wrapper providing SECDED parity functionality. The ECC wrapper is controlled by an ECC Aggregator.

##### **12.5.1.4.6.1 ECC Wrapper**

The ECC wrapper provides Single Error Correction (SEC) and Double Error Detection (DED) parity to the Message Memory content. It has side band signals for error notification. The ECC Wrapper implements an error injection test mode.

The error correction is done using a lazy write back. When an error is detected, it is noted in a FIFO Queue which waits for an access gap to write the data back and refresh the memory. If a transaction writes new data to the compromised entry before the lazy write back completes, the write back is discarded.

##### **12.5.1.4.6.2 ECC Aggregator**

---

##### **Note**

For more information about ECC Aggregator, refer to *ECC Aggregator*.

---

#### **12.5.1.4.7 Rx Handling**

The Rx Handler controls the following operations:

- Acceptance filtering
- The transfer of received messages to the Rx Buffers or to one of the two Rx FIFOs (Rx FIFO 0 or Rx FIFO 1)
- Rx FIFO Put and Get Index operations

##### **12.5.1.4.7.1 Acceptance Filtering**

The MCAN module is capable to configure two sets of acceptance filters - one set for standard and one set for extended identifiers. These filters can be assigned to an Rx Buffer or to one of the two Rx FIFOs.

The main features of the filter elements are:

- Each filter element can be configured as:
  - Range Filter (from - to)
  - Filter for specific IDs (for one or two dedicated IDs)
  - Classic Bit Mask Filter
- Each filter element can be enabled/disabled individually
- Each filter element can be configured for acceptance or rejection filtering
- Filters are checked sequentially and execution (acceptance filtering procedure) stops at the first matching filter element or when the end of the filter list is reached

Related configuration registers are:

- Global Filter Configuration (MCAN\_GFC) register
- Standard ID Filter Configuration (MCAN\_SIDFC) register
- Extended ID Filter Configuration (MCAN\_XIDFC) register
- Extended ID AND Mask (MCAN\_XIDAM) register

Depending on the configuration of the filter element (see SFEC/EFEC in [Section 12.5.1.4.10, Message RAM](#)) if filter matches, one of the following actions is performed:

- Received frame is stored in FIFO 0 or FIFO 1
- Received frame is stored in Rx Buffer
- Received frame is stored in Rx Buffer and generation of pulse at filter event pin is performed. This is high level single ICLK pulse. For more information, see [Section 12.5.1.4.2.1, DMA Requests](#).
- Received frame is rejected
- Set High Priority Message interrupt flag MCAN\_IR[8] HPM
- Set High Priority Message interrupt flag MCAN\_IR[8] HPM and store received frame in FIFO 0 or FIFO 1

Acceptance filtering starts when complete Message ID is received. Acceptance filtering stops at the first matching enabled filter element or when the end of the filter list is reached. If a filter element matches - the Rx Handler starts writing the received message data in portions of 32 bit to the matching Rx Buffer or Rx FIFO. If an error condition occurs (for example: CRC error), this message is rejected with the following impact on the affected Rx Buffer or Rx FIFO:

- Rx Buffer:  
New Data flag (MCAN\_NDAT1/MCAN\_NDAT2) of matching Rx Buffer is not set, but Rx Buffer (partly) overwritten with received data (for error type see MCAN\_PSR[2-0] LEC respectively MCAN\_PSR[10-8] DLEC fields).
- Rx FIFO:  
Put index of matching Rx FIFO is not updated, but related Rx FIFO element (partly) overwritten with received data (for error type see MCAN\_PSR[2-0] LEC respectively MCAN\_PSR[10-8] DLEC fields). If matching Rx FIFO is configured to operate in overwrite mode, the boundary conditions described in [Section 12.5.1.4.7.2.2](#) have to be considered.

#### 12.5.1.4.7.1.1 Range Filter

Each filter element can be configured to operate as Range Filter (Standard Filter Type SFT = 00/Extended Filter Type EFT = 00). The filter matches for all received message frames with IDs in the range from SFID1 to SFID2 ( $SFID2 \geq SFID1$ ) respectively in the range from EFID1 to EFID2 ( $EFID2 \geq EFID1$ ). For more information see [Section 12.5.1.4.10.5, Standard Message ID Filter Element](#) and [Section 12.5.1.4.10.6, Extended Message ID Filter Element](#).

There are two options for range filtering of extended frames:

- Extended Filter Type EFT = 00: The Extended ID AND Mask (MCAN\_XIDAM) is used for Range Filtering. The Message ID of received frames is ANDed with the Extended ID AND Mask (MCAN\_XIDAM) before the range filter is applied.
- Extended Filter Type EFT = 11: The Extended ID AND Mask (MCAN\_XIDAM) is not used for Range Filtering.

#### 12.5.1.4.7.1.2 Filter for specific IDs

Each filter element can be configured to filter one or two dedicated Message IDs (Standard Filter Type SFT =01/ Extended Filter Type EFT =01). To filter only one specific Message ID, the filter element has to be configured with SFID1 = SFID2 respectively EFID1 = EFID2. For more information see [Section 12.5.1.4.10.5, Standard Message ID Filter Element](#) and [Section 12.5.1.4.10.6, Extended Message ID Filter Element](#).

#### 12.5.1.4.7.1.3 Classic Bit Mask Filter

Classic bit mask filtering can filter groups of Message IDs (Standard Filter Type SFT =10/Extended Filter Type EFT =10). This is done by masking single bits of a received Message ID. In this case SFID1/EFID1 element is used as Message ID filter, while SFID2/EFID2 element is used as filter mask.

A 0 bit at the filter mask (SFID2/EFID2) will mask out the corresponding bit position of the configured Message ID filter (SFID1/EFID1) and the value of the received Message ID at that bit position is not relevant for acceptance filtering. Only those bits of the received Message ID where the corresponding mask bits are 1 are relevant for acceptance filtering.

There are two interesting cases:

- All mask bits are 1: a match occurs only when the received Message ID and the configured Message ID filter are identical.
- All mask bits are 0: all Message IDs match.

#### 12.5.1.4.7.1.4 Standard Message ID Filtering

The standard Message ID (11-bit ID) filtering flow is shown in [Figure 12-286](#). Section 12.5.1.4.10.5, *Standard Message ID Filter Element* describes the standard Message ID filter element.

The Remote Transmission Request (RTR) and Extended Identifier (XTD) bits of the received frames are compared against the list of configured filter elements. This is controlled by the following registers:

- Global Filter Configuration (MCAN\_GFC) register
- Standard ID Filter Configuration (MCAN\_SIDFC) register



mcan-009

**Figure 12-286. Standard Message ID Filter Path**

#### 12.5.1.4.7.1.5 Extended Message ID Filtering

The extended Message ID (29-bit ID) filtering flow is shown in Figure 12-287. Section 12.5.1.4.10.6, *Extended Message ID Filter Element* describes the extended Message ID filter element.

The Remote Transmission Request (RTR) and Extended Identifier (XTD) bits of the received frames are compared against the list of configured filter elements. This is controlled by the following registers:

- Global Filter Configuration (MCAN\_GFC) register
- Extended ID Filter Configuration (MCAN\_XIDFC) register

Note that before the filter list is executed the received identifier is ANDed with the Extended ID AND Mask (MCAN\_XIDAM).



rcan-010

**Figure 12-287. Extended Message ID Filter Path**

#### 12.5.1.4.7.2 Rx FIFOs

The configuration of the Rx FIFOs (Rx FIFO 0 and Rx FIFO 1) can be done via the MCAN\_RXF0C and MCAN\_RXF1C registers. Each Rx FIFO can be configured to store up to 64 received messages.

After acceptance filtering the received messages that passed are transferred to the Rx FIFO. The filter mechanisms available for the Rx FIFO 0 and Rx FIFO 1 is described in [Section 12.5.1.4.7.1, Acceptance Filtering](#). [Section 12.5.1.4.10.2, Rx Buffer and FIFO Element](#) describes the Rx FIFO element.

The Rx FIFO watermark can be used to prevent an Rx FIFO overflow. If the Rx FIFO fill level reaches the Rx FIFO watermark configured by the MCAN\_RXFnC[30-24] FnWM field (where: n = 0 or 1) an interrupt flag MCAN\_IR[1] RF0W/MCAN\_IR[5] RF1W is set.

When the Rx FIFO Put Index reaches the Rx FIFO Get Index (MCAN\_RXFnS[21-16] FnPI = MCAN\_RXFnS[13-8] FnGI) an Rx FIFO Full condition is signalled by the MCAN\_RXFnS[24] FnF status bit and interrupt flag MCAN\_IR[2] RF0F/MCAN\_IR[6] RF1F is set. [Figure 12-288](#) shows Rx FIFO Status. The FIFOs fill level is presented in the MCAN\_RXFnS[6-0] FnFL field (the number of elements stored in Rx FIFO).



mcan-011

**Figure 12-288. Rx FIFO Status**

Rx FIFOs start address in the Message RAM (MCAN\_RXFnC[15-2] FnSA field) have to be configured when reading from an Rx FIFO (Rx FIFO Get Index - MCAN\_RXFnS[13-8] FnGI). [Table 12-257](#) presents Rx Buffer/Rx FIFO Element Size for different Rx Buffer/Rx FIFO Data Field Size which is configured via the MCAN\_RXESC register.

**Table 12-257. Rx Buffer/Rx FIFO Element Size**

| MCAN_RXESC[10-8] RBDS<br>MCAN_RXESC[2-0] F0DS/<br>MCAN_RXESC[6-4] F1DS | Data Field<br>[bytes] | FIFO Element Size<br>[RAM words] |
|------------------------------------------------------------------------|-----------------------|----------------------------------|
| 000                                                                    | 8                     | 4                                |
| 001                                                                    | 12                    | 5                                |
| 010                                                                    | 16                    | 6                                |
| 011                                                                    | 20                    | 7                                |
| 100                                                                    | 24                    | 8                                |
| 101                                                                    | 32                    | 10                               |
| 110                                                                    | 48                    | 14                               |
| 111                                                                    | 64                    | 18                               |

#### 12.5.1.4.7.2.1 Rx FIFO Blocking Mode

The Rx FIFO blocking mode is the default operation mode for the Rx FIFOs. It is configured by the MCAN\_RXFnC[31] FnOM = 0.

If an Rx FIFO full condition is reached (MCAN\_RXFnS[21-16] FnPI = MCAN\_RXFnS[13-8] FnGI), no further messages are written to the corresponding Rx FIFO until at least one message has been read out and the Rx FIFO Get Index has been incremented. An Rx FIFO full condition is signalled by the MCAN\_RXFnS[24] FnF = 1 and interrupt flag MCAN\_IR[2] RF0F/MCAN\_IR[6] RF1F is set.

In case a message is received while the corresponding Rx FIFO is full, this message is rejected and the message lost condition is signalled by MCAN\_RXFnS[25] RFnL = 1 and interrupt flag MCAN\_IR[3] RFnL/MCAN\_IR[25] RFnL is set.

#### 12.5.1.4.7.2.2 Rx FIFO Overwrite Mode

The Rx FIFO overwrite mode is configured by the MCAN\_RXFnC[31] FnOM = 1. When an Rx FIFO full condition is reached (MCAN\_RXFnS[21-16] FnPI = MCAN\_RXFnS[13-8] FnGI) signalled by MCAN\_RXFnS[24] FnF = 1, the next accepted message for the FIFO will overwrite the oldest FIFO message. Put index/Get index are both incremented by one.

In overwrite mode if an Rx FIFO full condition is signalled, reading of the Rx FIFO elements should start at least at get index + 1. The reason for that is, that it might happen, that a received message is written to the Message RAM (Put index) while the Host CPU is reading from the Message RAM (Get index). In this case inconsistent data may be read from the respective Rx FIFO element. The problem is solved by adding an offset to the Get index when reading from the Rx FIFO. The offset depends on how fast the Host CPU accesses the Rx FIFO. [Figure 12-289](#) shows an offset of two with respect to the Get index when reading the Rx FIFO. In this case the two messages stored in element 1 and 2 are lost.



**Figure 12-289. Rx FIFO Overflow Handling**

After reading from the Rx FIFO, the number of the last element read has to be written to the Rx FIFO Acknowledge Index MCAN\_RXFnA[5-0] FnAI. This increments the get index to that element number. In case the Put index has not been incremented to this Rx FIFO element, the Rx FIFO full condition is reset (MCAN\_RXFnS[24] FnF = 0).

#### 12.5.1.4.7.3 Dedicated Rx Buffers

The MCAN supports up to 64 dedicated Rx Buffers. The start address of the Rx Buffers section in the Message RAM is configured via MCAN\_RXBC[15-2] RBSA field. To store in an Rx Buffer a Standard or Extended Message ID Filter Element with SFEC/EFEC = 111 and SFID2/EFID2[10-9] = 00 has to be configured (see [Section 12.5.1.4.10.5, Standard Message ID Filter Element](#) and [Section 12.5.1.4.10.6, Extended Message ID Filter Element](#)).

After a received message has been accepted by a filter element, the message is stored into the Rx Buffer in the Message RAM referenced by the filter element (the format is the same as for an Rx FIFO element). In addition the flag MCAN\_IR[19] DRX (Message stored in Dedicated Rx Buffer) is set.

[Table 12-258](#) shows Example Filter Configuration for Rx Buffers.

**Table 12-258. Example Filter Configuration for Rx Buffers**

| Filter Element | SFID1[10-0]<br>EFID1[28-0] | SFID2[10-9]<br>EFID2[10-9] | SFID2[5-0]<br>EFID2[5-0] |
|----------------|----------------------------|----------------------------|--------------------------|
| 0              | ID message 1               | 00                         | 00 0000                  |

**Table 12-258. Example Filter Configuration for Rx Buffers (continued)**

| Filter Element | SFID1[10-0]<br>EFID1[28-0] | SFID2[10-9]<br>EFID2[10-9] | SFID2[5-0]<br>EFID2[5-0] |
|----------------|----------------------------|----------------------------|--------------------------|
| 1              | ID message 2               | 00                         | 00 0001                  |
| 2              | ID message 3               | 00                         | 00 0010                  |

After the last word of a matching received message has been written to the Message RAM, the respective New Data flag in register MCAN\_NDAT1/MCAN\_NDAT2 is set. As long as the New Data flag is set, the respective Rx Buffer is locked against updates from received matching frames. The New Data flags have to be reset by the Host CPU by writing a 1 to the respective bit position.

While an Rx Buffer's New Data flag is set, a Message ID Filter Element referencing this specific Rx Buffer will not match, causing the acceptance filtering to continue. Following Message ID Filter Elements may cause the received message to be stored into another Rx Buffer, or into an Rx FIFO, or the message may be rejected, depending on filter configuration.

#### 12.5.1.4.7.3.1 Rx Buffer Handling

Rx Buffer Handling include the following steps:

- Reset interrupt flag MCAN\_IR[19] DRX
- Read New Data registers
- Read messages from Message RAM
- Reset New Data flags of processed messages

#### 12.5.1.4.7.4 Debug on CAN Support

Debug DMA is not supported feature. Debug messages can be traced through the RX FIFO (see [Section 12.5.1.4.7.2](#)).

#### 12.5.1.4.8 Tx Handling

The Tx Handler is used to handle the Tx requests. It controls the transfer of transmit messages from the dedicated Tx Buffers, the Tx FIFO, and the Tx Queue to the CAN Core, the Tx Event FIFO, and the Put and Get Index operations. The MCAN module supports up to 32 Tx Buffers. These Tx Buffers can be configured as dedicated Tx Buffers, Tx FIFO, or Tx Queue and as combination of dedicated Tx Buffers/Tx FIFO or dedicated Tx Buffers/Tx Queue. For each Tx Buffer element Classical CAN or CAN FD transmission mode can be configured. [Section 12.5.1.4.10.3](#) describes the Tx Buffer Element. [Table 12-259](#) shows the possible configurations for message transmission.

**Table 12-259. Possible Configurations for Message Transmission**

| MCAN_CCCR            |                      | Tx Buffer Element |         | Frame Transmission                |
|----------------------|----------------------|-------------------|---------|-----------------------------------|
| MCAN_CCCR[9]<br>BRSE | MCAN_CCCR[8]<br>FDOE | FDF               | BRS     |                                   |
| ignored              | 0                    | ignored           | ignored | Classic CAN                       |
| 0                    | 1                    | 0                 | ignored | Classic CAN                       |
| 0                    | 1                    | 1                 | ignored | CAN FD without bit rate switching |
| 1                    | 1                    | 0                 | ignored | Classic CAN                       |
| 1                    | 1                    | 1                 | 0       | CAN FD without bit rate switching |
| 1                    | 1                    | 1                 | 1       | CAN FD with bit rate switching    |

When the Tx Buffer Request Pending MCAN\_TXBRP register is updated, or when a transmission has been started the Tx Handler starts scanning to check for the highest priority pending Tx request. The Tx Buffer with lowest Message ID has highest priority.

---

**Note**

AUTOSAR requires at least three Tx Queue Buffers and support of transmit cancellation.

---

#### 12.5.1.4.8.1 Transmit Pause

The transmit pause feature is intended for use in CAN networks where the CAN Message IDs are specific and cannot easily be changed. These Message IDs may have a higher priority than other defined Message IDs, while in a specific application their relative priority should be inverse. This allows for a case where one ECU sends a burst of CAN messages that cause another ECU's CAN messages to be delayed (paused).

The transmit pause feature is enabled by the MCAN\_CCCR[14] TXP bit. By default this bit is disabled (MCAN\_CCCR[14] TXP = 0). Each time after successfully transmitted message, a pause for two CAN bit times occurs before the start of the next transmission. This allows the other CAN nodes in the network to transmit messages even if their Message IDs have lower priority.

#### 12.5.1.4.8.2 Dedicated Tx Buffers

Dedicated Tx Buffers are intended for message transmission under complete control of the Host CPU.

There are two options:

- Each dedicated Tx Buffer is configured with a specific Message ID.
- Two or more dedicated Tx Buffers are configured with the same Message ID. In this case the Tx Buffer with the lowest buffer number is transmitted first.

After the data section has been updated, a transmission is requested by an Add Request. This is done via the MCAN\_TXBAR[x]ARn bit (where x = 0 - 31). The requested messages arbitrate internally with messages from an optional Tx FIFO or Tx Queue and externally with messages on the CAN bus, and are sent out according to their Message ID.

**Table 12-260** shows Tx Buffer/Tx FIFO/Tx Queue Element Size. A Dedicated Tx Buffer allocates Element Size 32-bit words in the Message RAM. The start address of a dedicated Tx Buffer in the Message RAM is calculated by adding transmit buffer index from 0 to 31 (MCAN\_TXFQS[20-16] TFQPI) × Element Size to the Tx Buffer Start Address MCAN\_TXBC[15-2] TBSA field.

**Table 12-260. Tx Buffer/Tx FIFO/Tx Queue Element Size**

| MCAN_TXESC[2-0] TBDS | Data Field [bytes] | Element Size [RAM words] |
|----------------------|--------------------|--------------------------|
| 000                  | 8                  | 4                        |
| 001                  | 12                 | 5                        |
| 010                  | 16                 | 6                        |
| 011                  | 20                 | 7                        |
| 100                  | 24                 | 8                        |
| 101                  | 32                 | 10                       |
| 110                  | 48                 | 14                       |
| 111                  | 64                 | 18                       |

#### 12.5.1.4.8.3 Tx FIFO

Tx FIFO mode is configured by setting bit MCAN\_TXBC[30] TFQM = 0. The stored in the Tx FIFO messages are transmitted starting with the message referenced by the Get Index MCAN\_TXFQS[12-8] TFGI field.

After each transmission the Get Index is incremented until the Tx FIFO is empty. The Tx FIFO Free Level MCAN\_TXFQS[5-0] TFFL field indicates the number of the available free Tx FIFO elements. The Tx FIFO allows transmission of messages with the same Message ID from different Tx Buffers in the order these messages have been written to the Tx FIFO.

New transmit messages have to be written to the Tx FIFO starting with the Tx Buffer referenced by the Put Index MCAN\_TXFQS[20-16] TFQPI field. After each Add Request (MCAN\_TXBAR[x] ARn = 1) the

Put Index is incremented to the next free Tx FIFO element. When the Put Index reaches the Get Index (MCAN\_TXFQS[20-16] TFQPI = MCAN\_TXFQS[12-8] TFGI), Tx FIFO Full condition is signalled by bit MCAN\_TXFQS[21] TFQF = 1. In this case no further messages should be written to the Tx FIFO until the next message has been transmitted and the Get Index has been incremented.

The number of requested Tx buffers should not exceed the number of free Tx Buffers as indicated by the Tx FIFO Free Level MCAN\_TXFQS[5-0] TFFL field.

In case a transmission request for the Tx Buffer referenced by the Get Index is cancelled, the Get Index is incremented to the next Tx Buffer with pending transmission request and the Tx FIFO Free Level MCAN\_TXFQS[5-0] TFFL field is recalculated. In case transmission cancellation is applied to any other Tx Buffer - the Get Index and the FIFO Free Level remain unchanged.

A Tx FIFO element allocates Element Size 32-bit words in the Message RAM (see [Table 12-260](#)). The start address of the next available (free) Tx FIFO Buffer is calculated by adding Tx FIFO/Queue Put Index MCAN\_TXFQS[20-16] TFQPI (from 0 to 31) × Element Size to the Tx Buffer Start Address MCAN\_TXBC[15-2] TBSA field.

#### 12.5.1.4.8.4 Tx Queue

Tx Queue mode is configured by setting bit MCAN\_TXBC[30] TFQM = 1. The stored in the Tx Queue messages are transmitted starting with the highest priority message (lowest Message ID). In case two or more Queue Buffers are configured with the same Message ID, the Queue Buffer with the lowest buffer number is transmitted first.

New transmit messages have to be written to the Tx FIFO starting with the Tx Buffer referenced by the Put Index MCAN\_TXFQS[20-16] TFQPI field. Each Add Request cyclically increments the Put Index to the next free Tx Buffer. In case of Tx Queue Full condition (MCAN\_TXFQS[21] TFQF = 1), the Put Index is not valid and no further message should be written to the Tx Queue until at least one of the requested messages has been sent out or a pending transmission request has been cancelled.

The application may use the MCAN\_TXBRP register instead of the Put Index and may place messages to any Tx Buffer without pending transmission request.

A Tx Queue Buffer allocates Element Size 32-bit words in the Message RAM (see [Table 12-260](#)). The start address of the next available (free) Tx Queue Buffer is calculated by adding Tx FIFO/Queue Put Index MCAN\_TXFQS[20-16] TFQPI (from 0 to 31) × Element Size to the Tx Buffer Start Address MCAN\_TXBC[15-2] TBSA field.

#### 12.5.1.4.8.5 Mixed Dedicated Tx Buffers/Tx FIFO

For this combination the Tx Buffers section in the Message RAM is separated in two parts:

- Dedicated Tx Buffers: the number of Dedicated Tx Buffers is configured by the MCAN\_TXBC[21-16] NDTB field
- Tx FIFO: the number of Tx Buffers assigned to the Tx FIFO is configured by the MCAN\_TXBC[29-24] TFQS field

If the MCAN\_TXBC[29-24] TFQS field is empty (zero) - only Dedicated Tx Buffers are used.

Tx prioritization:

- Scan Dedicated Tx Buffers and oldest pending Tx FIFO Buffer (referenced by the MCAN\_TXFQS[12-8] TFGI field)
- Buffer with lowest Message ID gets highest priority and is transmitted next

[Figure 12-290](#) shows Mixed Dedicated Tx Buffers/Tx FIFO example.



mcan-013

**Figure 12-290. Mixed Dedicated Tx Buffers/Tx FIFO (example)**

#### 12.5.1.4.8.6 Mixed Dedicated Tx Buffers/Tx Queue

For this combination the Tx Buffers section in the Message RAM is separated in two parts:

- Dedicated Tx Buffers: the number of Dedicated Tx Buffers is configured by the MCAN\_TXBC[21-16] NDTB field
- Tx Queue: the number of Tx Buffers assigned to the Tx Queue is configured by the MCAN\_TXBC[29-24] TFQS field

If MCAN\_TXBC[29-24] TFQS field is empty (zero) - only Dedicated Tx Buffers are used.

Tx prioritization:

- Scan all Tx Buffers with activated transmission request
- Tx Buffer with lowest Message ID gets highest priority and is transmitted next

Figure 12-291 shows Mixed Dedicated Tx Buffers/Tx Queue example.



mcan-014

**Figure 12-291. Mixed Dedicated Tx Buffers/Tx Queue (example)**

#### 12.5.1.4.8.7 Transmit Cancellation

This feature is especially intended for gateway and AUTOSAR based applications. The Host CPU can cancel a requested transmission from a dedicated Tx Buffer or a Tx Queue Buffer by setting bit MCAN\_TXBCR[n] CRn = 1 (where n = 0 - 31). The corresponding bit position n is equivalent to the number of the Tx Buffer.

Transmit cancellation is not intended for Tx FIFO operation.

Successful cancellation is signalled by setting the corresponding bit of the MCAN\_TXBCF register (MCAN\_TXBCF[n] CFn = 1).

If transmission from a Tx Buffer is already ongoing and a transmit cancellation is requested, the corresponding MCAN\_TXBRP[n] TRPn bit remains set as long as the transmission is in progress. If the transmission was successful, the corresponding MCAN\_TXBTO[n] TOn and MCAN\_TXBCF[n] CFn bits are set. If the transmission was not successful, only the corresponding bit MCAN\_TXBCF[n] CFn = 1.

---

**Note**

If pending transmission is cancelled immediately before this transmission could have been started, a short time window occurs where no transmission is started even if another message is also pending in this node. This may enable another node to transmit a message which may have a lower priority than the second message in this node.

---

**12.5.1.4.8.8 Tx Event Handling**

To support Tx Event Handling the Message RAM has implemented a Tx Event FIFO section. Up to 32 Tx Event FIFO elements can be configured. [Section 12.5.1.4.10.4](#) describes the Tx Event FIFO element. After message transmission on the CAN bus, Message ID and Timestamp are stored in a Tx Event FIFO element. To link a Tx Event to a Tx Event FIFO element, the Message Marker from the transmitted Tx Buffer is copied into the Tx Event FIFO element.

A Tx Event FIFO full condition is signalled by the MCAN\_IR[14] TEFF bit. In this case no further elements are written to the Tx Event FIFO until at least one element has been read out and the Tx Event FIFO Get Index has been incremented (MCAN\_TXEFS[12-8] EFGI). In case a Tx Event occurs while the Tx Event FIFO is full, this event is rejected and interrupt flag MCAN\_IR[15] TEFL bit is set.

The Tx Event FIFO watermark can be configured to avoid a Tx Event FIFO overflow. When the Tx Event FIFO fill level reaches the Tx Event FIFO watermark configured by the MCAN\_TXEFC[29-24] EFWM field, interrupt flag MCAN\_IR[13] TEFW is set. When reading from the Tx Event FIFO, two times the Tx Event FIFO Get Index MCAN\_TXEFS[12-8] EFGI field has to be added to the Tx Event FIFO start address MCAN\_TXEFC[15-2] EFSA field.

**12.5.1.4.9 FIFO Acknowledge Handling**

The Get Indices of the two Rx FIFOs (Rx FIFO 0 or Rx FIFO 1) and the Tx Event FIFO are controlled by writing to the corresponding FIFO Acknowledge Index (see MCAN\_RXF0A, MCAN\_RXF1A, and MCAN\_TXEFA). Writing to the FIFO Acknowledge Index will set the FIFO Get Index to the FIFO Acknowledge Index plus one and thereby updates the FIFO Fill Level.

There are two use cases:

- A single element has been read from the FIFO: the Get Index value is written to the FIFO Acknowledge Index.
- A sequence of elements has been read from the FIFO: the Get Index value (Index of the last element read) is written to the FIFO Acknowledge Index at the end of that read sequence.

The Host CPU has free access to the Message RAM. The special care has to be taken when reading FIFO elements in an arbitrary order (Get Index not considered). This can be useful when reading a High Priority Message from one of the two Rx FIFOs. In this case the FIFO's Acknowledge Index should not be written because this would set the Get Index to a wrong position and also changes the FIFO's Fill Level. In this case some of the older FIFO elements would be lost.

---

**Note**

The application has to ensure that a valid value is written to the FIFO Acknowledge Index. The MCAN module does not check for erroneous values.

---

#### 12.5.1.4.10 Message RAM

The MCAN module has implemented Message RAM. The main purpose of the Message RAM is to store:

- Receive Messages
- Transmit Messages
- Tx Event Elements
- Message ID Filter Elements

##### 12.5.1.4.10.1 Message RAM Configuration

The MCAN module is configured to allocate 4352 words in the Message RAM. The Message RAM has a width of 32 bits.

The Message RAM is capable to include each of the sections listed in [Figure 12-292](#). It is not necessary to configure each of the sections (a section in the Message RAM may be 0) and there is not restriction with respect to the sequence of the sections. For parity checking or ECC a respective number of bits has to be added to each word.

When the MCAN module addresses the Message RAM it addresses 32-bit words. The start addresses are configurable and they are 32-bit word addresses.

The element size can be configured for:

- Rx FIFO 0 via the MCAN\_RXESC[2-0] F0DS field
- Rx FIFO 1 via the MCAN\_RXESC[6-4] F1DS field
- Rx Buffers via the MCAN\_RXESC[10-8] RBDS field
- Tx Buffers via the MCAN\_TXESC[2-0] TBDS field



**Figure 12-292. Message RAM Configuration**

The Host CPU configures the following information in the Message RAM:

- Start addresses of the memory sections
- Number of elements in each section
- The size of the elements in some sections

---

**Note**

The MCAN module does not check for errors in the Message RAM configuration. The configuration of the start addresses of the different sections and the number of elements of each section has to be done carefully. This will prevent falsification or loss of data.

**12.5.1.4.10.2 Rx Buffer and FIFO Element**

Up to 64 Rx Buffers and two Rx FIFOs can be configured in the Message RAM. Each Rx FIFO section can be configured to store up to 64 received messages. The element size can be configured for storage of CAN FD messages with up to 64 bytes data field via the MCAN\_RXESC register.

Figure 12-293 shows Rx Buffer/Rx FIFO element structure.



mcan-016

**Figure 12-293. Rx Buffer/Rx FIFO Element Structure**

Table 12-261 shows Rx Buffer/Rx FIFO element field descriptions.

**Table 12-261. Rx Buffer/Rx FIFO Element Field Descriptions**

| Word | Bits | Field Name | Description                                                                                                                                                                                                                                                                                  |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 31   | ESI        | Error State Indicator<br><ul style="list-style-type: none"> <li>• 0h = Transmitting node is error active</li> <li>• 1h = Transmitting node is error passive</li> </ul>                                                                                                                       |
|      | 30   | XTD        | Extended Identifier<br>Signals to the Host CPU whether the received frame has a standard or extended identifier. <ul style="list-style-type: none"> <li>• 0h = 11-bit standard identifier</li> <li>• 1h = 29-bit extended identifier</li> </ul>                                              |
| R0   | 29   | RTR        | Remote Transmission Request<br>Signals to the Host CPU whether the received frame is a data frame or a remote frame. <ul style="list-style-type: none"> <li>• 0h = Received frame is a data frame</li> <li>• 1h = Received frame is a remote frame</li> </ul>                                |
| 28-0 | 28-0 | ID[28-0]   | <b>Note:</b> There are no remote frames in CAN FD format. In case a CAN FD frame was received (FDF = 1), RTR bit reflects the state of the reserved r1 bit (RES[23]).<br>Identifier<br>Standard or extended identifier depending on XTD bit. A standard identifier is stored into ID[28-18]. |

**Table 12-261. Rx Buffer/Rx FIFO Element Field Descriptions (continued)**

| Word | Bits  | Field Name | Description                                                                                                                                                                                                                                                                                                                      |
|------|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 31    | ANMF       | <p>Accepted Non-matching Frame</p> <p>Acceptance of non-matching frames may be enabled via the MCAN_GFC[5-4] ANFS and MCAN_GFC[3-2] ANFE fields.</p> <ul style="list-style-type: none"> <li>• 0h = Received frame matching filter index FIDX field</li> <li>• 1h = Received frame did not match any Rx filter element</li> </ul> |
|      | 30-24 | FIDX[6-0]  | <p>Filter Index</p> <p>0h-7Fh (0-127): Index of matching Rx acceptance filter element (invalid if ANMF = 1).</p> <p>Range is 0 to MCAN_SIDFC[23-16] LSS - 1 respectively MCAN_XIDFC[22-16] LSE - 1.</p>                                                                                                                          |
|      | 23-22 | RES        | Reserved                                                                                                                                                                                                                                                                                                                         |
| R1   | 21    | FDF        | <p>FD Format</p> <ul style="list-style-type: none"> <li>• 0h = Standard frame format</li> <li>• 1h = CAN FD frame format (new DLC-coding and CRC)</li> </ul>                                                                                                                                                                     |
|      | 20    | BRS        | <p>Bit Rate Switch</p> <ul style="list-style-type: none"> <li>• 0h = Frame received without bit rate switching</li> <li>• 1h = Frame received with bit rate switching</li> </ul>                                                                                                                                                 |
|      | 19-16 | DLC[3-0]   | <p>Data Length Code</p> <ul style="list-style-type: none"> <li>• 0h-8h (0-8) = CAN + CAN FD: received frame has 0-8 data bytes</li> <li>• 9h-Fh (9-15) = CAN: received frame has 8 data bytes</li> <li>• 9h-Fh (9-15) = CAN FD: received frame has 12/16/20/24/32/48/64 data bytes</li> </ul>                                    |
|      | 15-0  | RXTS[15-0] | <p>Rx Timestamp</p> <p>Timestamp Counter value captured on start of frame reception.</p> <p>Resolution depending on configuration of the Timestamp Counter Prescaler MCAN_TSCC[19-16] TCP.</p>                                                                                                                                   |
| R2   | 31-24 | DB3[7-0]   | Data Byte 3                                                                                                                                                                                                                                                                                                                      |
|      | 23-16 | DB2[7-0]   | Data Byte 2                                                                                                                                                                                                                                                                                                                      |
|      | 15-8  | DB1[7-0]   | Data Byte 1                                                                                                                                                                                                                                                                                                                      |
|      | 7-0   | DB0[7-0]   | Data Byte 0                                                                                                                                                                                                                                                                                                                      |
| R3   | 31-24 | DB7[7-0]   | Data Byte 7                                                                                                                                                                                                                                                                                                                      |
|      | 23-16 | DB6[7-0]   | Data Byte 6                                                                                                                                                                                                                                                                                                                      |
|      | 15-8  | DB5[7-0]   | Data Byte 5                                                                                                                                                                                                                                                                                                                      |
|      | 7-0   | DB4[7-0]   | Data Byte 4                                                                                                                                                                                                                                                                                                                      |
| ...  | ...   | ...        | ...                                                                                                                                                                                                                                                                                                                              |
| Rn   | 31-24 | DBm[7-0]   | Data Byte m                                                                                                                                                                                                                                                                                                                      |
|      | 23-16 | DBm-1[7-0] | Data Byte m-1                                                                                                                                                                                                                                                                                                                    |
|      | 15-8  | DBm-2[7-0] | Data Byte m-2                                                                                                                                                                                                                                                                                                                    |
|      | 7-0   | DBm-3[7-0] | Data Byte m-3                                                                                                                                                                                                                                                                                                                    |

**Note:** Depending on the configuration of the element size (MCAN\_RXESC), between two and sixteen 32-bit words (Rn = 3-17) are used for storage of a CAN message's data field.

#### 12.5.1.4.10.3 Tx Buffer Element

The Tx Buffers section can be configured to hold dedicated Tx Buffers as well as a Tx FIFO/Tx Queue. In case that the Tx Buffers section is shared by dedicated Tx buffers and a Tx FIFO/Tx Queue, the dedicated Tx Buffers start at the beginning of the Tx Buffers section followed by the buffers assigned to the Tx FIFO or Tx Queue. The Tx Handler makes difference between dedicated Tx Buffers and Tx FIFO/Tx Queue via the MCAN\_TXBC[29-24] TFQS and MCAN\_TXBC[21-16] NDTB fields. The element size can be configured for storage of CAN FD messages with up to 64 bytes data field via the MCAN\_TXESC register.

Figure 12-294 shows Tx Buffer element structure.



**Figure 12-294. Tx Buffer Element Structure**

Table 12-262 shows Tx Buffer element field descriptions.

**Table 12-262. Tx Buffer Element Field Descriptions**

| Word | Bits     | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | ESI      |            | <p>Error State Indicator</p> <ul style="list-style-type: none"> <li>0h = ESI bit in CAN FD format depends only on error passive flag</li> <li>1h = ESI bit in CAN FD format transmitted recessive</li> </ul> <p><b>Note:</b> The ESI bit of the transmit buffer is or'ed with the error passive flag to decide the value of the ESI bit in the transmitted CAN FD frame. As required by the CAN FD protocol specification, an error active node may optionally transmit the ESI bit recessive, but an error passive node will always transmit the ESI bit recessive.</p> |
| T0   | 30       | XTD        | <p>Extended Identifier</p> <ul style="list-style-type: none"> <li>0h = 11-bit standard identifier</li> <li>1h = 29-bit extended identifier</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 29   | RTR      |            | <p>Remote Transmission Request</p> <ul style="list-style-type: none"> <li>0h = Transmit data frame</li> <li>1h = Transmit remote frame</li> </ul> <p><b>Note:</b> When RTR = 1, the MCAN module transmits a remote frame according to ISO11898-1:2015, even if the MCAN_CCCR[8] FDOE bit enables the transmission in CAN FD format.</p>                                                                                                                                                                                                                                  |
| 28-0 | ID[28-0] |            | <p>Identifier</p> <p>Standard or extended identifier depending on XTD bit. A standard identifier has to be written to ID[28-18].</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**Table 12-262. Tx Buffer Element Field Descriptions (continued)**

| Word | Bits  | Field Name | Description                                                                                                                                                                                                                                                                                   |
|------|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 31-24 | MM[7-0]    | <p>Message Marker</p> <p>Written by Host CPU during Tx Buffer configuration. Copied into Tx Event FIFO element for identification of Tx message status (see also MM[7-0] field in <a href="#">Table 12-263</a>).</p>                                                                          |
|      | 23    | EFC        | <p>Event FIFO Control</p> <ul style="list-style-type: none"> <li>• 0h = Don't store Tx events</li> <li>• 1h = Store Tx events</li> </ul>                                                                                                                                                      |
|      | 22    | RES        | Reserved                                                                                                                                                                                                                                                                                      |
|      | 21    | FDF        | <p>FD Format</p> <ul style="list-style-type: none"> <li>• 0h = Frame transmitted in Classic CAN format</li> <li>• 1h = Frame transmitted in CAN FD format</li> </ul>                                                                                                                          |
| T1   |       |            | <p>Bit Rate Switch</p> <ul style="list-style-type: none"> <li>• 0h = CAN FD frames transmitted without bit rate switching</li> <li>• 1h = CAN FD frames transmitted with bit rate switching</li> </ul>                                                                                        |
|      | 20    | BRS        | <p><b>Note:</b> ESI, FDF, and BRS bits are only evaluated when CAN FD operation is enabled via the MCAN_CCCR[8] FDOE bit.</p> <p>BRS bit is only evaluated when in addition the MCAN_CCCR[9] BRSE = 1.</p>                                                                                    |
|      | 19-16 | DLC[3-0]   | <p>Data Length Code</p> <ul style="list-style-type: none"> <li>• 0h-8h (0-8) = CAN + CAN FD: transmit frame has 0-8 data bytes</li> <li>• 9h-Fh (9-15) = CAN: transmit frame has 8 data bytes</li> <li>• 9h-Fh (9-15) = CAN FD: transmit frame has 12/16/20/24/32/48/64 data bytes</li> </ul> |
|      | 15-0  | RES        | Reserved                                                                                                                                                                                                                                                                                      |
| T2   | 31-24 | DB3[7-0]   | Data Byte 3                                                                                                                                                                                                                                                                                   |
|      | 23-16 | DB2[7-0]   | Data Byte 2                                                                                                                                                                                                                                                                                   |
|      | 15-8  | DB1[7-0]   | Data Byte 1                                                                                                                                                                                                                                                                                   |
|      | 7-0   | DB0[7-0]   | Data Byte 0                                                                                                                                                                                                                                                                                   |
| T3   | 31-24 | DB7[7-0]   | Data Byte 7                                                                                                                                                                                                                                                                                   |
|      | 23-16 | DB6[7-0]   | Data Byte 6                                                                                                                                                                                                                                                                                   |
|      | 15-8  | DB5[7-0]   | Data Byte 5                                                                                                                                                                                                                                                                                   |
|      | 7-0   | DB4[7-0]   | Data Byte 4                                                                                                                                                                                                                                                                                   |
| ...  | ...   | ...        | ...                                                                                                                                                                                                                                                                                           |
| Tn   | 31-24 | DBm[7-0]   | Data Byte m                                                                                                                                                                                                                                                                                   |
|      | 23-16 | DBm-1[7-0] | Data Byte m-1                                                                                                                                                                                                                                                                                 |
|      | 15-8  | DBm-2[7-0] | Data Byte m-2                                                                                                                                                                                                                                                                                 |
|      | 7-0   | DBm-3[7-0] | Data Byte m-3                                                                                                                                                                                                                                                                                 |

**Note:** Depending on the configuration of the element size (MCAN\_TXESC), between two and sixteen 32-bit words (Tn = 3-17) are used for storage of a CAN message's data field.

#### 12.5.1.4.10.4 Tx Event FIFO Element

Each element stores information about transmitted messages. By reading the Tx Event FIFO the Host CPU gets this information in the order the messages were transmitted. Status information about the Tx Event FIFO can be obtained from the MCAN\_TXEFS register.

Figure 12-295 shows Tx Event FIFO element structure.



Figure 12-295. Tx Event FIFO Element Structure

Table 12-263 shows Tx Event FIFO element field descriptions.

Table 12-263. Tx Event FIFO Element Field Descriptions

| Word | Bits | Field Name | Description                                                                                                                                                     |
|------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| E0   | 31   | ESI        | Error State Indicator <ul style="list-style-type: none"> <li>0h = Transmitting node is error active</li> <li>1h = Transmitting node is error passive</li> </ul> |
|      | 30   | XTD        | Extended Identifier <ul style="list-style-type: none"> <li>0h = 11-bit standard identifier</li> <li>1h = 29-bit extended identifier</li> </ul>                  |
|      | 29   | RTR        | Remote Transmission Request <ul style="list-style-type: none"> <li>0h = Data frame transmitted</li> <li>1h = Remote frame transmitted</li> </ul>                |
|      | 28-0 | ID[28-0]   | Identifier<br>Standard or extended identifier depending on XTD bit. A standard identifier has to be written to ID[28-18].                                       |

**Table 12-263. Tx Event FIFO Element Field Descriptions (continued)**

| Word | Bits  | Field Name | Description                                                                                                                                                                                                                                                                                         |
|------|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 31-24 | MM[7-0]    | <p>Message Marker</p> <p>Copied from Tx Buffer into Tx Event FIFO element for identification of Tx message status (see also MM[7-0] field in <a href="#">Table 12-262</a>).</p>                                                                                                                     |
|      | 23-22 | ET[1-0]    | <p>Event Type</p> <ul style="list-style-type: none"> <li>0h = Reserved</li> <li>1h = Tx event</li> <li>2h = Transmission in spite of cancellation (always set for transmissions in DAR mode)</li> <li>3h = Reserved</li> </ul>                                                                      |
|      | 21    | FDF        | <p>FD Format</p> <ul style="list-style-type: none"> <li>0h = Standard frame format</li> <li>1h = CAN FD frame format (new DLC-coding and CRC)</li> </ul>                                                                                                                                            |
| E1   | 20    | BRS        | <p>Bit Rate Switch</p> <ul style="list-style-type: none"> <li>0h = Frame transmitted without bit rate switching</li> <li>1h = Frame transmitted with bit rate switching</li> </ul>                                                                                                                  |
|      | 19-16 | DLC[3-0]   | <p>Data Length Code</p> <ul style="list-style-type: none"> <li>0h-8h (0-8) = CAN + CAN FD: frame with 0-8 data bytes transmitted</li> <li>9h-Fh (9-15) = CAN: frame with 8 data bytes transmitted</li> <li>9h-Fh (9-15) = CAN FD: frame with 12/16/20/24/32/48/64 data bytes transmitted</li> </ul> |
|      | 15-0  | TXTS[15-0] | <p>Tx Timestamp</p> <p>Timestamp Counter value captured on start of frame transmission. Resolution depending on configuration of the Timestamp Counter Prescaler MCAN_TSCTC[19-16] TCP field.</p>                                                                                                   |

#### 12.5.1.4.10.5 Standard Message ID Filter Element

Up to 128 filter elements can be configured for 11-bit standard IDs. When accessing a Standard Message ID Filter element, its address is the Filter List Standard Start Address MCAN\_SIDFC[15-2] FLSSA field plus the index of the filter element (0-127).

[Figure 12-296](#) shows Standard Message ID Filter element structure.


**Figure 12-296. Standard Message ID Filter Element Structure**

[Table 12-264](#) shows Standard Message ID Filter element field descriptions.

Table 12-264. Standard Message ID Filter Element Field Descriptions

| Word  | Bits        | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             |             | Standard Filter Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31-30 | SFT[1-0]    |             | <ul style="list-style-type: none"> <li>0h = Range filter from SFID1 to SFID2 (SFID2 <math>\geq</math> SFID1)</li> <li>1h = Dual ID filter for SFID1 or SFID2</li> <li>2h = Classic filter: SFID1 = filter; SFID2 = mask</li> <li>3h = Filter element disabled</li> </ul> <p><b>Note:</b> With SFT = 11 the filter element is disabled and the acceptance filtering continues (same behaviour as with SFEC = 000)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 29-27 | SFEC[2-0]   |             | <p>Standard Filter Element Configuration</p> <p>All enabled filter elements are used for acceptance filtering of standard frames. Acceptance filtering stops at the first matching enabled filter element or when the end of the filter list is reached. If SFEC = 100, 101, or 110 a match sets interrupt flag MCAN_IR[8]HPM and, if enabled, an interrupt is generated. In this case the MCAN_HPMs register is updated with the status of the priority match.</p> <ul style="list-style-type: none"> <li>0h = Disable filter element</li> <li>1h = Store in Rx FIFO 0 if filter matches</li> <li>2h = Store in Rx FIFO 1 if filter matches</li> <li>3h = Reject ID if filter matches</li> <li>4h = Set priority if filter matches</li> <li>5h = Set priority and store in FIFO 0 if filter matches</li> <li>6h = Set priority and store in FIFO 1 if filter matches</li> <li>7h = Store into Rx Buffer , configuration of SFT[1-0] ignored</li> </ul> |
| S0    | 26-16       | SFID1[10-0] | <p>Standard Filter ID 1</p> <p>When filtering for Rx Buffers this field defines the ID of a standard message to be stored. The received identifiers must match exactly, no masking mechanism is used.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 15-11       | RES         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | SFID2[10-0] |             | <p>Standard Filter ID 2</p> <p>This bit field has a different meaning depending on the configuration of SFEC:</p> <ul style="list-style-type: none"> <li>1) SFEC = 001 - 110 Second ID of standard ID filter element</li> <li>2) SFEC = 111 Filter for Rx Buffers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10-0  | SFID2[10-9] |             | <p>This field is decides whether the received message is stored into an Rx Buffer or treated as message A, B, or C of the debug message sequence.</p> <ul style="list-style-type: none"> <li>0h = Store message into an Rx Buffer</li> <li>1h = Debug Message A</li> <li>2h = Debug Message B</li> <li>3h = Debug Message C</li> </ul> <p><b>Note:</b> Debug feature is not supported.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | SFID2[8-6]  |             | <p>This field is used to control the filter event pins at the Extension Interface. A one at the respective bit position enables generation of a pulse at the related filter event pin with the duration of one MCAN_ICKL period in case the filter matches.</p> <p><b>Note:</b> Only three filter event pins are supported.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       | SFID2[5-0]  |             | <p>This field defines the offset to the Rx Buffer Start Address</p> <p>MCAN_RXBC[15-21] RBSA field for storage of a matching message.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

#### 12.5.1.4.10.6 Extended Message ID Filter Element

Up to 64 filter elements can be configured for 29-bit extended IDs. When accessing an Extended Message ID Filter element, its address is the Filter List Extended Start Address MCAN\_XIDFC[15-2] FLESA field plus two times the index of the filter element (0-63).

Figure 12-297 shows Extended Message ID Filter element structure.



**Figure 12-297. Extended Message ID Filter Element Structure**

Table 12-265 shows Extended Message ID Filter element field descriptions.

**Table 12-265. Extended Message ID Filter Element Field Descriptions**

| Word | Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 31-29 | EFEC[2-0]   | <p>Extended Filter Element Configuration</p> <p>All enabled filter elements are used for acceptance filtering of extended frames. Acceptance filtering stops at the first matching enabled filter element or when the end of the filter list is reached. If EFEC = 100, 101, or 110 a match sets interrupt flag MCAN_IR[8]HPM and, if enabled, an interrupt is generated. In this case the MCAN_HPMs register is updated with the status of the priority match.</p> <ul style="list-style-type: none"> <li>• 0h = Disable filter element</li> <li>• 1h = Store in Rx FIFO 0 if filter matches</li> <li>• 2h = Store in Rx FIFO 1 if filter matches</li> <li>• 3h = Reject ID if filter matches</li> <li>• 4h = Set priority if filter matches</li> <li>• 5h = Set priority and store in FIFO 0 if filter matches</li> <li>• 6h = Set priority and store in FIFO 1 if filter matches</li> <li>• 7h = Store into Rx Buffer or as debug message, configuration of EFT[1-0] ignored</li> </ul> |
| F0   | 28-0  | EFID1[28-0] | <p>Extended Filter ID 1</p> <p>First ID of extended ID filter element.</p> <p>When filtering for Rx Buffers this field defines the ID of an extended message to be stored. The received identifiers must match exactly, only XIDAM masking mechanism (see <a href="#">Section 12.5.1.4.7.1.5, Extended Message ID Filtering</a>) is used.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**Table 12-265. Extended Message ID Filter Element Field Descriptions (continued)**

| Word | Bits  | Field Name  | Description                                                                                                                                                                                                                                                                                                                                            |
|------|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 31-30 | EFT[1-0]    | Extended Filter Type<br>• 0h = Range filter from EFID1 to EFID2 (EFID2 $\geq$ EFID1)<br>• 1h = Dual ID filter for EFID1 or EFID2<br>• 2h = Classic filter: EFID1 = filter, EFID2 = mask<br>• 3h = Range filter from EFID1 to EFID2 (EFID2 $\geq$ EFID1),<br>XIDAM mask not applied                                                                     |
|      | 29    | RES         | Reserved                                                                                                                                                                                                                                                                                                                                               |
|      |       | EFID2[28-0] | Extended Filter ID 2<br>This bit field has a different meaning depending on the configuration of EFEC:<br>• 1) EFEC = 001 - 110 Second ID of extended ID filter element<br>• 2) EFEC = 111 Filter for Rx Buffers                                                                                                                                       |
| F1   | 28-0  | EFID2[10-9] | This field decides whether the received message is stored into an Rx Buffer or treated as message A, B, or C of the debug message sequence.<br>• 0h = Store message into an Rx Buffer<br>• 1h = Debug Message A<br>• 2h = Debug Message B<br>• 3h = Debug Message C                                                                                    |
|      |       | EFID2[8-6]  | Note: Debug feature is not supported.<br>This field is used to control the filter event pins at the Extension Interface. A one at the respective bit position enables generation of a pulse at the related filter event pin with the duration of one MCAN_ICKL period in case the filter matches.<br>Note: Only three filter event pins are supported. |
|      |       | EFID2[5-0]  | This field defines the offset to the Rx Buffer Start Address MCAN_RXBC[15-2] RBSA field for storage of a matching message.                                                                                                                                                                                                                             |

### 12.5.2 Enhanced Capture (ECAP) Module

This section describes the Enhanced Capture (ECAP) module in the device.

#### 12.5.2.1 ECAP Overview

The Enhanced Capture (ECAP) module can be used for:

- Sample rate measurements of audio inputs
- Speed measurements of rotating machinery (for example, toothed sprockets sensed via Hall sensors)
- Elapsed time measurements between position sensor pulses
- Period and duty cycle measurements of pulse train signals
- Decoding current or voltage amplitude derived from duty cycle encoded current/voltage sensors

Figure 12-298 shows the ECAP modules overview.



A.  $i = 0$  to number of instances - 1.

**Figure 12-298. ECAP Overview**

### 12.5.2.1.1 ECAP Features

The ECAP module includes the following features:

- 32-bit time base counter
- 4 × 32 bits event time-stamp capture registers (ECAP0\_CAP1 through ECAP0\_CAP4)
- 4-stage sequencer (Mod4 counter), synchronized to external events (ECAPx pin edges)
- Independent edge polarity (rising / falling edge) selection for all 4 sequenced time-stamp capture events
- Input capture signal pre-scaling (from 1 to 16)
- One-shot compare register (2 bits) to freeze captures after 1 to 4 time-stamp events
- Continuous mode capture of time-stamps in a four-deep circular buffer
- Interrupt capabilities on any of the 4 capture events
- Absolute time-stamp capture
- Difference (Delta) mode time-stamp capture
- All above resources dedicated to a single input pin
- When not used in capture mode, the ECAP module can be configured as a single channel PWM output

### 12.5.2.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

### 12.5.2.2 ECAP Environment

#### 12.5.2.2.1 ECAP I/O Interface

This section describes the ECAP external connections (environment).

Figure 12-299 shows the ECAP interface signals.



#### Note

i represents an ECAP instance. See the device datasheet for available domains and ECAP instances

**Figure 12-299. ECAP External Interface I/Os**

Table 12-266 describes the ECAP I/O signals.

**Table 12-266. ECAP I/O Signals**

| Module Pin                          | Device Level Signal               | I/O <sup>(1)</sup> | Description                                     | Module Pin<br>Reset Value <sup>(2)</sup> |
|-------------------------------------|-----------------------------------|--------------------|-------------------------------------------------|------------------------------------------|
| <b>ECAPi<sup>(3)</sup></b>          |                                   |                    |                                                 |                                          |
| ECAPi <sup>(3)</sup> _CAPIN_APWMOUT | ECAPi <sup>(3)</sup> _IN_APWM_OUT | I/O                | ECAPi <sup>(3)</sup> Capture input / PWM output | HiZ                                      |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) i represents an ECAP instance. See the device datasheet for available domains and ECAP instances

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

### 12.5.2.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.5.2.4 ECAP Functional Description

The ECAP module represents one complete capture channel, which has the following independent key resources:

- Dedicated input capture pin
- 32 events selection mapping capability to the input capture pin
- 32-bit time base counter
- $4 \times 32$ -bit time-stamp capture registers (ECAP0\_CAP1 through ECAP0\_CAP4)
- 4-stage sequencer (Mod4 counter) that is synchronized to external events, ECAP pin rising/falling edges.
- Independent edge polarity (rising/falling edge) selection for all 4 events
- Input capture signal prescaling (from 2-62)
- One-shot compare register (2 bits) to freeze captures after 1 to 4 time-stamp events
- Control for continuous time-stamp captures using a 4-deep circular buffer (ECAP0\_CAP1 through ECAP0\_CAP4) scheme
- Interrupt capabilities on any of the 4 capture events

Multiple identical ECAP modules can be contained in a system as shown in [Figure 12-300](#). For actual number of the ECAP modules integrated in the device, refer to [ECAP Integration](#). The letter x within a signal or module name is used to indicate a generic ECAP instance on a device. For example, output interrupt request, ECAP1INT belongs to ECAP1, ECAP2INT belongs to ECAP2, and so forth.



ecap-003

**Figure 12-300. Multiple ECAP Modules**

#### 12.5.2.4.1 Capture and APWM Operating Modes

The ECAP module resources can be used to implement a single-channel PWM generator (with 32-bit capabilities) when it is not being used for input captures. The counter operates in count-up mode, providing a time-base for asymmetrical pulse width modulation (PWM) waveforms. The ECAP0\_CAP1 and ECAP0\_CAP2 registers become the active period and compare registers, respectively, while the ECAP0\_CAP3 and ECAP0\_CAP4 registers become the period and capture shadow registers, respectively. [Figure 12-301](#) is a high-level view of both the capture and auxiliary pulse-width modulator (APWM) modes of operation.



ecap-004

- A single pin is shared between CAP and APWM functions. In capture mode, it is an input. In APWM mode, it is an output.
- In APWM mode, writing any value to the ECAP0\_CAP1/ECAP0\_CAP2 active registers also writes the same value to the corresponding shadow registers (ECAP0\_CAP3/ECAP0\_CAP4). This emulates immediate mode. Writing to the shadow registers (ECAP0\_CAP3/ECAP0\_CAP4) invokes the shadow mode.

**Figure 12-301. Capture and APWM Modes of Operation**

#### 12.5.2.4.1.1 ECAP Capture Mode Description

Figure 12-302 shows the various components that implement the capture function.



**Figure 12-302. Capture Function Diagram**

#### 12.5.2.4.1.1 ECAP Event Prescaler

An input capture signal (pulse train) can be prescaled by  $N = 2-62$  (in multiples of 2) or can bypass the prescaler. This is useful when very high frequency signals are used as inputs. Figure 12-303 shows a functional diagram and Figure 12-304 shows the operation of the prescale function.



- A. When a prescale value of 1 is chosen (ECAP0\_ECCCTL[13-9] EVTFLTPS = 0b0000) the input capture signal by-passes the prescale logic completely.

**Figure 12-303. Event Prescale Control**



**Figure 12-304. Prescale Function Waveforms**

#### 12.5.2.4.1.1.2 ECAP Edge Polarity Select and Qualifier

- Four independent edge polarity (rising edge/falling edge) selection multiplexers are used, one for each capture event.
- Each edge (up to 4) is event qualified by the Mod4 sequencer.
- The edge event is gated to its respective CAPn register by the Mod4 counter. The CAPn register is loaded on the falling edge.

#### 12.5.2.4.1.1.3 ECAP Continuous/One-Shot Control

- The Mod4 (2-bit) counter is incremented via edge qualified events CEVT1 through CEVT4 (see the ECAP0\_ECINT\_EN\_FLG register).
- The Mod4 counter continues counting (0->1->2->3->0) and wraps around unless stopped.
- A 2-bit stop register is used to compare the Mod4 counter output; when equal the Mod4 counter stops and inhibits further loads of the ECAP0\_CAP1 through ECAP0\_CAP4 registers. This occurs during one-shot operation.

The continuous/one-shot block (Figure 12-305) controls the start/stop and reset (zero) functions of the Mod4 counter via a mono-shot type of action that can be triggered by the stop-value comparator and re-armed via software control.

Once armed, the ECAP module waits for 1-4 (defined by stop-value) capture events before freezing both the Mod4 counter and contents of the ECAP0\_CAP1 through ECAP0\_CAP4 registers (time-stamps).

Re-arming prepares the ECAP module for another capture sequence. Also re-arming clears (to zero) the Mod4 counter and permits loading of the ECAP0\_CAP1 through ECAP0\_CAP4 registers again, providing the ECAP0\_ECCTL[8] CAPLDEN bit is set.

In continuous mode, the Mod4 counter continues to run (0->1->2->3->0), the one-shot action is ignored, and capture values continue to be written to the ECAP0\_CAP1 through ECAP0\_CAP4 registers in a circular buffer sequence.



ecap-008

Figure 12-305. ECAP Continuous/One-shot Block Diagram

#### 12.5.2.4.1.1.4 ECAP 32-Bit Counter and Phase Control

This counter (Figure 12-306) provides the time-base for event captures, and is clocked via the system clock.

A phase register is provided to achieve synchronization with other counters, via a hardware and software forced sync. This is useful in APWM mode when a phase offset between modules is needed.

On any of the four event loads, an option to reset the 32-bit counter is given. This is useful for time difference capture. The 32-bit counter value is captured first, then it is reset to 0 by any of the LD1 through LD4 signals.



**Figure 12-306. ECAP Counter and Synchronization Block Diagram**

#### 12.5.2.4.1.1.5 CAP1-CAP4 Registers

These 32-bit registers are fed by the 32-bit counter timer bus, CTR[0-31] and are loaded (capture a time-stamp) when their respective LD inputs are strobed.

Loading of the capture registers can be inhibited via the control ECAP0\_ECCTL[8] CAPLDEN bit. During one-shot operation, this bit is cleared (loading is inhibited) automatically when a stop condition occurs, StopValue = Mod4.

The ECAP0\_CAP1 and ECAP0\_CAP2 registers become the active period and compare registers, respectively, in APWM mode.

The ECAP0\_CAP3 and ECAP0\_CAP4 registers become the respective shadow registers (APRD and ACMP) for the ECAP0\_CAP1 and ECAP0\_CAP2 registers during APWM operation.

#### 12.5.2.4.1.1.6 ECAP Interrupt Control

An interrupt can be generated on capture events CEVT1 through CEVT4, CNTOVF (see the ECAP0\_ECINT\_EN\_FLG[21] CNTOVF\_FLG bit) or APWM events (TSCNT = PRD, TSCNT = CMP). See [Figure 12-307](#).

A counter overflow event (FFFF FFFFh->0000 0000h) is also provided as an interrupt source (CNTOVF).

The capture events are edge and sequencer qualified (that is, ordered in time) by the polarity select and Mod4 gating, respectively.

One of these events can be selected as the interrupt source (from the ECAPn module) going to the interrupt controller.

Seven interrupt events (CEVT1, CEVT2, CEVT3, CEVT4, CNTOVF, TSCNT = PRD, TSCNT = CMP) can be generated. The interrupt enable register (ECAP0\_ECINT\_EN\_FLG) is used to enable/disable individual interrupt event sources. The interrupt flag register (ECAP0\_ECINT\_EN\_FLG) indicates if any interrupt event has been latched and contains the global interrupt flag ECAP0\_ECINT\_EN\_FLG[16] INT\_FLG bit. An interrupt pulse is generated to the interrupt controller only if any of the interrupt events are enabled, the flag bit is 1h, and the INT\_FLG flag bit is 0h. The interrupt service routine must clear the global interrupt flag bit and the serviced event via the interrupt clear register (ECAP0\_ECINT\_CLR\_FRC) before any other interrupt pulses are generated. The interrupt force register (ECAP0\_ECINT\_CLR\_FRC) can force an interrupt event. This is useful for test purposes.

#### 12.5.2.4.1.1.7 ECAP Shadow Load and Lockout Control

In capture mode, this logic inhibits (locks out) any shadow loading of the ECAP0\_CAP1 or ECAP0\_CAP2 registers from APRD and ACMP registers, respectively.

In APWM mode, shadow loading is active and two choices are permitted:

- Immediate - APRD or ACMP are transferred to the ECAP0\_CAP1 or ECAP0\_CAP2 register immediately upon writing a new value.
- On period equal, CTR[31-0] = PRD[31-0]

---

#### Note

The CEVT1\_FLG, CEVT2\_FLG, CEVT3\_FLG, CEVT4\_FLG flags are only active in capture mode (ECAP0\_ECCTL[25] CAP\_APWM == 0h). The TSCNT = PRD, TSCNT = CMP flags are only valid in APWM mode (ECAP0\_ECCTL[25] CAP\_APWM == 1h). CNTOVF\_FLG flag is valid in both modes.



ecap-010

**Figure 12-307. Interrupts in ECAP Module**

#### 12.5.2.4.1.2 ECAP APWM Mode Operation

Main operating highlights of the APWM section:

- The time-stamp counter bus is made available for comparison via 2 digital (32-bit) comparators.
- When the ECAP0\_CAP1/ECAP0\_CAP2 registers are not used in capture mode, their contents can be used as Period and Compare values in APWM mode.
- Double buffering is achieved via the shadow registers - APRD and ACMP (ECAP0\_CAP3/ECAP0\_CAP4). The shadow register contents are transferred over to ECAP0\_CAP1/ECAP0\_CAP2 registers either immediately upon a write, or on a TSCNT = PRD trigger.
- In APWM mode, writing to the ECAP0\_CAP1/ECAP0\_CAP2 active registers will also write the same value to the corresponding shadow registers (ECAP0\_CAP3/ECAP0\_CAP4). This emulates immediate mode. Writing to the shadow registers (ECAP0\_CAP3/ECAP0\_CAP4) will invoke the shadow mode.
- During initialization, software must write the PRD and CMP values to the active registers. This automatically copies the initial values into the shadow values. For subsequent compare updates, during run-time, software should use only shadow registers.



**Figure 12-308. PWM Waveform Details of ECAP APWM Mode Operation**

The behavior of APWM active-high mode (APWMPOL == 0) is:

CMP = 0x00000000, output low for duration of period (0% duty)

CMP = 0x00000001, output high 1 cycle

CMP = 0x00000002, output high 2 cycles

CMP = PERIOD, output high except for 1 cycle (<100% duty)

CMP = PERIOD+1, output high for complete period (100% duty)

CMP > PERIOD+1, output high for complete period

The behavior of APWM active-low mode (APWMPOL == 1) is:

CMP = 0x00000000, output high for duration of period (0% duty)

CMP = 0x00000001, output low 1 cycle

CMP = 0x00000002, output low 2 cycles

CMP = PERIOD, output low except for 1 cycle (<100% duty)

CMP = PERIOD+1, output low for complete period (100% duty)

CMP > PERIOD+1, output low for complete period

#### 12.5.2.4.2 Summary of ECAP Functional Registers

Table 12-267 shows the ECAP module control and status register set. All 32-bit registers are aligned on even address boundaries and are organized in little-endian mode.

---

#### Note

In APWM mode, writing to the ECAP0\_CAP1/ECAP0\_CAP2 active registers also writes the same value to the corresponding shadow registers (ECAP0\_CAP3/ECAP0\_CAP4). This emulates immediate mode. Writing to the shadow registers (ECAP0\_CAP3/ECAP0\_CAP4) invokes the shadow mode.

**Table 12-267. ECAP Control and Status Functional Registers**

| Offset | Register Name       | Description                                  | Size (×16) |
|--------|---------------------|----------------------------------------------|------------|
| 0h     | ECAP0_TSCNT         | Time-Stamp Counter Register                  | 2          |
| 4h     | ECAP0_CNTPHS        | Counter Phase Offset Value Register          | 2          |
| 8h     | ECAP0_CAP1          | Capture 1 Register                           | 2          |
| Ch     | ECAP0_CAP2          | Capture 2 Register                           | 2          |
| 10h    | ECAP0_CAP3          | Capture 3 Register                           | 2          |
| 14h    | ECAP0_CAP4          | Capture 4 Register                           | 2          |
| 28h    | ECAP0_ECCTL         | Capture Control Register                     | 2          |
| 2Ch    | ECAP0_ECINT_EN_FLG  | Capture Interrupt Enable and Flag Register   | 2          |
| 30h    | ECAP0_ECINT_CLR_FRC | Capture Interrupt Clear and Forcing Register | 2          |
| 5Ch    | ECAP0_PID           | Revision ID Register                         | 2          |

---

#### Note

For more information on the ECAP registers, see *ECAP Registers*.

### 12.5.2.5 ECAP Use Cases

The following sections will provide applications examples and code snippets to show how to configure and operate the ECAP module. For clarity and ease of use, below are useful #defines which will help in the understanding of the examples.

```

// ECCTL1 ( ECAP Control Reg 1)
//=====
// CAPxPOL bits
#defineEC_RISING      0x0
#defineEC_FALLING     0x1
// CTRRSTX bits
#defineEC_ABS_MODE    0x0
#defineEC_DELTA_MODE   0x1
// PRESCALE bits
#defineEC_BYPASS      0x0
#defineEC_DIV1        0x0
#defineEC_DIV2        0x1
#defineEC_DIV4        0x2
#defineEC_DIV6        0x3
#defineEC_DIV8        0x4
#defineEC_DIV10       0x5
// ECCTL2 ( ECAP Control Reg 2)
//=====
// CONT/ONESHOT bit
#defineEC_CONTINUOUS   0x0
#defineEC_ONESHOT      0x1
// STOPVALUE bit
#defineEC_EVENT1       0x0
#defineEC_EVENT2       0x1
#defineEC_EVENT3       0x2
#defineEC_EVENT4       0x3
// RE-ARM bit
#defineEC_ARM          0x1
// TSCTRSTOP bit
#defineEC_FREEZE       0x0
#defineEC_RUN          0x1
// SYNCSEL bit
#defineEC_SYNCIN        0x0
#defineEC_CTR_PRD       0x1
#defineEC_SYNC_DIS      0x2
// CAP/APWM mode bit
#defineEC_CAP_MODE      0x0
#defineEC_APWM_MODE     0x1
// APWMPOL bit
#defineEC_ACTV_HI       0x0
#defineEC_ACTV_LO       0x1
// Generic
#defineEC_DISABLE       0x0
#defineEC_ENABLE        0x1
#defineEC_FORCE         0x1

```

#### 12.5.2.5.1 Absolute Time-Stamp Operation Rising Edge Trigger Example

Figure 12-309 shows an example of continuous capture operation (Mod4 counter wraps around). In this figure, TSCTR counts-up without resetting and capture events are qualified on the rising edge only, this gives period (and frequency) information.

On an event, the TSCTR contents (time-stamp) is first captured, then Mod4 counter is incremented to the next state. When the TSCTR reaches FFFF FFFFh (maximum value), it wraps around to 0000 0000h (not shown in Figure 12-309), if this occurs, the CTOVF\_FLG (counter overflow) flag is set, and an interrupt (if enabled) occurs. Captured time-stamps are valid at the point indicated by the diagram, after the 4-th event, hence event CEVT4 can conveniently be used to trigger an interrupt and the CPU can read data from the CAPn registers.



**Figure 12-309. Capture Sequence for Absolute Time-Stamp, Rising Edge Detect**

**Table 12-268. ECAP Initialization for CAP Mode Absolute Time, Rising Edge Trigger**

| Register | Bit        | Value         |
|----------|------------|---------------|
| ECCTL1   | CAP1POL    | EC_RISING     |
| ECCTL1   | CAP2POL    | EC_RISING     |
| ECCTL1   | CAP3POL    | EC_RISING     |
| ECCTL1   | CAP4POL    | EC_RISING     |
| ECCTL1   | CTRIRST1   | EC_ABS_MODE   |
| ECCTL1   | CTRIRST2   | EC_ABS_MODE   |
| ECCTL1   | CTRIRST3   | EC_ABS_MODE   |
| ECCTL1   | CTRIRST4   | EC_ABS_MODE   |
| ECCTL1   | CAPLDEN    | EC_ENABLE     |
| ECCTL1   | PRESCALE   | EC_DIV1       |
| ECCTL2   | CAP_APWM   | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESH | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL  | EC_SYNCO_DIS  |
| ECCTL2   | SYNCI_EN   | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP  | EC_RUN        |

**Example 12-1. Code Snippet for CAP Mode Absolute Time, Rising Edge Trigger**

```

// Code snippet for CAP mode Absolute Time, Rising edge trigger
// Run Time ( e.g. CEVT4 triggered ISR call)
//=====
TSt1 = ECAPxRegs.CAP1;// Fetch Time-Stamp captured at t1
TSt2 = ECAPxRegs.CAP2;// Fetch Time-Stamp captured at t2
TSt3 = ECAPxRegs.CAP3;// Fetch Time-Stamp captured at t3
TSt4 = ECAPxRegs.CAP4;// Fetch Time-Stamp captured at t4
Period1 = TSt2-TSt1;// Calculate 1st period
Period2 = TSt3-TSt2;// Calculate 2nd period
Period3 = TSt4-TSt3;// Calculate 3rd period

```

#### 12.5.2.5.2 Absolute Time-Stamp Operation Rising and Falling Edge Trigger Example

In Figure 12-310 the ECAP operating mode is almost the same as in the previous section except capture events are qualified as either rising or falling edge, this now gives both period and duty cycle information: Period1 =  $t_3 - t_1$ , Period2 =  $t_5 - t_3$ , ...etc. Duty Cycle1 (on-time %) =  $(t_2 - t_1) / \text{Period1} \times 100\%$ , etc. Duty Cycle1 (off-time %) =  $(t_3 - t_2) / \text{Period1} \times 100\%$ , etc.



ecap\_015

**Figure 12-310. Capture Sequence for Absolute Time-Stamp, Rising and Falling Edge Detect**

**Table 12-269. ECAP Initialization for CAP Mode Absolute Time, Rising and Falling Edge Trigger**

| Register | Bit        | Value         |
|----------|------------|---------------|
| ECCTL1   | CAP1POL    | EC_RISING     |
| ECCTL1   | CAP2POL    | EC_FALLING    |
| ECCTL1   | CAP3POL    | EC_RISING     |
| ECCTL1   | CAP4POL    | EC_FALLING    |
| ECCTL1   | CTRIRST1   | EC_ABS_MODE   |
| ECCTL1   | CTRIRST2   | EC_ABS_MODE   |
| ECCTL1   | CTRIRST3   | EC_ABS_MODE   |
| ECCTL1   | CTRIRST4   | EC_ABS_MODE   |
| ECCTL1   | CAPLDEN    | EC_ENABLE     |
| ECCTL1   | PRESCALE   | EC_DIV1       |
| ECCTL2   | CAP_APWM   | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESH | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL  | EC_SYNCO_DIS  |
| ECCTL2   | SYNCl_EN   | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP  | EC_RUN        |

**Example 12-2. Code Snippet for CAP Mode Absolute Time, Rising and Falling Edge Trigger**

```

// Code snippet for CAP mode Absolute Time, Rising & Falling edge triggers
// Run Time ( e.g. CEVT4 triggered ISR call)
//=====
TSt1 = ECAPxRegs.CAP1;// Fetch Time-Stamp captured at t1
TSt2 = ECAPxRegs.CAP2;// Fetch Time-Stamp captured at t2
TSt3 = ECAPxRegs.CAP3;// Fetch Time-Stamp captured at t3
TSt4 = ECAPxRegs.CAP4;// Fetch Time-Stamp captured at t4
Period1 = TSt3-TSt1;// Calculate 1st period
DutyOnTime1 = TSt2-TSt1;// Calculate On time
DutyoffTime1 = TSt3-TSt2;// Calculate Off time

```

### 12.5.2.5.3 Time Difference (Delta) Operation Rising Edge Trigger Example

Figure 12-311 shows how the ECAP module can be used to collect Delta timing data from pulse train waveforms. Here Continuous Capture mode (TSCTR counts-up without resetting, and Mod4 counter wraps around) is used. In Delta-time mode, TSCTR is Reset back to Zero on every valid event. Here Capture events are qualified as Rising edge only. On an event, TSCTR contents (time-stamp) is captured first, and then TSCTR is reset to Zero. The Mod4 counter then increments to the next state. If TSCTR reaches FFFF FFFFh (maximum value), before the next event, it wraps around to 0000 0000h and continues, a CNTOVF\_FLG (counter overflow) Flag is set, and an Interrupt (if enabled) occurs. The advantage of Delta-time Mode is that the CAPn contents directly give timing data without the need for CPU calculations: Period1 = T<sub>1</sub>, Period2 = T<sub>2</sub>,...etc. As shown in Figure 12-311, the CEVT1 event is a good trigger point to read the timing data, T<sub>1</sub>, T<sub>2</sub>, T<sub>3</sub>, T<sub>4</sub> are all valid here.



**Figure 12-311. Capture Sequence for Delta Mode Time-Stamp, Rising Edge Detect**

**Table 12-270. ECAP Initialization for CAP Mode Delta Time, Rising Edge Trigger**

| Register | Bit        | Value         |
|----------|------------|---------------|
| ECCTL1   | CAP1POL    | EC_RISING     |
| ECCTL1   | CAP2POL    | EC_RISING     |
| ECCTL1   | CAP3POL    | EC_RISING     |
| ECCTL1   | CAP4POL    | EC_RISING     |
| ECCTL1   | CTR_RST1   | EC_DELTA_MODE |
| ECCTL1   | CTR_RST2   | EC_DELTA_MODE |
| ECCTL1   | CTR_RST3   | EC_DELTA_MODE |
| ECCTL1   | CTR_RST4   | EC_DELTA_MODE |
| ECCTL1   | CAPLDEN    | EC_ENABLE     |
| ECCTL1   | PRESCALE   | EC_DIV1       |
| ECCTL2   | CAP_APWM   | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESH | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL  | EC_SYNCO_DIS  |
| ECCTL2   | SYNCI_EN   | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP  | EC_RUN        |

**Example 12-3. Code Snippet for CAP Mode Delta Time, Rising Edge Trigger**

```

// Code snippet for CAP mode Delta Time, Rising edge trigger
// Run Time ( e.g. CEVT1 triggered ISR call)
//=====
// Note: here Time-stamp directly represents the Period value.
Period4 = ECAPxRegs.CAP1;// Fetch Time-Stamp captured at T1
Period1 = ECAPxRegs.CAP2;// Fetch Time-Stamp captured at T2
Period2 = ECAPxRegs.CAP3;// Fetch Time-Stamp captured at T3
Period3 = ECAPxRegs.CAP4;// Fetch Time-Stamp captured at T4

```

#### 12.5.2.5.4 Time Difference (Delta) Operation Rising and Falling Edge Trigger Example

In Figure 12-312 the ECAP operating mode is almost the same as in previous section except Capture events are qualified as either Rising or Falling edge, this now gives both Period and Duty cycle information: Period1 =  $T_1 + T_2$ , Period2 =  $T_3 + T_4$ , ...etc Duty Cycle1 (on-time %) =  $T_1 / \text{Period1} \times 100\%$ , etc Duty Cycle1 (off-time %) =  $T_2 / \text{Period1} \times 100\%$ , etc.

During initialization, you must write to the active registers for both period and compare. This will then automatically copy the init values into the shadow values. For subsequent compare updates, that is, during run-time, only the shadow registers must be used.



**Figure 12-312. Capture Sequence for Delta Mode Time-Stamp, Rising and Falling Edge Detect**

**Table 12-271. ECAP Initialization for CAP Mode Delta Time, Rising and Falling Edge Triggers**

| Register | Bit        | Value         |
|----------|------------|---------------|
| ECCTL1   | CAP1POL    | EC_RISING     |
| ECCTL1   | CAP2POL    | EC_FALLING    |
| ECCTL1   | CAP3POL    | EC_RISING     |
| ECCTL1   | CAP4POL    | EC_FALLING    |
| ECCTL1   | CTR_RST1   | EC_DELTA_MODE |
| ECCTL1   | CTR_RST2   | EC_DELTA_MODE |
| ECCTL1   | CTR_RST3   | EC_DELTA_MODE |
| ECCTL1   | CTR_RST4   | EC_DELTA_MODE |
| ECCTL1   | CAPLDEN    | EC_ENABLE     |
| ECCTL1   | PRESCALE   | EC_DIV1       |
| ECCTL2   | CAP_APWM   | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESH | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL  | EC_SYNCO_DIS  |
| ECCTL2   | SYNCI_EN   | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP  | EC_RUN        |

**Example 12-4. Code Snippet for CAP Mode Delta Time, Rising and Falling Edge Triggers**

```

// Code snippet for CAP mode Delta Time, Rising and Falling edge triggers
// Run Time ( e.g. CEVT1 triggered ISR call)
//=====
// Note: here Time-stamp directly represents the Duty cycle values.
DutyOnTime1 = ECAPxRegs.CAP2;// Fetch Time-Stamp captured at T2
DutyOffTime1 = ECAPxRegs.CAP3;// Fetch Time-Stamp captured at T3
DutyOnTime2 = ECAPxRegs.CAP4;// Fetch Time-Stamp captured at T4
DutyOffTime2 = ECAPxRegs.CAP1;// Fetch Time-Stamp captured at T1
Period1 = DutyOnTime1 + DutyOffTime1;
Period2 = DutyOnTime2 + DutyOffTime2;

```

### 12.5.2.5.5 Application of the APWM Mode

#### 12.5.2.5.5.1 Simple PWM Generation (Independent Channel/s) Example

In this example, the ECAP module is configured to operate as a PWM generator. Here a very simple single channel PWM waveform is generated from output pin APWM<sub>Mn</sub>. The PWM polarity is active high, which means that the compare value (CAP2 reg is now a compare register) represents the on-time (high level) of the period. Alternatively, if the APWMPOL bit is configured for active low, then the compare value represents the off-time.



**Figure 12-313. PWM Waveform Details of APWM Mode Operation**

Table 12-272. ECAP Initialization for APWM Mode

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 0x1000       |
| CTRPHS   | CTRPHS    | 0x0          |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCl_EN  | EC_DISABLE   |
| ECCTL2   | SYNCO_SEL | EC_SYNCO_DIS |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

**Example 12-5. Code Snippet for APWM Mode**

```

// Code snippet for APWM mode Example 1
// Run Time (Instant 1, e.g. ISR call)
//=====
ECAPxRegs.CAP2 = 0x300;      // Set duty cycle i.e. compare value
// Run Time (Instant 2, e.g. another ISR call)
//=====
ECAPxRegs.CAP2 = 0x500;      // Set duty cycle i.e. compare value

```

**12.5.2.5.5.2 Multichannel PWM Generation with Synchronization Example**

Figure 12-314 takes advantage of the synchronization feature between the ECAP modules. Here 4 independent PWM channels are required with different frequencies, but at integer multiples of each other to avoid "beat" frequencies. Hence one ECAP module is configured as the Controller and the remaining 3 are Targets all receiving their synch pulse (CTR = PRD) from the controller. Note the Controller is chosen to have the lower frequency ( $F_1 = 1/20,000$ ) requirement. Here Target2 Freq =  $2 \times F_1$ , Target3 Freq =  $4 \times F_1$  and Target4 Freq =  $5 \times F_1$ . Note here values are in decimal notation. Also, only the APWM1 output waveform is shown.



**Figure 12-314. Multichannel PWM Example Using 4 ECAP Modules**

ecap\_019

**Table 12-273. ECAP1 Initialization for Multichannel PWM Generation with Synchronization**

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 20000        |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCl_EN  | EC_DISABLE   |
| ECCTL2   | SYNCO_SEL | EC_CTR_PRD   |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

**Table 12-274. ECAP2 Initialization for Multichannel PWM Generation with Synchronization**

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 10000        |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCl_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCI     |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

**Table 12-275. ECAP3 Initialization for Multichannel PWM Generation with Synchronization**

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 5000         |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCl_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCI     |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

**Table 12-276. ECAP4 Initialization for Multichannel PWM Generation with Synchronization**

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 4000         |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCl_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCO_DIS |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

**Example 12-6. Code Snippet for Multichannel PWM Generation with Synchronization**

```
// Code snippet for APWM mode Example 2
// Run Time (Note: Example execution of one run-time instant)
//=====
ECAP1Regs.CAP2 = 7000; // Set Duty cycle i.e., compare value = 7000
ECAP2Regs.CAP2 = 2000; // Set Duty cycle i.e., compare value = 2000
ECAP3Regs.CAP2 = 550; // Set Duty cycle i.e., compare value = 550
ECAP4Regs.CAP2 = 6500; // Set Duty cycle i.e., compare value = 6500
```

#### 12.5.2.5.5.3 Multichannel PWM Generation with Phase Control Example

In [Figure 12-315](#), the Phase control feature of the APWM mode is used to control a 3 phase Interleaved DC/DC converter topology. This topology requires each phase to be off-set by 120° from each other. Hence if "Leg" 1 (controlled by APWM1) is the reference Leg (or phase), that is, 0°, then Leg 2 need 120° off-set and Leg 3 needs 240° off-set. The waveforms in [Figure 12-315](#) show the timing relationship between each of the phases (Legs). Note ECAP1 module is the Controller and issues a SyncOut pulse to the targets (modules 2, 3) whenever TSCTR = Period value.



Figure 12-315. Multiphase (channel) Interleaved PWM Example Using 3 ECAP Modules

**Table 12-277. ECAP1 Initialization for Multichannel PWM Generation with Phase Control**

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 1200         |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_DISABLE   |
| ECCTL2   | SYNCO_SEL | EC_CTR_PRD   |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

**Table 12-278. ECAP2 Initialization for Multichannel PWM Generation with Phase Control**

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 1200         |
| CTRPHS   | CTRPHS    | 800          |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCI     |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

**Table 12-279. ECAP3 Initialization for Multichannel PWM Generation with Phase Control**

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 1200         |
| CTRPHS   | CTRPHS    | 400          |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCI_DIS |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

### Example 12-7. Code Snippet for Multichannel PWM Generation with Phase Control

```

// Code snippet for APWM mode Example 3
// Run Time (Note: Example execution of one run-time instant)
//=====
// All phases are set to the same duty cycle
ECAP1Regs.CAP2 = 700;      // Set Duty cycle i.e. compare value = 700
ECAP2Regs.CAP2 = 700;      // Set Duty cycle i.e. compare value = 700
ECAP3Regs.CAP2 = 700;      // Set Duty cycle i.e. compare value = 700

```

### 12.5.3 Enhanced Pulse Width Modulation (EPWM) Module

This chapter describes the Enhanced Pulse Width Modulation (EPWM) module in the device.

#### 12.5.3.1 EPWM Overview

An effective PWM peripheral must be able to generate complex pulse width waveforms with minimal CPU overhead or intervention. It needs to be highly programmable and very flexible while being easy to understand and use. The EPWM unit described here addresses these requirements by allocating all needed timing and control resources on a per PWM channel basis. Cross-coupling or sharing of resources has been avoided; instead, the EPWM is built up from smaller single-channel modules with separate resources and that can operate together as required to form a system. This modular approach results in an orthogonal architecture and provides a more transparent view of the peripheral structure, helping users to understand its operation quickly.

In the further description, the letter x within a signal or module name is used to indicate a generic EPWM instance on a device. For example, output signals EPWMxA and EPWMxB refer to the output signals from the EPWMx instance. Thus, EPWM1A and EPWM1B belong to EPWM1, EPWM2A and EPWM2B belong to EPWM2, and so forth.

The EPWM module represents one complete PWM channel composed of two PWM outputs: EPWMxA and EPWMxB.

As also described in *Daisy-Chain Connectivity between EPWM Modules*, the EPWM modules are chained together via a clock synchronization scheme that allows them to operate as a single system when required. Additionally, this synchronization scheme can be extended to the Enhanced Capture (ECAP) peripheral module. The EPWM modules can also operate stand-alone.

Figure 12-316 shows the EPWM module overview.



**Figure 12-316. EPWM Overview**

#### 12.5.3.1.1 EPWM Features

Each EPWM module supports the following features:

- Dedicated 16-bit time-base counter with period and frequency control
- Two PWM outputs (EPWMxA and EPWMxB) that can be used in the following configurations:
  - Two independent PWM outputs with single-edge operation
  - Two independent PWM outputs with dual-edge symmetric operation
  - One independent PWM output with dual-edge asymmetric operation
- Asynchronous override control of PWM signals through software
- Programmable phase-control support for lag or lead operation relative to other EPWM modules
- Hardware-locked (synchronized) phase relationship on a cycle-by-cycle basis
- Dead-band generation with independent rising and falling edge delay control
- Programmable trip zone allocation of both cycle-by-cycle trip and one-shot trip on fault conditions
- A trip condition can force either high, low, or high-impedance state logic levels at PWM outputs
- Allows events to trigger both CPU interrupts and ADC start of conversions
- Programmable event prescaling minimizes CPU overhead on interrupts
- PWM chopping by a high-frequency carrier signal, useful for pulse transformer gate drives

#### 12.5.3.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### 12.5.3.1.3 Multiple EPWM Module Details

Each EPWM module is connected to the input/output signals shown in [Figure 12-317](#).

The order in which the EPWM modules are connected may differ from what is shown in [Figure 12-317](#). See [Daisy-Chain Connectivity between EPWM Modules](#) for the actual synchronization scheme implemented in the device. Each EPWM module consists of seven submodules and is connected within a system via the signals shown in [Figure 12-318](#).



A.  $x = 0$  to number of instances

epwm-001

**Figure 12-317. Multiple EPWM Modules**



epwm-002

A.  $x = 0$  to number of instances

**Figure 12-318. Submodules and Signal Connections for an EPWM Module**

Figure 12-319 shows more internal details of a single EPWM module.

The main signals used by the EPWM module are:

- **PWM output signals (EPWMxA and EPWMxB)**  
The PWM output signals are available external to the device through the GPIO peripheral.
- **Trip-zone signals (TZ0 to TZ5)**  
These input signals alert the EPWM module of an external fault condition. Each module on a device can be configured to either use or ignore any of the trip-zone signals. The trip-zone signal can be configured as an asynchronous input through the GPIO peripheral.
- **Time-base synchronization input (EPWMxSYNCI) and output (EPWMxSYNCO) signals**  
The synchronization signals daisy chain the EPWM modules together. Each module can be configured to either use or ignore its synchronization input. For more information see *Daisy-Chain Connectivity between EPWM Modules*.
- **ADC start-of-conversion signals (EPWMxSOCA and EPWMxSOCB)**  
Each EPWM module has two ADC start of conversion signals (one for each sequencer). Any EPWM module can trigger a start of conversion for either sequencer. Which event triggers the start of conversion is configured in the Event-Trigger submodule of the EPWM module.
- **Peripheral Bus**  
The peripheral bus is 32-bits wide and allows both 16-bit and 32-bit writes to the EPWM registers.

Figure 12-319 also shows the key internal submodule interconnect signals. Each submodule is described in *EPWM Functional Description*.



epwm-003

Figure 12-319. EPWM Submodule Interconnect Signals

### 12.5.3.2 EPWM Environment

The EPWMX (where x = 0 to number of instances) module is hereinafter referred to as EPWM module.

This section describes the EPWM external connections (environment).

Figure 12-320 shows the EPWM I/O interface signals.

**Figure 12-320. EPWM I/O Interface Signals**



A. i represents a valid instance of EPWM in a domain. See the device datasheet for specifics.

B. Pin only available on specific instances. See the device datasheet for specifics.

Table 12-280 describes the EPWM I/O signals.

**Table 12-280. EPWM I/O Signals**

| Module Pin                                      | Device Level Signal           | I/O <sup>(1)</sup> | Description                         | Module Pin Reset Value <sup>(2)</sup> |
|-------------------------------------------------|-------------------------------|--------------------|-------------------------------------|---------------------------------------|
| <b>EPWMi<sup>(3)</sup></b>                      |                               |                    |                                     |                                       |
| EPWMi <sup>(3)</sup> A                          | EHRPWMi <sup>(3)</sup> _A     | O                  | EPWMi <sup>(3)</sup> output A       | 0x0                                   |
| EPWMi <sup>(3)</sup> B                          | EHRPWMi <sup>(3)</sup> _B     | O                  | EPWMi <sup>(3)</sup> output B       | 0x0                                   |
| EPWMi <sup>(3)</sup> SYNCI <sup>(4)</sup>       | EHRPWMi <sup>(3)</sup> _SYNCI | I                  | EPWMi <sup>(3)</sup> Sync input     | HiZ                                   |
| EPWMi <sup>(3)</sup> SYNCO <sup>(4)</sup>       | EHRPWMi <sup>(3)</sup> _SYNCO | O                  | EPWMi <sup>(3)</sup> Sync output    | 0x0                                   |
| EPWMi <sup>(3)</sup> _TRIP_TZ[0] <sup>(4)</sup> | EHRPWM_TZn_INi <sup>(3)</sup> | I                  | EPWMi <sup>(3)</sup> TripZone input | HiZ                                   |
| <b>EPWM Start of Conversion</b>                 |                               |                    |                                     |                                       |
| PWM_SOCA                                        | EHRPWM_SOCA                   | O                  | EPWM start of conversion output A   | HiZ                                   |
| PWM_SOCB                                        | EHRPWM_SOCB                   | O                  | EPWM start of conversion output B   | HiZ                                   |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) i represents a valid instance of EPWM in a domain. See the device datasheet for specifics.

(4) Pin only available on specific instances. See the device datasheet for specifics.

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables Pin Attributes and Pin Multiplexing in the device-specific Datasheet.

### 12.5.3.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.5.3.4 EPWM Functional Description

Seven submodules are included in each EPWM peripheral. Each of these submodules performs specific tasks that can be configured by software.

##### 12.5.3.4.1 EPWM Submodule Features

Table 12-281 lists the seven key submodules together with a list of their main configuration parameters.

**Table 12-281. Submodule Configuration Parameters**

| Submodule             | Configuration Parameter or Option                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Time-base (TB)        | <ul style="list-style-type: none"> <li>Scale the time-base clock (TBCLK) relative to the system clock (FICLK).</li> <li>Configure the PWM time-base counter (TBCNT) frequency or period.</li> <li>Time-base counter mode selection: <ul style="list-style-type: none"> <li>count-up mode: used for asymmetric PWM</li> <li>count-down mode: used for asymmetric PWM</li> <li>count-up-and-down mode: used for symmetric PWM</li> </ul> </li> <li>Configure the time-base phase relative to another EPWM module.</li> <li>Synchronize the time-base counter between modules through hardware or software.</li> <li>Configure the direction (up or down) of the time-base counter after a synchronization event.</li> <li>Configure how the time-base counter will behave when the device is halted by an emulator.</li> <li>Specify the source for the synchronization output of the EPWM module: <ul style="list-style-type: none"> <li>Synchronization input signal</li> <li>Time-base counter equal to zero</li> <li>Time-base counter equal to counter-compare B (CMPB)</li> <li>No output synchronization signal generated</li> </ul> </li> </ul> |
| Counter-compare (CC)  | <ul style="list-style-type: none"> <li>Specify the PWM duty cycle for output EPWMxA and/or output EPWMxB</li> <li>Specify the time at which switching events occur on the EPWMxA or EPWMxB output</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Action-qualifier (AQ) | <ul style="list-style-type: none"> <li>Specify the type of action taken when a time-base or counter-compare submodule event occurs: <ul style="list-style-type: none"> <li>No action taken</li> <li>Output EPWMxA and/or EPWMxB switched high</li> <li>Output EPWMxA and/or EPWMxB switched low</li> <li>Output EPWMxA and/or EPWMxB toggled</li> </ul> </li> <li>Force the PWM output state through software control</li> <li>Configure and control the PWM dead-band through software</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Dead-band (DB)        | <ul style="list-style-type: none"> <li>Control of traditional complementary dead-band relationship between upper and lower switches</li> <li>Specify the output rising-edge-delay value</li> <li>Specify the output falling-edge delay value</li> <li>Bypass the dead-band module entirely. In this case the PWM waveform is passed through without modification</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| PWM-chopper (PC)      | <ul style="list-style-type: none"> <li>Create a chopping (carrier) frequency</li> <li>Pulse width of the first pulse in the chopped pulse train</li> <li>Duty cycle of the second and subsequent pulses</li> <li>Bypass the PWM-chopper module entirely. In this case the PWM waveform is passed through without modification.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**Table 12-281. Submodule Configuration Parameters (continued)**

| Submodule          | Configuration Parameter or Option                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Trip-zone (TZ)     | <ul style="list-style-type: none"> <li>Configure the EPWM module to react to one, all, or none of the trip-zone pins</li> <li>Specify the tripping action taken when a fault occurs: <ul style="list-style-type: none"> <li>Force EPWMxA and/or EPWMxB high</li> <li>Force EPWMxA and/or EPWMxB low</li> <li>Force EPWMxA and/or EPWMxB to a high-impedance state</li> <li>Configure EPWMxA and/or EPWMxB to ignore any trip condition</li> </ul> </li> <li>Configure how often the EPWM will react to the trip-zone pin: <ul style="list-style-type: none"> <li>One-shot</li> <li>Cycle-by-cycle</li> </ul> </li> <li>Enable the trip-zone to initiate an interrupt</li> <li>Bypass the trip-zone module entirely</li> </ul> |
| Event-trigger (ET) | <ul style="list-style-type: none"> <li>Enable the EPWM events that will trigger an interrupt.</li> <li>Specify the rate at which events cause triggers (every occurrence or every second or third occurrence)</li> <li>Poll, set, or clear event flags</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Some examples on various EPWM module configurations are shown below. These examples use the constant definitions shown in [Example 12-8](#).

## Constant Definitions Used in the EPWM Code Examples

```

// TBCTL (Time-Base Control)
// =====
// TBCNT MODE bits
#define TB_COUNT_UP      0x0
#define TB_COUNT_DOWN    0x1
#define TB_COUNT_UPDOWN  0x2
#define TB_FREEZE        0x3
// PHSEN bit
#define TB_DISABLE        0x0
#define TB_ENABLE         0x1
// PRDLD bit
#define TB_SHADOW         0x0
#define TB_IMMEDIATE     0x1
// SYNCSEL bits
#define TB_SYNC_IN        0x0
#define TB_CTR_ZERO       0x1
#define TB_CTR_CMPB      0x2
#define TB_SYNC_DISABLE   0x3
// HSPCLKDIV and CLKDIV bits
#define TB_DIV1           0x0
#define TB_DIV2           0x1
#define TB_DIV4           0x2
// PHSDIR bit
#define TB_DOWN           0x0
#define TB_UP             0x1

// CMPCTL (Compare Control)
// =====
// LOADAMODE and LOADBMODE bits
#define CC_CTR_ZERO       0x0
#define CC_CTR_PRD        0x1

```

```

#define      CC_CTR_ZERO_PRD      0x2
#define      CC_LD_DISABLE       0x3
// SHDWAMODE and SHDWBMODE bits
#define      CC_SHADOW           0x0
#define      CC_IMMEDIATE        0x1
// AQCTLA and AQCTLB (Action-qualifier Control)
// =====
// ZRO, PRD, CAU, CAD, CBU, CBD bits
#define      AQ_NO_ACTION        0x0
#define      AQ_CLEAR             0x1
#define      AQ_SET               0x2
#define      AQ_TOGGLE             0x3
// DBCTL (Dead-Band Control)
// =====
// MODE bits
#define      DB_DISABLE           0x0
#define      DBA_ENABLE            0x1
#define      DBB_ENABLE            0x2
#define      DB_FULL_ENABLE        0x3
// POLSEL bits
#define      DB_ACTV_HI           0x0
#define      DB_ACTV_LOC          0x1
#define      DB_ACTV_HIC          0x2
#define      DB_ACTV_LO           0x3
// PCCTL (chopper control)
// =====
// CHPEN bit
#define      CHP_ENABLE            0x0
#define      CHP_DISABLE           0x1
// CHPFREQ bits
#define      CHP_DIV1              0x0
#define      CHP_DIV2              0x1
#define      CHP_DIV3              0x2
#define      CHP_DIV4              0x3
#define      CHP_DIV5              0x4
#define      CHP_DIV6              0x5
#define      CHP_DIV7              0x6
#define      CHP_DIV8              0x7
// CHPDUTY bits
#define      CHP1_8TH              0x0
#define      CHP2_8TH              0x1
#define      CHP3_8TH              0x2
#define      CHP4_8TH              0x3
#define      CHP5_8TH              0x4
#define      CHP6_8TH              0x5
#define      CHP7_8TH              0x6
// TZSEL (Trip-zone Select)
// =====
// CBCn and OSHTn bits
#define      TZ_ENABLE              0x0
#define      TZ_DISABLE             0x1
// TZCTL (Trip-zone Control)
// =====
// TZA and TZB bits
#define      TZ_HIZ                0x0
#define      TZ_FORCE_HI            0x1
#define      TZ_FORCE_LO            0x2
#define      TZ_DISABLE              0x3
// ETSEL (Event-trigger Select)
// =====
// INTSEL, SOCASEL, SOCBSEL bits
#define      ET_CTR_ZERO            0x1
#define      ET_CTR_PRD              0x2
#define      ET_CTRU_CMPA             0x4
#define      ET_CTRD_CMPA             0x5
#define      ET_CTRU_CMPB             0x6
#define      ET_CTRD_CMPB             0x7
// ETPS (Event-trigger Prescale)
// =====
// INTPRD, SOCAPRD, SOCBPRD bits
#define      ET_DISABLE              0x0
#define      ET_1ST                  0x1

```

```
#define ET_2ND 0x2
#define ET_3RD 0x3
```

#### 12.5.3.4.2 EPWM Time-Base (TB) Submodule

This section describes the Time-Base (TB) submodule in the PWM module.

##### 12.5.3.4.2.1 Overview

Each EPWM module has its own time-base submodule that determines all of the timing events. Built-in synchronization logic allows the time-base of multiple EPWM modules (EPWMx) to work together as a single system. [Figure 12-321](#) illustrates the time-base module's place within the EPWM.



**Figure 12-321. EPWM Time-Base Submodule**

##### 12.5.3.4.2.2 Controlling and Monitoring the EPWM Time-Base Submodule

[Table 12-282](#) lists the registers used to control and monitor the time-base submodule.

**Table 12-282. EPWM Time-Base Submodule Registers**

| Acronym    | Register Description       | Address Offset | Shadowed |
|------------|----------------------------|----------------|----------|
| EPWM_TBCTL | Time-Base Control Register | 0h             | No       |
| EPWM_TBSTS | Time-Base Status Register  | 2h             | No       |
| EPWM_TBPHS | Time-Base Phase Register   | 6h             | No       |
| EPWM_TBCNT | Time-Base Counter Register | 8h             | No       |
| EPWM_TBPRD | Time-Base Period Register  | Ah             | Yes      |

[Figure 12-322](#) shows the critical signals and registers of the time-base submodule. [Table 12-283](#) provides descriptions of the key signals associated with the time-base submodule.



epwm-009

**Figure 12-322. EPWM Time-Base Submodule Signals and Registers**

**Table 12-283. EPWM Time-Base Submodule Key Signals**

| Signal     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EPWMxSYNCI | Time-base synchronization input.<br>Input pulse used to synchronize the time-base counter with the counter of another EPWM module earlier in the synchronization chain. An EPWM peripheral can be configured to use or ignore this signal. For the first EPWM module (EPWM0) this signal comes from a device pin. For subsequent EPWM modules this signal is passed from another EPWM peripheral. For example, EPWM2SYNCI is generated by the EPWM1 peripheral and the EPWM3SYNCI is generated (optional through internal multiplexer) by EPWM2 or from a device pin. See <a href="#">Section 12.5.3.4.2.3.2</a> for information on the synchronization order of a particular device. |
| EPWMxSYNCO | Time-base synchronization output.<br>This output pulse is used to synchronize the counter of an EPWM module later in the synchronization chain. The EPWM module generates this signal from one of three event sources:<br>1. EPWMxSYNCI (Synchronization input pulse)<br>2. TBCNT = 0: The time-base counter (EPWM_TBCNT register) equal to zero (TBCNT = 0000h).<br>3. TBCNT = CMPB: The time-base counter (EPWM_TBCNT register) equal to the counter-compare B register — EPWM_CMPB (that is bitfield TBCNT = bitfield CMPB).                                                                                                                                                       |
| PRD_eq     | Time-base counter equal to the specified period.<br>This signal is generated whenever the counter value is equal to the active period register value. That is when TBCNT = TBPRD.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CNT_zero   | Time-base counter equal to zero.<br>This signal is generated whenever the counter value is zero. That is when TBCNT equals 0000h.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CMPB_eq    | Time-base counter equal to active counter-compare B register (TBCNT = CMPB).<br>This event is generated by the counter-compare submodule and used by the synchronization out logic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 12-283. EPWM Time-Base Submodule Key Signals (continued)**

| Signal  | Description                                                                                                                                                                                                     |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CNT_dir | Time-base counter direction.<br>Indicates the current direction of the EPWM's time-base counter. This signal is high when the counter is increasing and low when it is decreasing.                              |
| CNT_max | Time-base counter equal max value (TBCNT = FFFFh).<br>Generated event when the EPWM_TBCNT register value reaches its maximum value. This signal is only used only as a status bit.                              |
| TBCLK   | Time-base clock.<br>This is a prescaled version of the system clock — FICLK and is used by all submodules within the EPWMn. This clock determines the rate at which time-base counter increments or decrements. |

#### 12.5.3.4.2.3 Calculating PWM Period and Frequency

The frequency of PWM events is controlled by the time-base period register (EPWM\_TBPRD) and the mode of the time-base counter. [Figure 12-323](#) shows the period ( $T_{pwm}$ ) and frequency ( $F_{pwm}$ ) relationships for the up-count, down-count, and up-down-count time-base counter modes when the period is set to 4 (EPWM\_TBPRD[15:0] TBPRD = 0x4). The time increment for each step is defined by the time-base clock (TBCLK) which is a prescaled version of the system clock (FICLK).

The time-base counter has three modes of operation selected by the time-base control register (EPWM\_TBCTL):

- **Up-Down-Count Mode:** In up-down-count mode, the time-base counter starts from zero and increments until the period (TBPRD) value is reached. When the period value is reached, the time-base counter then decrements until it reaches zero. At this point the counter repeats the pattern and begins to increment.
- **Up-Count Mode:** In this mode, the time-base counter starts from zero and increments until it reaches the value in the period register (TBPRD). When the period value is reached, the time-base counter resets to zero and begins to increment once again.
- **Down-Count Mode:** In down-count mode, the time-base counter starts from the period (TBPRD) value and decrements until it reaches zero. When it reaches zero, the time-base counter is reset back to the period value and it repeats this pattern.



Figure 12-323. EPWM Time-Base Frequency and Period

#### 12.5.3.4.2.3.1 EPWM Time-Base Period Shadow Register

The time-base period register (EPWM\_TBPRD) has a shadow register. Shadowing allows the register update to be synchronized with the hardware. The following definitions are used to describe all shadow registers in the EPWM module:

- **Active Register:** The active register controls the hardware and is responsible for actions that the hardware causes or invokes.
- **Shadow Register:** The shadow register buffers or provides a temporary holding location for the active register. It has no direct effect on any control hardware. At a strategic point in time the shadow register's content is transferred to the active register. This prevents corruption or spurious operation due to the register being asynchronously modified by software.

The memory address of the shadow period register is the same as the active register. Which register is written to or read from is determined by the EPWM\_TBCTL[3] PRDLD bit. This bit enables and disables the EPWM\_TBPRD shadow register as follows:

- **Time-Base Period Shadow Mode:** The EPWM\_TBPRD shadow register is enabled when EPWM\_TBCTL[3] PRDLD = 0h. Reads from and writes to the EPWM\_TBPRD register memory address go to the shadow register. The shadow register contents are transferred to the active register (EPWM\_TBPRD (Active) ← EPWM\_TBPRD (shadow)) when the time-base counter register (EPWM\_TBCNT) equals zero (TBCNT = 0000h). By default the EPWM\_TBPRD shadow register is enabled.
- **Time-Base Period Immediate Load Mode:** If immediate load mode is selected (EPWM\_TBCTL[3] PRDLD = 1h), then a read from or a write to the TBPRD memory address goes directly to the active register.

#### 12.5.3.4.2.3.2 EPWM Time-Base Counter Synchronization

A time-base synchronization scheme connects all of the EPWM modules on a device. Each EPWM module has a synchronization input (EPWMxSYNCI) and a synchronization output (EPWMxSYNCO). The input synchronization for the first instance (EPWM0) comes from an external pin. For the device EPWM environment sync pin details refer to the [Section 12.5.3.2](#). The possible synchronization connections for the remaining EPWM modules is shown in [Figure 12-324](#).



epwm-011

**Figure 12-324. EPWM Time-Base Counter Synchronization Scheme 1**

Each EPWM module can be configured to use or ignore the synchronization input. If the EPWM\_TBCTL[2] PHSEN bit is set, then the time-base counter (TBCNT) of the EPWM module (EPWM\_TBCNT register) will be automatically loaded with the phase register (EPWM\_TBPHS) contents when one of the following conditions occur:

- **EPWMxSYNCI: Synchronization Input Pulse:** The value of the phase register is loaded into the counter register when an input synchronization pulse is detected (EPWM\_TBPHS → EPWM\_TBCNT). This operation occurs on the next valid time-base clock (TBCLK) edge.
- **Software Forced Synchronization Pulse:** Writing a 1h to the EPWM\_TBCTL[6] SWFSYNC control bit invokes a software forced synchronization. This pulse is ORed with the synchronization input signal, and therefore has the same effect as a pulse on EPWMxSYNCI.

This feature enables the EPWM module to be automatically synchronized to the time base of another EPWM module. Lead or lag phase control can be added to the waveforms generated by different EPWM modules to synchronize them. In up-down-count mode, the EPWM\_TBCTL[13] PHSDIR bit configures the direction of the time-base counter immediately after a synchronization event. The new direction is independent of the direction prior to the synchronization event. The TBPHS bit is ignored in count-up or count-down modes. See [Figure 12-325](#) through [Figure 12-328](#) for examples.

Clearing the EPWM\_TBCTL[2] PHSEN bit configures the EPWM to ignore the synchronization input pulse. The synchronization pulse can still be allowed to flow-through to the EPWMxSYNCO and be used to synchronize other EPWM modules. In this way, a controller time-base (for example: EPWM1) and downstream modules (EPWM2–EPWMx) can be set and they may select to run in synchronization with the controller.

#### 12.5.3.4.2.4 Phase Locking the Time-Base Clocks of Multiple EPWM Modules

As already described in the *EPWM Modules Time-Base Clock Gating*, TB\_CLKEN bit in the CTRLMMR\_EPWMn\_CTRL (where n = 0 to 8) register of the device CTRL\_MMR0 can be used to individually control or globally synchronize the time-base clocks of all enabled EPWM modules on a device. When all

TB\_CLKEN bits are set to 0h, the time-base clocks of all EPWMx (where  $x = 0$  to 8) modules are stopped (default). When all TB\_CLKEN bits are simultaneously set in software to 1h, all EPWMx modules time-base clocks are started with the rising edge of TBCLK aligned. For perfectly synchronized TBCLKs, the prescaler bits in the EPWM\_TBCTL register of each EPWM module must be set identically. The proper procedure for enabling the EPWM clocks is as follows:

1. Enable the EPWM module clocks.
2. Set TB\_CLKEN = 0. This will stop the time-base clock within any enabled EPWMx module.
3. Configure the prescaler values and desired EPWM modes per each involved EPWMx.
4. Simultaneously set TB\_CLKEN bits to 1h.

#### 12.5.3.4.2.5 EPWM Time-Base Counter Modes and Timing Waveforms

The time-base counter operates in one of four modes:

- Up-count mode which is asymmetrical.
- Down-count mode which is asymmetrical.
- Up-down-count which is symmetrical.
- Frozen where the time-base counter is held constant at the current value.

To illustrate the operation of the first three modes, [Figure 12-325](#) to [Figure 12-328](#) show when events are generated and how the time-base responds to an EPWMxSYNCl signal.



**Figure 12-325. EPWM Time-Base Up-Count Mode Waveforms**



**Figure 12-326. EPWM Time-Base Down-Count Mode Waveforms**



**Figure 12-327. EPWM Time-Base Up-Down-Count Waveforms, EPWM\_TBCTL[13] PHSDIR = 0 Count Down on Synchronization Event**



**Figure 12-328. EPWM Time-Base Up-Down Count Waveforms, EPWM\_TBCTL[13] PHSDIR = 1 Count Up on Synchronization Event**

#### 12.5.3.4.3 EPWM Counter-Compare (CC) Submodule

This section describes the Counter-Compare (CC) submodule in the PWM module.

##### 12.5.3.4.3.1 Overview

Figure 12-329 illustrates the counter-compare submodule within the EPWM. Figure 12-330 shows the basic structure of the counter-compare submodule.



**Figure 12-329. EPWM Counter-Compare Submodule**

CC module features:

- Generates events based on programmable time stamps using the EPWM\_CMPA and EPWM\_CMPB registers
  - CMPA\_eq (Time-base counter equals counter-compare A register (TBCNT = CMPA)).
  - CMPB\_eq (Time-base counter equals counter-compare B register (TBCNT = CMPB)).
- Controls the PWM duty cycle if the action-qualifier submodule is configured appropriately
- Shadows new compare values to prevent corruption or glitches during the active PWM cycle.

The counter-compare submodule takes as input the time-base counter value. This value is continuously compared to the counter-compare A (EPWM\_CMPA) and counter-compare B (EPWM\_CMPB) registers. When the time-base counter is equal to one of the compare registers, the counter-compare unit generates an appropriate event.

##### 12.5.3.4.3.2 Controlling and Monitoring the EPWM Counter-Compare Submodule

Table 12-284 lists the registers used to control and monitor the counter-compare submodule. Table 12-285 lists the key signals associated with the counter-compare submodule.

**Table 12-284. EPWM Counter-Compare Submodule Registers**

| Acronym     | Register Description              | Address Offset | Shadowed |
|-------------|-----------------------------------|----------------|----------|
| EPWM_CMPCTL | Counter-Compare Control Register. | Eh             | No       |
| EPWM_CMPA   | Counter-Compare A Register        | 12h            | Yes      |
| EPWM_CMPB   | Counter-Compare B Register        | 14h            | Yes      |



epwm-017

**Figure 12-330. EPWM Counter-Compare Submodule Signals and Registers**

**Table 12-285. EPWM Counter-Compare Submodule Key Signals**

| Signal   | Description of Event                                                           | Register Bitfields Compared |
|----------|--------------------------------------------------------------------------------|-----------------------------|
| CMPA_eq  | Time-base counter equal to the active counter-compare A value                  | TBCNT = CMPA                |
| CMPB_eq  | Time-base counter equal to the active counter-compare B value                  | TBCNT = CMPB                |
| PRD_eq   | Time-base counter equal to the active period.                                  | TBCNT = TBPRD               |
|          | Used to load active counter-compare A and B registers from the shadow register |                             |
| CNT_zero | Time-base counter equal to zero.                                               | TBCNT = 0000h               |
|          | Used to load active counter-compare A and B registers from the shadow register |                             |

#### 12.5.3.4.3.3 Operational Highlights for the EPWM Counter-Compare Submodule

The counter-compare submodule is responsible for generating two independent compare events based on two compare registers:

1. CMPA: Time-base counter equal to counter-compare A register (EPWM\_TBCNT = EPWM\_CMPA).
2. CMPB: Time-base counter equal to counter-compare B register (EPWM\_TBCNT = EPWM\_CMPB).

For up-count or down-count mode, each event occurs only once per cycle. For up-down-count mode each event occurs twice per cycle, if the compare value is between 0000h and TBPRD; and occurs once per cycle, if the compare value is equal to 0000h or equal to TBPRD. These events are fed into the action-qualifier submodule where they are qualified by the counter direction and converted into actions if enabled. Refer to [Section 12.5.3.4.4](#) for more details.

The counter-compare EPWM\_CMPA and EPWM\_CMPB registers each have an associated shadow register. Shadowing provides a way to keep updates to the registers synchronized with the hardware. When shadowing is used, updates to the active registers only occurs at strategic points. This prevents corruption or spurious operation due to the register being asynchronously modified by software. The memory address of the active register and the shadow register is identical. Which register is written to or read from is determined by the EPWM\_CMPCTL[4] SHDWAMODE and EPWM\_CMPCTL[6] SHDWBMODE bits. These bits enable and disable the EPWM\_CMPA shadow register and EPWM\_CMPB shadow register respectively. The behavior of the two load modes is described below:

- **Shadow Load Mode:**

The shadow mode for the EPWM\_CMPA register is enabled by clearing the EPWM\_CMPCTL[4] SHDWAMODE bit and the shadow register for EPWM\_CMPB register is enabled by clearing the EPWM\_CMPCTL[6] SHDWBMODE bit. Shadow mode is enabled by default for both EPWM\_CMPA and EPWM\_CMPB register.

If the shadow register is enabled then the content of the shadow register is transferred to the active register on one of the following events:

- PRD\_eq: Time-base counter equal to the period (TBCNT = TBPRD).
- CNT\_zero: Time-base counter equal to zero (TBCNT = 0000h)
- Both PRD\_eq and CNT\_zero events occurrence

Which of these three events will drive the counter compare module is specified by the EPWM\_CMPCTL[1-0] LOADAMODE and EPWM\_CMPCTL[3-2] LOADBMODE register bit fields. Only the active register contents are used by the counter-compare submodule to generate events to be sent to the action-qualifier.

- **Immediate Load Mode:**

If immediate load mode is selected (EPWM\_CMPCTL[4] SHDWAMODE = 1h or EPWM\_CMPCTL[6] SHDWBMODE = 1h), then a read from or a write to the register will go directly to the active register.

[Figure 12-331](#) and [Figure 12-332](#) show Compare A and B Dual Shadow registers.



epwm-050

**Figure 12-331. Compare A Dual Shadow register**



epwm-051

**Figure 12-332. Compare B Dual Shadow register**

#### 12.5.3.4.3.4 EPWM Counter-Compare Submodule Timing Waveforms

As described in [Section 12.5.3.4.2](#), the Time Base (TB) module can be configured to operate in 3 distinct count modes:

- Up-count mode: used to generate an asymmetrical PWM waveform.
- Down-count mode: used to generate an asymmetrical PWM waveform.
- Up-down-count mode: used to generate a symmetrical PWM waveform.

The timing diagrams in [Figure 12-333](#) to [Figure 12-336](#) show how CMPA and CMPB events are generated in each of the 3 count modes and how the EPWMxSYNC1 signal interacts.



An EPWMxSYNCI external synchronization event can cause a discontinuity in the TBCNT count sequence. This can lead to a compare event being skipped. This skipping is considered normal operation and must be taken into account.

**Figure 12-333. EPWM Counter-Compare Event Waveforms in Up-Count Mode**



**Figure 12-334. EPWM Counter-Compare Events in Down-Count Mode**



**Figure 12-335. EPWM Counter-Compare Events in Up-Down-Count Mode, EPWM\_TBCTL[13] PHSDIR = 0 Count Down on Synchronization Event**



**Figure 12-336. EPWM Counter-Compare Events in Up-Down-Count Mode, EPWM\_TBCTL[13] PHSDIR = 1 Count Up on Synchronization Event**

#### 12.5.3.4.4 EPWM Action-Qualifier (AQ) Submodule

This section describes the Action-Qualifier (AQ) submodule in the PWM module.

##### 12.5.3.4.4.1 Overview

Figure 12-337 shows the action-qualifier (AQ) submodule in the EPWM system. This submodule has the most important role in waveform construction and PWM generation. It decides which events are converted into various action types, thereby producing the required switched waveforms at the EPWMxA and EPWMxB outputs.



epwm-022

**Figure 12-337. EPWM Action-Qualifier Submodule**

AQ module features:

- Qualifying and generating actions (set, clear, toggle) based on the following events:
  - PRD\_eq: Time-base counter equal to the period (TBCNT = TBPRD)
  - CNT\_zero: Time-base counter equal to zero (TBCNT = 0000h)
  - CMPA\_eq: Time-base counter equal to the counter-compare A register (TBCNT = CMPA)
  - CMPB\_eq: Time-base counter equal to the counter-compare B register (TBCNT = CMPB)
- Managing priority when these events occur concurrently
- Providing independent control of events when the time-base counter is increasing and when it is decreasing

##### 12.5.3.4.4.2 Controlling and Monitoring the EPWM Action-Qualifier Submodule

Table 12-286 lists the registers used to control and monitor the action-qualifier submodule.

**Table 12-286. EPWM Action-Qualifier Submodule Registers**

| Acronym      | Register Description                                    | Address Offset | Shadowed |
|--------------|---------------------------------------------------------|----------------|----------|
| EPWM_AQCTLA  | Action-Qualifier Control Register For Output A (EPWMxA) | 16h            | No       |
| EPWM_AQCTLB  | Action-Qualifier Control Register For Output B (EPWMxB) | 18h            | No       |
| EPWM_AQSFRC  | Action-Qualifier Software Force Register                | 1Ah            | No       |
| EPWM_AQCSFRC | Action-Qualifier Continuous Software Force              | 1Ch            | Yes      |

The action-qualifier submodule is based on event-driven logic. It can be thought of as a programmable cross switch with events at the input and actions at the output, all of which are software controlled via the set of registers as shown in Figure 12-338. The possible input events are summarized again in Table 12-287.



epwm-023

**Figure 12-338. EPWM Action-Qualifier Submodule Inputs and Outputs**

**Table 12-287. EPWM Action-Qualifier Submodule Possible Input Events**

| Signal                | Description                                      | Register Bitfield Compared |
|-----------------------|--------------------------------------------------|----------------------------|
| PRD_eq                | Time-base counter equal to the period value      | TBCNT = TBPRD              |
| CNT_zero              | Time-base counter equal to zero                  | TBCNT = 0000h              |
| CMPA_eq               | Time-base counter equal to the counter-compare A | TBCNT = CMPA               |
| CMPB_eq               | Time-base counter equal to the counter-compare B | TBCNT = CMPB               |
| Software forced event | Asynchronous event initiated by software         |                            |

The software forced action is a useful asynchronous event. This control is handled by EPWM\_AQSFR and EPWM\_AQCSFR registers.

The action-qualifier submodule controls how the two outputs EPWMxA and EPWMxB behave when a particular event occurs. The event inputs to the action-qualifier submodule are further qualified by the counter direction (up or down). This allows for independent action on outputs on both the count-up and count-down phases.

The possible actions imposed on outputs EPWMxA and EPWMxB are:

- Set High:** Set output EPWMxA or EPWMxB to a high level.
- Clear Low:** Set output EPWMxA or EPWMxB to a low level.
- Toggle:** If EPWMxA or EPWMxB is currently pulled high, then pull the output low. If EPWMxA or EPWMxB is currently pulled low, then pull the output high.
- Do Nothing:** Keep outputs EPWMxA and EPWMxB at same level as currently set. Although the "Do Nothing" option prevents an event from causing an action on the EPWMxA and EPWMxB outputs, this event can still trigger interrupts. See the Event\_Trigger (ET) submodule description in [Section 12.5.3.4.8](#) for details.

Actions are specified independently for either output (EPWMxA or EPWMxB). Any or all events can be configured to generate actions on a given output. All qualifier actions are configured via the control registers found at the end of this section.

For clarity, the drawings in this chapter use a set of symbolic actions. These symbols are summarized in [Figure 12-339](#). Each symbol represents an action as a marker in time. Some actions are fixed in time (zero and period) while the CMPA and CMPB actions are moveable and their time positions are programmed via the counter-compare A and B registers, respectively. To turn off or disable an action, use the "Do Nothing option"; it is the default at reset.

| S/W<br>force                                                                      | TB Counter equals:                                                                |                                                                                   |                                                                                   |                                                                                     | Actions    |
|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------|
|                                                                                   | Zero                                                                              | Comp<br>A                                                                         | Comp<br>B                                                                         | Period                                                                              |            |
|  |  |  |  |  | Do Nothing |
|  |  |  |  |  | Clear Low  |
|  |  |  |  |  | Set High   |
|  |  |  |  |  | Toggle     |

epwm-024

**Figure 12-339. Possible Action-Qualifier Actions for EPWMxA and EPWMxB Outputs**

#### 12.5.3.4.4.3 EPWM Action-Qualifier Event Priority

It is possible for the EPWM action qualifier to receive more than one event at the same time. In this case events are assigned a priority by the hardware. The general rule is: events occurring later in time have a higher priority and software forced events always have the highest priority. The event priority levels for up-down-count mode are shown in [Table 12-288](#). A priority level 1 is the highest priority and level 7 is the lowest. The priority changes slightly depending on the direction of TBCNT.

**Table 12-288. EPWM Action-Qualifier Event Priority for Up-Down-Count Mode**

| Priority Level | Event if TBCNT is Incrementing<br>TBCNT = 0 up to TBCNT = TBPRD | Event if TBCNT is Decrementing<br>TBCNT = TBPRD down to TBCNT = 1 |
|----------------|-----------------------------------------------------------------|-------------------------------------------------------------------|
| 1 (Highest)    | Software forced event                                           | Software forced event                                             |
| 2              | Counter equals CMPB on up-count (CBU)                           | Counter equals CMPB on down-count (CBD)                           |
| 3              | Counter equals CMPA on up-count (CAU)                           | Counter equals CMPA on down-count (CAD)                           |
| 4              | Counter equals zero                                             | Counter equals period (TBPRD in EPWM_TBPRD active register)       |
| 5              | Counter equals CMPB on down-count (CBD) <sup>(1)</sup>          | Counter equals CMPB on up-count (CBU) <sup>(1)</sup>              |
| 6 (Lowest)     | Counter equals CMPA on down-count (CAD) <sup>(1)</sup>          | Counter equals CMPA on up-count (CBU) <sup>(1)</sup>              |

- (1) To maintain symmetry for up-down-count mode, both up-events (CAU/CBU) and down-events (CAD/CBD) can be generated for TBPRD. Otherwise, up-events can occur only when the counter is incrementing and down-events can occur only when the counter is decrementing.

[Table 12-289](#) shows the action-qualifier priority for up-count mode. In this case, the counter direction is always defined as up and thus down-count events will never be taken.

**Table 12-289. EPWM Action-Qualifier Event Priority for Up-Count Mode**

| Priority Level | Event                                   |
|----------------|-----------------------------------------|
| 1 (Highest)    | Software forced event                   |
| 2              | Counter equal to period (TBPRD)         |
| 3              | Counter equal to CMPB on up-count (CBU) |
| 4              | Counter equal to CMPA on up-count (CAU) |
| 5 (Lowest)     | Counter equal to Zero                   |

[Table 12-290](#) shows the action-qualifier priority for down-count mode. In this case, the counter direction is always defined as down and thus up-count events will never be taken.

**Table 12-290. EPWM Action-Qualifier Event Priority for Down-Count Mode**

| Priority Level | Event                                     |
|----------------|-------------------------------------------|
| 1 (Highest)    | Software forced event                     |
| 2              | Counter equal to Zero                     |
| 3              | Counter equal to CMPB on down-count (CBD) |
| 4              | Counter equal to CMPA on down-count (CAD) |
| 5 (Lowest)     | Counter equal to period (TBPRD)           |

It is possible to set the compare value greater than the period. In this case the action will take place as shown in Table 12-291.

**Table 12-291. Behavior if CMPA/CMPB is Greater than the Period**

| Counter Mode       | Compare on Up-Count Event CAU/CBU                                                                                                                                                                                                                                                   | Compare on Down-Count Event CAU/CBU                                                                                                                                                                                                                                             |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Up-Count Mode      | If $\text{CMPA/CMPB} \leq \text{TBPRD}$ period, then the event occurs on a compare match ( $\text{TBCNT} = \text{CMPA}$ or $\text{CMPB}$ ).<br>If $\text{CMPA/CMPB} > \text{TBPRD}$ , then the event will not occur.                                                                | Never occurs.                                                                                                                                                                                                                                                                   |
| Down-Count Mode    | Never occurs.                                                                                                                                                                                                                                                                       | If $\text{CMPA/CMPB} < \text{TBPRD}$ , the event will occur on a compare match ( $\text{TBCNT} = \text{CMPA}$ or $\text{CMPB}$ ).<br>If $\text{CMPA/CMPB} \geq \text{TBPRD}$ , the event will occur on a period match ( $\text{TBCNT} = \text{TBPRD}$ ).                        |
| Up-Down-Count Mode | If $\text{CMPA/CMPB} < \text{TBPRD}$ and the counter is incrementing, the event occurs on a compare match ( $\text{TBCNT} = \text{CMPA}$ or $\text{CMPB}$ ).<br>If $\text{CMPA/CMPB} \geq \text{TBPRD}$ , the event will occur on a period match ( $\text{TBCNT} = \text{TBPRD}$ ). | If $\text{CMPA/CMPB} < \text{TBPRD}$ and the counter is decrementing, the event occurs on a compare match ( $\text{TBCNT} = \text{CMPA}$ or $\text{CMPB}$ ).<br>If $\text{CMPA/CMPB} \geq \text{TBPRD}$ , the event occurs on a period match ( $\text{TBCNT} = \text{TBPRD}$ ). |

#### 12.5.3.4.4.4 Waveforms for Common EPWM Configurations

##### Note

The waveforms in this chapter show the EPWMs behavior for a static compare register value. In a running system, the active compare registers (EPWM\_CMPA and EPWM\_CMPB) are typically updated from their respective shadow registers once every period. The user specifies when the update will take place — either when the time-base counter reaches zero or when the time-base counter reaches period. There are some cases when the action based on the new value can be delayed by one period or the action based on the old value can take effect for an extra period. Some PWM configurations avoid this situation. These include, but are not limited to, the following:

##### Use up-down-count mode to generate a symmetric PWM:

- If EPWM\_CMPA / EPWM\_CMPB is loaded on zero, then use EPWM\_CMPA / EPWM\_CMPB values greater than or equal to 1.
- If EPWM\_CMPA / EPWM\_CMPB is loaded on period, then use EPWM\_CMPA / EPWM\_CMPB values less than or equal to TBPRD - 1.

This means there will always be a pulse of at least one TBCLK cycle in a PWM period which, when very short, tend to be ignored by the system.

##### Use up-down-count mode to generate an asymmetric PWM:

- To achieve 50-0% asymmetric PWM use the following configuration: Load EPWM\_CMPA / EPWM\_CMPB on period and use the period action to clear the PWM and a compare-up action to set the PWM. Modulate the compare value from 0 to TBPRD to achieve 50-0% PWM duty.

##### When using up-count mode to generate an asymmetric PWM:

- To achieve 0-100% asymmetric PWM use the following configuration: Load EPWM\_CMPA / EPWM\_CMPB on TBPRD. Use the Zero action to set the PWM and a compare-up action to clear the PWM. Modulate the compare value from 0 to TBPRD+1 to achieve 0-100% PWM duty.

Figure 12-340 shows how a symmetric PWM waveform can be generated using the up-down-count mode of the TBCNT. In this mode 0-100% DC modulation is achieved by using equal compare matches on the up count and down count portions of the waveform. In the example shown, CMPA is used to make the comparison. When the counter is incrementing the CMPA match will pull the PWM output high. Likewise, when the counter is decrementing the compare match will pull the PWM signal low. When  $CMPA = 0$ , the PWM signal is low for the entire period giving the 0% duty waveform. When  $EPWM\_CMPA = EPWM\_TBPRD$ , the PWM signal is high achieving 100% duty.

When using this configuration in practice, if  $CMPA/CMPB$  is loaded on zero, then use  $CMPA/CMPB$  values greater than or equal to 1. If  $CMPA/CMPB$  is loaded on period, then use  $CMPA/CMPB$  values less than or equal to  $TBPRD - 1$ . This means there will always be a pulse of at least one TBCLK cycle in a PWM period which, when very short, tend to be ignored by the system.



epwm-025

Figure 12-340. EPWM Up-Down-Count Mode Symmetrical Waveform

The PWM waveforms in [Figure 12-341](#) through [Figure 12-346](#) show some common action-qualifier configurations. Some conventions used in the figures are as follows:

- TBPRD, CMPA, and CMPB refer to the value written in their respective registers (EPWM\_TBPRD, EPWM\_CMPA, and EPWM\_CMPB). The active register, not the shadow register, is used by the hardware.
- CMPx, refers to either CMPA or CMPB.
- EPWMxA and EPWMxB refer to the output signals from EPWMx
- Up-Down means Count-up-and-down mode, Up means up-count mode and Dwn means down-count mode
- Sym = Symmetric, Asym = Asymmetric

[Table 12-292](#) and [Table 12-293](#) contain initialization and runtime register configurations for the waveforms in [Figure 12-341](#).



- PWM period =  $(TBPRD + 1) \times T_{TBCLK}$
- Duty modulation for EPWMxA is set by CMPA, and is active high (that is, high time duty proportional to CMPA).
- Duty modulation for EPWMxB is set by CMPB and is active high (that is, high time duty proportional to CMPB).
- The "Do Nothing" actions ( X ) are shown for completeness, but will not be shown on subsequent diagrams.
- Actions at zero and period, although appearing to occur concurrently, are actually separated by one TBCLK period. TBCNT wraps from period to 0000h.

**Figure 12-341. Up, Single Edge Asymmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB — Active High**

**Table 12-292. EPWMx Initialization for Figure 12-341**

| Register    | Bitfield  | Value           | Comments                     |
|-------------|-----------|-----------------|------------------------------|
| EPWM_TBPRD  | TBPRD     | 600 (258h)      | Period = 601 TBCLK counts    |
| EPWM_TBPHS  | TBPHS     | 0               | Clear Phase Register to 0    |
| EPWM_TBCNT  | TBCNT     | 0               | Clear TB counter             |
| EPWM_TBCTL  | CTRMODE   | TB_UP           |                              |
|             | PHSEN     | TB_DISABLE      | Phase loading disabled       |
|             | PRDLD     | TB_SHADOW       |                              |
|             | SYNCOSEL  | TB_SYNC_DISABLE |                              |
|             | HSPCLKDIV | TB_DIV1         | TBCLK = FICLK                |
|             | CLKDIV    | TB_DIV1         |                              |
| EPWM_CMPA   | CMPA      | 350 (15Eh)      | Compare A = 350 TBCLK counts |
| EPWM_CMPB   | CMPB      | 200 (C8h)       | Compare B = 200 TBCLK counts |
| EPWM_CMPCTL | SHDWAMODE | CC_SHADOW       |                              |
|             | SHDWBMODE | CC_SHADOW       |                              |
|             | LOADAMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
|             | LOADBMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
| EPWM_AQCTLA | ZRO       | AQ_SET          |                              |
|             | CAU       | AQ_CLEAR        |                              |
| EPWM_AQCTLB | ZRO       | AQ_SET          |                              |
|             | CBU       | AQ_CLEAR        |                              |

**Table 12-293. EPWMx Run Time Changes for Figure 12-341**

| Register  | Bitfield | Value  | Comments                      |
|-----------|----------|--------|-------------------------------|
| EPWM_CMPA | CMPA     | Duty1A | Adjust duty for output EPWM1A |
| EPWM_CMPB | CMPB     | Duty1B | Adjust duty for output EPWM1B |

**Table 12-294** and **Table 12-295** contain initialization and runtime register configurations for the waveforms in Figure 12-342.



- A. PWM period =  $(TBPRD + 1) \times T_{TBCLK}$
- B. Duty modulation for EPWMxA is set by CMPA, and is active low (that is, the low time duty is proportional to CMPA).
- C. Duty modulation for EPWMxB is set by CMPB and is active low (that is, the low time duty is proportional to CMPB).
- D. The Do Nothing actions ( X ) are shown for completeness here, but will not be shown on subsequent diagrams.
- E. Actions at zero and period, although appearing to occur concurrently, are actually separated by one TBCLK period. TBCNT wraps from period to 0000h.

**Figure 12-342. Up, Single Edge Asymmetric Waveform With Independent Modulation on EPWMxA and EPWMxB — Active Low**

**Table 12-294. EPWMx Initialization for Figure 12-342**

| Register    | Bitfield  | Value           | Comments                     |
|-------------|-----------|-----------------|------------------------------|
| EPWM_TBPRD  | TBPRD     | 600 (258h)      | Period = 601 TBCLK counts    |
| EPWM_TBPHS  | TBPHS     | 0               | Clear Phase Register to 0    |
| EPWM_TBCNT  | TBCNT     | 0               | Clear TB counter             |
| EPWM_TBCTL  | CTRMODE   | TB_UP           |                              |
|             | PHSEN     | TB_DISABLE      | Phase loading disabled       |
|             | PRDLD     | TB_SHADOW       |                              |
|             | SYNCOSEL  | TB_SYNC_DISABLE |                              |
|             | HSPCLKDIV | TB_DIV1         | TBCLK = FICLK                |
|             | CLKDIV    | TB_DIV1         |                              |
| EPWM_CMPA   | CMPA      | 350 (15Eh)      | Compare A = 350 TBCLK counts |
| EPWM_CMPB   | CMPB      | 200 (C8h)       | Compare B = 200 TBCLK counts |
| EPWM_CMPCTL | SHDWAMODE | CC_SHADOW       |                              |
|             | SHDWBMODE | CC_SHADOW       |                              |
|             | LOADAMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
|             | LOADBMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
| EPWM_AQCTLA | PRD       | AQ_CLEAR        |                              |
|             | CAU       | AQ_SET          |                              |
| EPWM_AQCTLB | PRD       | AQ_CLEAR        |                              |
|             | CBU       | AQ_SET          |                              |

**Table 12-295. EPWMx Run Time Changes for Figure 12-342**

| Register  | Bit  | Value  | Comments                      |
|-----------|------|--------|-------------------------------|
| EPWM_CMPA | CMPA | Duty1A | Adjust duty for output EPWM1A |
| EPWM_CMPB | CMPB | Duty1B | Adjust duty for output EPWM1B |

**Table 12-296** and **Table 12-297** contain initialization and runtime register configurations for the waveforms **Figure 12-343**. Use the code in **Example 12-8** to define the headers.



epwm-028

- A. PWM frequency =  $1/( (TBPRD + 1) \times T_{TBCLK} )$
- B. Pulse can be placed anywhere within the PWM cycle (0000h - TBPRD)
- C. High time duty proportional to (CMPB - CMPA)
- D. EPWMxB can be used to generate a 50% duty square wave with frequency =  $1/2 \times ((TBPRD + 1) \times TBCLK)$

**Figure 12-343. Up-Count, Pulse Placement Asymmetric Waveform With Independent Modulation on EPWMxA**

Table 12-296. EPWMx Initialization for Figure 12-343

| Register    | Bitfield  | Value           | Comments                     |
|-------------|-----------|-----------------|------------------------------|
| EPWM_TBPRD  | TBPRD     | 600 (258h)      | Period = 601 TBCLK counts    |
| EPWM_TBPHS  | TBPHS     | 0               | Clear Phase Register to 0    |
| EPWM_TBCNT  | TBCNT     | 0               | Clear TB counter             |
| EPWM_TBCTL  | CTRMODE   | TB_UP           |                              |
|             | PHSEN     | TB_DISABLE      | Phase loading disabled       |
|             | PRDLD     | TB_SHADOW       |                              |
|             | SYNCOSEL  | TB_SYNC_DISABLE |                              |
|             | HSPCLKDIV | TB_DIV1         | TBCLK = FICLK                |
|             | CLKDIV    | TB_DIV1         |                              |
| EPWM_CMPA   | CMPA      | 200 (C8h)       | Compare A = 200 TBCLK counts |
| EPWM_CMPB   | CMPB      | 400 (190h)      | Compare B = 400 TBCLK counts |
| EPWM_CMPCTL | SHDWAMODE | CC_SHADOW       |                              |
|             | SHDWBMODE | CC_SHADOW       |                              |
|             | LOADAMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
|             | LOADBMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
| EPWM_AQCTLA | CAU       | AQ_SET          |                              |
|             | CBU       | AQ_CLEAR        |                              |
| EPWM_AQCTLB | ZRO       | AQ_TOGGLE       |                              |

Table 12-297. EPWMx Run Time Changes for Figure 12-343

| Register  | Bitfield | Value    | Comments                      |
|-----------|----------|----------|-------------------------------|
| EPWM_CMPA | CMPA     | EdgePosA | Adjust duty for output EPWM1A |
| EPWM_CMPB | CMPB     | EdgePosB |                               |

**Table 12-298** and **Table 12-299** contain initialization and runtime register configurations for the waveforms in Figure 12-344. Use the code in [Example 12-8](#) to define the headers.



- A. PWM period =  $2 \times \text{TBPRD} \times T_{\text{TBCLK}}$
- B. Duty modulation for EPWMxA is set by CMPA, and is active low (that is, the low time duty is proportional to CMPA).
- C. Duty modulation for EPWMxB is set by CMPB and is active low (that is, the low time duty is proportional to CMPB).
- D. Outputs EPWMxA and EPWMxB can drive independent power switches.

**Figure 12-344. Up-Down-Count, Dual Edge Symmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB — Active Low**

**Table 12-298. EPWMx Initialization for Figure 12-344**

| Register    | Bitfield  | Value           | Comments                     |
|-------------|-----------|-----------------|------------------------------|
| EPWM_TBPRD  | TBPRD     | 600 (258h)      | Period = 601 TBCLK counts    |
| EPWM_TBPHS  | TBPHS     | 0               | Clear Phase Register to 0    |
| EPWM_TBCNT  | TBCNT     | 0               | Clear TB counter             |
| EPWM_TBCTL  | CTRMODE   | TB_UPDOWN       |                              |
|             | PHSEN     | TB_DISABLE      | Phase loading disabled       |
|             | PRDLD     | TB_SHADOW       |                              |
|             | SYNCOSEL  | TB_SYNC_DISABLE |                              |
|             | HSPCLKDIV | TB_DIV1         | TBCLK = FICLK                |
|             | CLKDIV    | TB_DIV1         |                              |
| EPWM_CMPA   | CMPA      | 400 (190h)      | Compare A = 400 TBCLK counts |
| EPWM_CMPB   | CMPB      | 500 (1F4h)      | Compare B = 500 TBCLK counts |
| EPWM_CMPCTL | SHDWAMODE | CC_SHADOW       |                              |
|             | SHDWBMODE | CC_SHADOW       |                              |
|             | LOADAMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
|             | LOADBMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
| EPWM_AQCTLA | CAU       | AQ_SET          |                              |
|             | CAD       | AQ_CLEAR        |                              |
| EPWM_AQCTLB | CBU       | AQ_SET          |                              |
|             | CBD       | AQ_CLEAR        |                              |

**Table 12-299. EPWMx Run Time Changes for Figure 12-344**

| Register  | Bitfield | Value  | Comments                      |
|-----------|----------|--------|-------------------------------|
| EPWM_CMPA | CMPA     | Duty1A | Adjust duty for output EPWM1A |
| EPWM_CMPB | CMPB     | Duty1B | Adjust duty for output EPWM1B |

**Table 12-300** and **Table 12-301** contain initialization and runtime register configurations for the waveforms in Figure 12-345. Use the code in [Example 12-8](#) to define the headers.



- PWM period =  $2 \times \text{TBPRD} \times T_{\text{TBCLK}}$
- Duty modulation for EPWMxA is set by CMPA, and is active low, that is, low time duty proportional to CMPA.
- Duty modulation for EPWMxB is set by CMPB and is active high, that is, high time duty proportional to CMPB.
- Outputs EPWMx can drive upper/lower (complementary) power switches.
- Dead-band = CMPB - CMPA (fully programmable edge placement by software). Note the dead-band module is also available if the more classical edge delay method is required.

**Figure 12-345. Up-Down-Count, Dual Edge Symmetric Waveform, With Independent Modulation on EPWMx A and EPWMx B — Complementary**

**Table 12-300. EPWMx Initialization for Figure 12-345**

| Register    | Bitfield  | Value           | Comments                     |
|-------------|-----------|-----------------|------------------------------|
| EPWM_TBPRD  | TBPRD     | 600 (258h)      | Period = 601 TBCLK counts    |
| EPWM_TBPHS  | TBPHS     | 0               | Clear Phase Register to 0    |
| EPWM_TBCNT  | TBCNT     | 0               | Clear TB counter             |
| EPWM_TBCTL  | CTRMODE   | TB_UPDOWN       |                              |
|             | PHSEN     | TB_DISABLE      | Phase loading disabled       |
|             | PRDLD     | TB_SHADOW       |                              |
|             | SYNCOSEL  | TB_SYNC_DISABLE |                              |
|             | HSPCLKDIV | TB_DIV1         | TBCLK = FICLK                |
|             | CLKDIV    | TB_DIV1         |                              |
| EPWM_CMPA   | CMPA      | 350 (15Eh)      | Compare A = 350 TBCLK counts |
| EPWM_CMPB   | CMPB      | 400 (190h)      | Compare B = 400 TBCLK counts |
| EPWM_CMPCTL | SHDWAMODE | CC_SHADOW       |                              |
|             | SHDWBMODE | CC_SHADOW       |                              |
|             | LOADAMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
|             | LOADBMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
| EPWM_AQCTLA | CAU       | AQ_SET          |                              |
|             | CAD       | AQ_CLEAR        |                              |
| EPWM_AQCTLB | CBU       | AQ_CLEAR        |                              |
|             | CBD       | AQ_SET          |                              |

**Table 12-301. EPWMx Run Time Changes for Figure 12-345**

| Register  | Bitfield | Value  | Comments                      |
|-----------|----------|--------|-------------------------------|
| EPWM_CMPA | CMPA     | Duty1A | Adjust duty for output EPWM1A |
| EPWM_CMPB | CMPB     | Duty1B | Adjust duty for output EPWM1B |

**Table 12-302** and **Table 12-303** contain initialization and runtime register configurations for the waveforms in Figure 12-346. Use the code in [Example 12-8](#) to define the headers.



epwm-031

- A. PWM period =  $2 \times \text{TBPRD} \times \text{TBCLK}$
- B. Rising edge and falling edge can be asymmetrically positioned within a PWM cycle. This allows for pulse placement techniques.
- C. Duty modulation for EPWMxA is set by CMPA and CMPB.
- D. Low time duty for EPWMxA is proportional to (CMPA + CMPB).
- E. To change this example to active high, CMPA and CMPB actions need to be inverted (that is, Set ! Clear and Clear Set).
- F. Duty modulation for EPWMxB is fixed at 50% (utilizes spare action resources for EPWMxB).

**Figure 12-346. Up-Down-Count, Dual Edge Asymmetric Waveform, With Independent Modulation on EPWMxA — Active Low**

**Table 12-302. EPWMx Initialization for Figure 12-346**

| Register    | Bitfield  | Value           | Comments                     |
|-------------|-----------|-----------------|------------------------------|
| EPWM_TBPRD  | TBPRD     | 600 (258h)      | Period = 601 TBCLK counts    |
| EPWM_TBPHS  | TBPHS     | 0               | Clear Phase Register to 0    |
| EPWM_TBCNT  | TBCNT     | 0               | Clear TB counter             |
| EPWM_TBCTL  | CTRMODE   | TB_UPDOWN       |                              |
|             | PHSEN     | TB_DISABLE      | Phase loading disabled       |
|             | PRDLD     | TB_SHADOW       |                              |
|             | SYNCOSEL  | TB_SYNC_DISABLE |                              |
|             | HSPCLKDIV | TB_DIV1         | TBCLK = FICLK                |
|             | CLKDIV    | TB_DIV1         |                              |
| EPWM_CMPA   | CMPA      | 250 (FAh)       | Compare A = 250 TBCLK counts |
| EPWM_CMPB   | CMPB      | 450 (1C2h)      | Compare B = 450 TBCLK counts |
| EPWM_CMPCTL | SHDWAMODE | CC_SHADOW       |                              |
|             | SHDWBMODE | CC_SHADOW       |                              |
|             | LOADAMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
|             | LOADBMODE | CC_CTR_ZERO     | Load on TBCNT = 0            |
| EPWM_AQCTLA | CAU       | AQ_SET          |                              |
|             | CBD       | AQ_CLEAR        |                              |
| EPWM_AQCTLB | ZRO       | AQ_CLEAR        |                              |
|             | PRD       | AQ_SET          |                              |

**Table 12-303. EPWMx Run Time Changes for Figure 12-346**

| Register  | Bitfield | Value    | Comments                      |
|-----------|----------|----------|-------------------------------|
| EPWM_CMPA | CMPA     | EdgePosA | Adjust duty for output EPWM1A |
| EPWM_CMPB | CMPB     | EdgePosB | Adjust duty for output EPWM1B |

#### 12.5.3.4.5 EPWM Dead-Band Generator (DB) Submodule

This section describes the Dead-Band Generator (DB) submodule in the PWM module.

### **12.5.3.4.5.1 Overview**

Figure 12-347 illustrates the dead-band generator submodule within the EPWM module.



**Figure 12-347. Dead-Band Generator Submodule**

The "Action-qualifier (AQ) Module" section discussed how it is possible to generate the required dead-band by having full control over edge placement using both the CMPA and CMPB resources of the EPWM module. However, if the more classical edge delay-based dead-band with polarity control is required, then the dead-band generator submodule should be used.

The key functions of the dead-band generator submodule are:

- Generating appropriate signal pairs (EPWMxA and EPWMxB) with dead-band relationship from a single EPWMxA input
  - Programming signal pairs for:
    - Active high (AH)
    - Active low (AL)
    - Active high complementary (AHC)
    - Active low complementary (ALC)
  - Adding programmable delay to rising edges (RED)
  - Adding programmable delay to falling edges (FED)
  - Can be totally bypassed from the signal path (note dotted lines in [Figure 12-347](#))

### 12.5.3.4.5.2 Controlling and Monitoring the EPWM Dead-Band Submodule

The dead-band generator submodule operation is controlled and monitored via the following registers:

**Table 12-304. Dead-Band Generator Submodule Registers**

| Acronym    | Register Description                        | Address Offset | Shadowed |
|------------|---------------------------------------------|----------------|----------|
| EPWM_DBCTL | Dead-Band Control Register                  | 1Eh            | No       |
| EPWM_DBRED | Dead-Band Rising Edge Delay Count Register  | 20h            | No       |
| EPWM_DBFED | Dead-Band Falling Edge Delay Count Register | 22h            | No       |

#### 12.5.3.4.5.3 Operational Highlights for the EPWM Dead-Band Generator Submodule

The dead-band submodule has two groups of independent selection options as shown in Figure 12-348.

- **Input Source Selection:** The input signals to the dead-band module are the EPWMxA and EPWMxB output signals from the action-qualifier. In this section they will be referred to as EPWMxA In and EPWMxB In. Using the EPWM\_DBCTL[5-4] IN\_MODE control bits, the signal source for each delay, falling-edge or rising-edge, can be selected:
  - EPWMxA In is the source for both falling-edge and rising-edge delay. This is the default mode.
  - EPWMxA In is the source for falling-edge delay, EPWMxB In is the source for rising-edge delay.
  - EPWMxA In is the source for rising edge delay, EPWMxB In is the source for falling-edge delay.
  - EPWMxB In is the source for both falling-edge and rising-edge delay.
- **Output Mode Control:** The output mode is configured by way of the EPWM\_DBCTL[1-0] OUT\_MODE bit fields. These bits determine if the falling-edge delay, rising-edge delay, neither, or both are applied to the input signals.
- **Polarity Control:** The polarity control (EPWM\_DBCTL[3-2] POLSEL) allows to be specified whether the rising-edge delayed signal and/or the falling-edge delayed signal is to be inverted before being sent out of the dead-band submodule.



epwm-033

Figure 12-348. Configuration Options for the EPWM Dead-Band Generator Submodule

Although all combinations are supported, not all are typical usage modes. Table 12-305 lists some classical dead-band configurations. These modes assume that the EPWM\_DBCTL[5-4] IN\_MODE is configured such that EPWMxA In is the source for both falling-edge and rising-edge delay. Enhanced, or non-traditional modes can be achieved by changing the input signal source. The modes shown in Table 12-305 fall into the following categories:

- **Mode 1: Bypass both falling-edge delay (FED) and rising-edge delay (RED)** Allows to be fully disabled the dead-band submodule from the PWM signal path.
- **Mode 2-5: Classical Dead-Band Polarity Settings** These represent typical polarity configurations that should address all the active high/low modes required by available industry power switch gate drivers. The waveforms for these typical cases are shown in Figure 12-349. Note that to generate equivalent waveforms to Figure 12-349, configure the action-qualifier submodule to generate the signal as shown for EPWMxA.
- **Mode 6: Bypass rising-edge-delay and Mode 7: Bypass falling-edge-delay** Finally the last two entries in Table 12-305 show combinations where either the falling-edge-delay (FED) or rising-edge-delay (RED) blocks are bypassed.

**Table 12-305. Classical Dead-Band Operating Modes**

| Mode | Mode Description <sup>(1)</sup>                                                       | EPWM_DBCTL[3-2]<br>POLSEL |        | EPWM_DBCTL[1-0]<br>OUT_MODE |    |
|------|---------------------------------------------------------------------------------------|---------------------------|--------|-----------------------------|----|
|      |                                                                                       | S3                        | S2     | S1                          | S0 |
| 1    | EPWMxA and EPWMxB Passed Through (No Delay)                                           | x                         | x      | 0                           | 0  |
| 2    | Active High Complementary (AHC)                                                       | 1                         | 0      | 1                           | 1  |
| 3    | Active Low Complementary (ALC)                                                        | 0                         | 1      | 1                           | 1  |
| 4    | Active High (AH)                                                                      | 0                         | 0      | 1                           | 1  |
| 5    | Active Low (AL)                                                                       | 1                         | 1      | 1                           | 1  |
| 6    | EPWMxA Out = EPWMxA In (No Delay)<br>EPWMxB Out = EPWMxA In with Falling Edge Delay   | 0 or 1                    | 0 or 1 | 0                           | 1  |
| 7    | EPWMxA Out = EPWMxA In with Rising Edge Delay<br>EPWMxB Out = EPWMxB In with No Delay | 0 or 1                    | 0 or 1 | 1                           | 0  |

- (1) These are classical dead-band modes and assume that EPWM\_DBCTL[5-4] IN\_MODE = 0h0. That is, EPWMxA in is the source for both the falling-edge and rising-edge delays. Enhanced, non-traditional modes can be achieved by changing the IN\_MODE configuration.

Figure 12-349 shows waveforms for typical cases where 0% < duty < 100%.



**Figure 12-349. Dead-Band Waveforms for Typical Cases (0% < Duty < 100%)**

The dead-band submodule supports independent values for rising-edge (RED) and falling-edge (FED) delays. The amount of delay is programmed using the EPWM\_DBRED and EPWM\_DBFED registers. These are 10-bit registers and their value represents the number of time-base clock, TBCLK, periods a signal edge is delayed by. For example, the formulas to calculate falling-edge-delay and rising-edge-delay are:

$$FED = EPWM\_DBFED \times T_{TBCLK}$$

$$RED = EPWM\_DBRED \times T_{TBCLK}$$

Where  $T_{TBCLK}$  is the period of TBCLK, the prescaled version of FICLK.

#### 12.5.3.4.6 EPWM-Chopper (PC) Submodule

This section describes the PWM-Chopper (PC) submodule in the PWM module.

##### 12.5.3.4.6.1 Overview

**Figure 12-350** illustrates the PWM-chopper (PC) submodule within the EPWM module. The PWM-chopper submodule allows a high-frequency carrier signal to modulate the PWM waveform generated by the action-qualifier and dead-band submodules. This capability is important if a pulse transformer-based gate drivers to control the power switching elements is needed.



epwm-035

**Figure 12-350. PWM-Chopper Submodule**

##### 12.5.3.4.6.2

PC module key features:

- Programmable chopping (carrier) frequency
- Programmable pulse width of first pulse
- Programmable duty cycle of second and subsequent pulses
- Can be fully bypassed if not required

##### 12.5.3.4.6.3 Controlling the EPWM-Chopper Submodule

The EPWM-chopper submodule operation is controlled via the register in **Table 12-306**.

**Table 12-306. EPWM-Chopper Submodule Registers**

| Acronym    | Register Description         | Address Offset | Shadowed |
|------------|------------------------------|----------------|----------|
| EPWM_PCCTL | PWM-chopper Control Register | 3Ch            | No       |

#### 12.5.3.4.6.4 Operational Highlights for the EPWM-Chopper Submodule

Figure 12-351 shows the operational details of the EPWM-chopper submodule. The carrier clock is derived from FICLK. Its frequency and duty cycle are controlled via the CHPFREQ and CHPDUTY bits in the EPWM\_PCCTL register. The one-shot block is a feature that provides a high energy first pulse to ensure hard and fast power switch turn on, while the subsequent pulses sustain pulses, ensuring the power switch remains on. The one-shot width is programmed via the OSHTWTH bits. The PWM-chopper submodule can be fully disabled (bypassed) via the CHPEN bit.



Figure 12-351. PWM-Chopper Submodule Signals and Registers

#### 12.5.3.4.6.5 EPWM-Chopper Waveforms

Figure 12-352 shows simplified waveforms of the chopping action only; one-shot and duty-cycle control are not shown. Details of the one-shot and duty-cycle control are discussed in the following sections.



**Figure 12-352. Simple EPWM-Chopper Submodule Waveforms Showing Chopping Action Only**

#### 12.5.3.4.6.5.1 EPWM-Chopper One-Shot Pulse

The width of the first pulse can be programmed to any of 16 possible pulse width values. The width or period of the first pulse is given by:

$$T_{1\text{st} \text{pulse}} = T_{\text{FICLK}} \times 8 \times \text{OSHTWTH}$$

Where  $T_{\text{FICLK}}$  is the period of the system clock (FICLK) and OSHTWTH is the four control bits (value from 1 to 16)

Figure 12-353 shows the first and subsequent sustaining pulses.



**Figure 12-353. EPWM-Chopper Submodule Waveforms Showing the First Pulse and Subsequent Sustaining Pulses**

#### 12.5.3.4.6.5.2 EPWM-Chopper Duty Cycle Control

Pulse transformer-based gate drive designs need to comprehend the magnetic properties or characteristics of the transformer and associated circuitry. Saturation is one such consideration. To assist the gate drive designer, the duty cycles of the second and subsequent pulses have been made programmable. These sustaining pulses ensure the correct drive strength and polarity is maintained on the power switch gate during the on period, and hence a programmable duty cycle allows a design to be tuned or optimized via software control.

Figure 12-354 shows the duty cycle control that is possible by programming the CHPDUTY bits. One of seven possible duty ratios can be selected ranging from 12.5 to 87.5%.



**Figure 12-354. EPWM-Chopper Submodule Waveforms Showing the Pulse Width (Duty Cycle) Control of Sustaining Pulses**

#### 12.5.3.4.7 EPWM Trip-Zone (TZ) Submodule

This section describes the Trip-Zone (TZ) submodule in the PWM module.

##### 12.5.3.4.7.1 Overview

Figure 12-355 shows how the trip-zone (TZ) submodule fits within the EPWM module. Each EPWM module is connected to six  $\overline{TZ0}$  to  $\overline{TZ5}$  signals that are sourced from the GPIO MUX. These signals indicate external fault or trip conditions, and the EPWM outputs can be programmed to respond accordingly when faults occur. See *EPWM Integration* to determine the number of trip-zone pins available for the device.



**Figure 12-355. EPWM Trip-Zone Submodule**

The key functions of the trip-zone submodule are:

- Trip inputs  $\overline{TZ0}$  to  $\overline{TZ5}$  can be flexibly mapped to any EPWM module.
- Upon a fault condition, outputs EPWMxA and EPWMxB can be forced to one of the following:
  - High
  - Low
  - High-impedance
  - No action taken
- Support for one-shot trip (OSHT) for major short circuits or over-current conditions.
- Support for cycle-by-cycle tripping (CBC) for current limiting operation.
- Each trip-zone input pin can be allocated to either one-shot or cycle-by-cycle operation.
- Interrupt generation is possible on any trip-zone pin.
- Software-forced tripping is also supported.
- The trip-zone submodule can be fully bypassed if it is not required.

#### Note

For each EPWMx module, 6 tripzone input events are supported ( $\overline{EPWMx\_TRIP\_TZ[5:0]}$ ). Each tripzone input for all EPWMx modules are tied to a common tripzone input pin, so that any EPWMx can be triggered by any of the six tripzone inputs.

#### 12.5.3.4.7.2 Controlling and Monitoring the EPWM Trip-Zone Submodule

The trip-zone submodule operation is controlled and monitored through the following registers:

**Table 12-307. EPWM Trip-Zone Submodule Registers**

| Acronym     | Register Description                               | Address Offset | Shadowed |
|-------------|----------------------------------------------------|----------------|----------|
| EPWM_TZSEL  | Trip-Zone Select Register <sup>(1)</sup>           | 24h            | No       |
| EPWM_TZCTL  | Trip-Zone Control Register <sup>(1)</sup>          | 28h            | No       |
| EPWM_TZEINT | Trip-Zone Enable Interrupt Register <sup>(1)</sup> | 2Ah            | No       |
| EPWM_TZFLG  | Trip-Zone Flag Register <sup>(1)</sup>             | 2Ch            | No       |
| EPWM_TZCLR  | Trip-Zone Clear Register <sup>(1)</sup>            | 2Eh            | No       |
| EPWM_TZFRC  | Trip-Zone Force Register <sup>(1)</sup>            | 30h            | No       |

(1) All trip-zone registers are EALLOW protected and can be modified only after executing the EALLOW instruction.

#### 12.5.3.4.7.3 Operational Highlights for the EPWM Trip-Zone Submodule

The trip-zone signals at pin  $\overline{TZ0}$  to  $\overline{TZ5}$  is an active-low input signal. When the pin goes low, it indicates that a trip event has occurred. Each EPWM module can be individually configured to ignore or use each of the trip-zone pins. Which trip-zone pins are used by a particular EPWM module is determined by the EPWM\_TZSEL register for that specific EPWM module. The trip-zone signal may or may not be synchronized to the system clock (FICLK). A minimum of 1 FICLK low pulse on the  $\overline{TZ0}$  to  $\overline{TZ5}$  inputs is sufficient to trigger a fault condition in the EPWM module. The asynchronous trip makes sure that if clocks are missing for any reason, the outputs can still be tripped by a valid event present on the  $\overline{TZ0}$  to  $\overline{TZ5}$  inputs.

The  $\overline{TZ0}$  to  $\overline{TZ5}$  inputs can be individually configured to provide either a cycle-by-cycle or one-shot trip event for a EPWM module. The configuration is determined by the EPWM\_TZSEL[5-0] CBCk and EPWM\_TZSEL[13-8] OSHTk bit field (where k = 0 to 5 corresponds to the trip pin), respectively.

- **Cycle-by-Cycle (CBC):** When a cycle-by-cycle trip event occurs, the action specified in the EPWM\_TZCTL register is carried out immediately on the EPWMxA and/or EPWMxB output. [Table 12-308](#) lists the possible actions. In addition, the cycle-by-cycle trip event flag (EPWM\_TZFLG[1] CBC) is set and a EPWMxTZINT interrupt is generated if it is enabled in the EPWM\_TZEINT register.

The specified condition on the pins is automatically cleared when the EPWM time-base counter reaches zero (EPWM\_TBCNT[15-0] TBCNT = 0000h) if the trip event is no longer present. Therefore, in this mode, the trip event is cleared or reset every PWM cycle. The EPWM\_TZFLG[1] CBC flag bit will remain set until it is manually cleared by writing to the EPWM\_TZCLR[1] CBC bit. If the cycle-by-cycle trip event is still present when the EPWM\_TZFLG[1] CBC bit is cleared, then it will again be immediately set.

- **One-Shot (OSHT):** When a one-shot trip event occurs, the action specified in the EPWM\_TZCTL register is carried out immediately on the EPWMxA and/or EPWMxB output. [Table 12-308](#) lists the possible actions. In addition, the one-shot trip event flag (EPWM\_TZFLG[2] OST) is set and a EPWMxTZINT interrupt is generated if it is enabled in the EPWM\_TZEINT register. The one-shot trip condition must be cleared manually by writing to the EPWM\_TZCLR[2] OST bit.

The action taken when a trip event occurs can be configured individually for each of the EPWM output pins by way of the EPWM\_TZCTL[1-0] TZA and EPWM\_TZCTL[3-2] TZB register bit field. One of four possible actions, shown in [Table 12-308](#), can be taken on a trip event.

**Table 12-308. Possible Actions On an EPWM Trip Event**

| EPWM_TZCTL[1-0] TZA<br>and/or<br>EPWM_TZCTL[3-2] TZB | EPWMxA<br>and/or<br>EPWMxB | Comment                                      |
|------------------------------------------------------|----------------------------|----------------------------------------------|
| 0                                                    | High-<br>Impedance         | Tripped                                      |
| 1h                                                   | Force to High<br>State     | Tripped                                      |
| 2h                                                   | Force to Low<br>State      | Tripped                                      |
| 3h                                                   | No Change                  | Do Nothing. No change is made to the output. |

***Example of EPWM Trip-Zone Configurations***

A one-shot trip event on  $\overline{TZ0}$  pulls both EPWM1A, EPWM1B low and also forces EPWM2A and EPWM2B high.

- Configure the EPWM1 registers as follows:
  - EPWM\_TZSEL[8] OSHT1 = 1: enables  $\overline{TZ}$  as a one-shot event source for EPWM1
  - EPWM\_TZCTL[1-0] TZA = 2: EPWM1A will be forced low on a trip event
  - EPWM\_TZCTL[3-2] TZB = 2: EPWM1B will be forced low on a trip event
- Configure the EPWM2 registers as follows:
  - EPWM\_TZSEL[8] OSHT1 = 1: enables  $\overline{TZ}$  as a one-shot event source for EPWM2
  - EPWM\_TZCTL[1-0] TZA = 1: EPWM2A will be forced high on a trip event
  - EPWM\_TZCTL[3-2] TZB = 1: EPWM2B will be forced high on a trip event

***12.5.3.4.7.4 Generating EPWM Trip-Event Interrupts***

Figure 12-356 and Figure 12-357 illustrate the trip-zone submodule control and interrupt logic, respectively.



epwm-041

Figure 12-356. EPWM Trip-Zone Submodule Mode Control Logic



epwm-042

**Figure 12-357. EPWM Trip-Zone Submodule Interrupt Logic**

#### 12.5.3.4.8 EPWM Event-Trigger (ET) Submodule

This section describes the Event-Trigger (ET) submodule in the PWM module.

##### 12.5.3.4.8.1 Overview

Figure 12-358 shows the event-trigger (ET) submodule in the EPWM system. The event-trigger submodule manages the events generated by the time-base submodule and the counter-compare submodule to generate an aggregated interrupt request.



epwm-043

**Figure 12-358. EPWM Event-Trigger Submodule**

The key functions of the event-trigger submodule are:

- Receives event inputs generated by the time-base and counter-compare submodules
- Uses the time-base direction information for up/down event qualification
- Uses prescaling logic to issue interrupt requests at:
  - Every event
  - Every second event
  - Every third event
- Provides full visibility of event generation via event counters and flags

#### 12.5.3.4.8.2 Controlling and Monitoring the EPWM Event-Trigger Submodule

The key registers used to configure the event-trigger submodule are shown in [Table 12-309](#):

**Table 12-309. EPWM Event-Trigger Submodule Registers**

| Acronym    | Register Description             | Address Offset | Shadowed |
|------------|----------------------------------|----------------|----------|
| EPWM_ETSEL | Event-Trigger Selection Register | 32h            | No       |
| EPWM_EPS   | Event-Trigger Prescale Register  | 34h            | No       |
| EPWM_EFLG  | Event-Trigger Flag Register      | 36h            | No       |
| EPWM_ECLR  | Event-Trigger Clear Register     | 38h            | No       |
| EPWM_EFRC  | Event-Trigger Force Register     | 3Ah            | No       |

#### 12.5.3.4.8.3 Operational Overview of the EPWM Event-Trigger Submodule

Each EPWM module has one interrupt request line as shown in [Figure 12-359](#). Mapping interrupt lines to device host interrupt controllers is device specific and is covered in *EPWM Integration*.



**Figure 12-359. EPWM Event-Trigger Submodule Inter-Connectivity to Interrupt Controller**

The event-trigger submodule monitors various event conditions (the left side inputs to event-trigger submodule shown in [Figure 12-360](#)) and can be configured to prescale these events before issuing an Interrupt request. The event-trigger prescaling logic can issue Interrupt requests at:

- Every event
- Every second event
- Every third event



**Figure 12-360. EPWM Event-Trigger Submodule Showing Event Inputs and Prescaled Outputs**

- ETSEL — This selects which of the possible events will trigger an interrupt.
- ETPS — This programs the event prescaling options previously mentioned.
- ETLG — These are flag bits indicating status of the selected and prescaled events.
- ETCLR — These bits allow to clear the flag bits in the EPWM\_EFLG register via software.
- ETFRC — These bits allow software forcing of an event. Useful for debugging or software intervention.

A more detailed look at how the various register bits interact with the Interrupt is shown in [Figure 12-361](#).

[Figure 12-361](#) shows the event-trigger's interrupt generation logic. The interrupt-period (EPWM\_ETPS[1-0] INTPRD) bits specify the number of events required to cause an interrupt pulse to be generated. The choices available are:

- Do not generate an interrupt
- Generate an interrupt on every event
- Generate an interrupt on every second event
- Generate an interrupt on every third event

An interrupt cannot be generated on every fourth or more events.

Which event can cause an interrupt is configured by the interrupt selection (EPWM\_ETSEL[2-0] INTSEL) bits.

The event can be one of the following:

- Time-base counter equal to zero (EPWM\_TBCNT[15-0] TBCNT = 0000h).
- Time-base counter equal to period (EPWM\_TBCNT[15-0] TBCNT = EPWM\_TBPRD[15-0] TBPRD).
- Time-base counter equal to the compare A register (EPWM\_CMPA) when the timer is incrementing.
- Time-base counter equal to the compare A register (EPWM\_CMPA) when the timer is decrementing.
- Time-base counter equal to the compare B register (EPWM\_CMPB) when the timer is incrementing.
- Time-base counter equal to the compare B register (EPWM\_CMPB) when the timer is decrementing.

The number of events that have occurred can be read from the interrupt event counter (EPWM\_ETPS[3-2] INTCNT) register bits. That is, when the specified event occurs the EPWM\_ETPS[3-2] INTCNT bits are incremented until they reach the value specified by the EPWM\_ETPS[1-0] INTPRD bit field. When EPWM\_ETPS[3-2] INTCNT = EPWM\_ETPS[1-0] INTPRD the counter stops counting and its output is set. The counter is only cleared when an interrupt is sent to the interrupt controller.

When EPWM\_ETPS[3-2] INTCNT reaches EPWM\_ETPS[1-0] INTPRD, one of the following behaviors will occur:

- If interrupts are enabled, EPWM\_ETSEL[3] INTEN = 1h and the interrupt flag is clear, EPWM\_EFLG[0] INT = 0h, then an interrupt pulse is generated and the interrupt flag is set, EPWM\_EFLG[0] INT = 1h, and the event counter is cleared EPWM\_ETPS[3-2] INTCNT = 0h. The counter will begin counting events again.
- If interrupts are disabled, EPWM\_ETSEL[3] INTEN = 0h, or the interrupt flag is set, EPWM\_EFLG[0] INT = 1h, the counter stops counting events when it reaches the period value EPWM\_ETPS[3-2] INTCNT = EPWM\_ETPS[1-0] INTPRD.
- If interrupts are enabled, but the interrupt flag is already set, then the counter will hold its output high until the EFLG[0] INT flag is cleared. This allows for one interrupt to be pending while one is serviced.

Writing to the INTPRD bits will automatically clear the counter INTCNT = 0 and the counter output will be reset (so no interrupts are generated). Writing a 1h to the EPWM\_ETFRC[0] INT bit will increment the event counter INTCNT. The counter will behave as described above when INTCNT = INTPRD. When INTPRD = 0h, the counter is disabled and hence no events will be detected and the EPWM\_ETFRC[0] INT bit is also ignored.



**Figure 12-361. EPWM Event-Trigger Interrupt Generator**

#### 12.5.3.4.8.4 Operation Overview of the EPWM SOCx Pulse Generator

Figure 12-362 shows the operation of the event-trigger's start-of-conversion-A (SOCA) pulse generator. The EPWM\_ETPS[11-10] SOCACNT counter and EPWM\_ETPS[9-8] SOCAPRD period values behave similarly to the interrupt generator except that the pulses are continuously generated. That is, the pulse flag EPWM\_ETFLG[2] SOCA is latched when a pulse is generated, but it does not stop further pulse generation. The enable/disable EPWM\_ETSEL[11] SOCASEN bit stops pulse generation, but input events can still be counted until the period value is reached as with the interrupt generation logic. The event that will trigger an SOCA and SOCB pulse can be configured separately in the EPWM\_ETSEL[10-8] SOCASEL and EPWM\_ETSEL[14-12] SOCBSEL bit field. The possible events are the same events that can be specified for the interrupt generation logic.



**Figure 12-362. EPWM Event-Trigger SOCA Pulse Generator**

Figure 12-363 shows the operation of the event-trigger's start-of-conversion-B (SOCB) pulse generator. The event-trigger's SOCB pulse generator operates the same way as the SOCA.



epwm-048

Figure 12-363. EPWM Event-Trigger SOCB Pulse Generator

#### 12.5.3.4.9 EPWM Functional Register Groups

The Table 12-310 lists the groups of EPWM module registers according to their functionalities.

Table 12-310. EPWM Module Control and Status Registers Grouped by Submodule

| Register Name                                | Offset | Size (x16) | Shadow | Register Description                                    |
|----------------------------------------------|--------|------------|--------|---------------------------------------------------------|
| Time-Base (TB) Submodule Registers           |        |            |        |                                                         |
| EPWM_TBCTL                                   | 0h     | 1          | No     | Time-Base Control Register                              |
| EPWM_TBSTS                                   | 2h     | 1          | No     | Time-Base Status Register                               |
| EPWM_TBPHS                                   | 6h     | 1          | No     | Time-Base Phase Register                                |
| EPWM_TBCNT                                   | 8h     | 1          | No     | Time-Base Counter Register                              |
| EPWM_TBPRD                                   | Ah     | 1          | Yes    | Time-Base Period Register                               |
| Counter-Compare (CC) Submodule Registers     |        |            |        |                                                         |
| EPWM_CMPCTL                                  | Eh     | 1          | No     | Counter-Compare Control Register                        |
| EPWM_CMPA                                    | 12h    | 1          | Yes    | Counter-Compare A Register                              |
| EPWM_CMPB                                    | 14h    | 1          | Yes    | Counter-Compare B Register                              |
| Action-Qualifier (AQ) Submodule Registers    |        |            |        |                                                         |
| EPWM_AQCTLA                                  | 16h    | 1          | No     | Action-Qualifier Control Register for Output A (EPWMxA) |
| EPWM_AQCTLB                                  | 18h    | 1          | No     | Action-Qualifier Control Register for Output B (EPWMxB) |
| EPWM_AQSFRC                                  | 1Ah    | 1          | No     | Action-Qualifier Software Force Register                |
| EPWM_AQCSFRC                                 | 1Ch    | 1          | Yes    | Action-Qualifier Continuous S/W Force Register Set      |
| Dead-Band (DB) Generator Submodule Registers |        |            |        |                                                         |
| EPWM_DBCTL                                   | 1Eh    | 1          | No     | Dead-Band Generator Control Register                    |
| EPWM_DBRED                                   | 20h    | 1          | No     | Dead-Band Generator Rising Edge Delay Count Register    |
| EPWM_DBFED                                   | 22h    | 1          | No     | Dead-Band Generator Falling Edge Delay Count Register   |
| Trip-Zone (TZ) Submodule Registers           |        |            |        |                                                         |
| EPWM_TZSEL                                   | 24h    | 1          | No     | Trip-Zone Select Register <sup>(1)</sup>                |
| EPWM_TZCTL                                   | 28h    | 1          | No     | Trip-Zone Control Register <sup>(1)</sup>               |
| EPWM_TZEINT                                  | 2Ah    | 1          | No     | Trip-Zone Enable Interrupt Register <sup>(1)</sup>      |

**Table 12-310. EPWM Module Control and Status Registers Grouped by Submodule (continued)**

| Register Name                                 | Offset | Size (x16) | Shadow | Register Description                    |
|-----------------------------------------------|--------|------------|--------|-----------------------------------------|
| EPWM_TZFLG                                    | 2Ch    | 1          | No     | Trip-Zone Flag Register <sup>(1)</sup>  |
| EPWM_TZCLR                                    | 2Eh    | 1          | No     | Trip-Zone Clear Register <sup>(1)</sup> |
| EPWM_TZFRC                                    | 30h    | 1          | No     | Trip-Zone Force Register <sup>(1)</sup> |
| <b>Event-Trigger (ET) Submodule Registers</b> |        |            |        |                                         |
| EPWM_ETSEL                                    | 32h    | 1          | No     | Event-Trigger Selection Register        |
| EPWM_EPS                                      | 34h    | 1          | No     | Event-Trigger Pre-Scale Register        |
| EPWM_ETFLG                                    | 36h    | 1          | No     | Event-Trigger Flag Register             |
| EPWM_ETCLR                                    | 38h    | 1          | No     | Event-Trigger Clear Register            |
| EPWM_ETFRC                                    | 3Ah    | 1          | No     | Event-Trigger Force Register            |
| <b>PWM-Chopper Submodule Registers</b>        |        |            |        |                                         |
| EPWM_PCCTL                                    | 3Ch    | 1          | No     | PWM-Chopper Control Register            |

(1) EALLOW protected registers.

#### 12.5.3.4.10 Proper EPWM Interrupt Initialization Procedure

When the EPWM peripheral clock is enabled it is possible that interrupt flags may be set due to spurious events as the EPWM registers not being properly initialized. The proper procedure for initializing the EPWM peripheral is:

1. Disable global interrupts (CPU INTM flag)
2. Disable EPWM interrupts
3. Initialize peripheral registers
4. Clear any spurious EPWM flags
5. Enable EPWM interrupts
6. Enable global interrupts

### 12.5.4 Enhanced Quadrature Encoder Pulse (EQEP) Module

This section describes the Enhanced Quadrature Encoder Pulse (EQEP) module in the device.

#### 12.5.4.1 EQEP Overview

The Enhanced Quadrature Encoder Pulse (EQEP) peripheral is used for direct interface with a linear or rotary incremental encoder to get position, direction and speed information from a rotating machine for use in high performance motion and position control system. The disk of an incremental encoder is patterned with a single track of slots patterns, as shown in [Figure 12-364](#). These slots create an alternating pattern of dark and light lines. The disk count is defined as the number of dark/light line pairs that occur per revolution (lines per revolution). As a rule, a second track is added to generate a signal that occurs once per revolution (index signal: QEPI), which can be used to indicate an absolute position. Encoder manufacturers identify the index pulse using different terms such as index, marker, home position and zero reference.



**Figure 12-364. Optical Encoder Disk**

To derive direction information, the lines on the disk are read out by two different photo-elements that "look" at the disk pattern with a mechanical shift of 1/4 the pitch of a line pair between them. This shift is realized with a reticle or mask that restricts the view of the photo-element to the desired part of the disk lines. As the disk rotates, the two photo-elements generate signals that are shifted 90 degrees out of phase from each other. These are commonly called the quadrature QEPA and QEPB signals. The clockwise direction for most encoders is defined as the QEPA channel going positive before the QEPB channel and vice versa as shown in [Figure 12-365](#).

The encoder wheel typically makes one revolution for every revolution of the motor or the wheel may be at a geared rotation ratio with respect to the motor. Therefore, the frequency of the digital signal coming from the QEPA and QEPB outputs varies proportionally with the velocity of the motor. For example, a 2000-line encoder directly coupled to a motor running at 5000 revolutions per minute (rpm) results in a frequency of 166.6 kHz, so by measuring the frequency of either the QEPA or QEPB output, the processor can determine the velocity of the motor.



**Figure 12-365. QEP Encoder Output Signal for Forward/Reverse Movement**

Quadrature encoders from different manufacturers come with two forms of index pulse (gated index pulse or ungated index pulse) as shown in [Figure 12-366](#). A nonstandard form of index pulse is ungated. In the ungated configuration, the index edges are not necessarily coincident with A and B signals. The gated index pulse is aligned to any of the four quadrature edges and width of the index pulse and can be equal to a quarter, half, or full period of the quadrature signal.



**Figure 12-366. Index Pulse Example**

Some typical applications for rotary encoders range from fax machines to motor controllers, and even robot localization. Rotary sensors are fundamental to the robotics and motion control systems found today. The optical shaft encoder can be used to improve a robot in various ways. The encoder can measure rotational distance traveled and speed, which can be used to monitor, for example, the angular position of a robot gripper arm or the speed of a robot.

**General Issues:** Estimating velocity from a digital position sensor is a cost-effective strategy in motor control. Two different first order approximations for velocity may be written as:

$$V(k) \approx \frac{x(k) - x(k-1)}{T} = \frac{\Delta X}{T}$$

eqep-004

(2)

$$V(k) \approx \frac{X}{t(k) - t(k-1)} = \frac{X}{\Delta T}$$

eqep-005

(3)

where

$v(k)$ : Velocity at time instant  $k$

$x(k)$ : Position at time instant  $k$

$x(k-1)$ : Position at time instant  $k - 1$

$T$ : Fixed unit time or inverse of velocity calculation rate

$\Delta X$ : Incremental position movement in unit time

$t(k)$ : Time instant " $k$ "

$t(k-1)$ : Time instant " $k - 1$ "

$X$ : Fixed unit position

$\Delta T$ : Incremental time elapsed for unit position movement.

[Equation 2](#) is the conventional approach to velocity estimation and it requires a time base to provide unit time event for velocity calculation. Unit time is the inverse of the velocity calculation rate.

The encoder count (position) is read once during each unit time event. The quantity  $[x(k) - x(k-1)]$  is formed by subtracting the previous reading from the current reading. Then the velocity estimate is computed by multiplying by the known constant  $1/T$  (where  $T$  is the constant time between unit time events and is known in advance).

Estimation based on [Equation 2](#) has an inherent accuracy limit directly related to the resolution of the position sensor and the unit time period  $T$ . For example, consider a 500-line per revolution quadrature encoder with a velocity calculation rate of 400 Hz. When used for position the quadrature encoder gives a four-fold increase in resolution, in this case, 2000 counts per revolution. The minimum rotation that can be detected is therefore 0.0005 revolutions, which gives a velocity resolution of 12 rpm when sampled at 400 Hz. While this resolution may be satisfactory at moderate or high speeds, for example, 1% error at 1200 rpm, it would clearly prove inadequate at low speeds. In fact, at speeds below 12 rpm, the speed estimate would erroneously be zero much of the time.

At low speed, [Equation 3](#) provides a more accurate approach. It requires a position sensor that outputs a fixed interval pulse train, such as the aforementioned quadrature encoder. The width of each pulse is defined by motor speed for a given sensor resolution. [Equation 3](#) can be used to calculate motor speed by measuring the elapsed time between successive quadrature pulse edges. However, this method suffers from the opposite limitation of [Equation 2](#). A combination of relatively large motor speeds and high sensor resolution makes the time interval  $\Delta T$  small, and thus more greatly influenced by the timer resolution. This can introduce considerable error into high-speed estimates.

For systems with a large speed range (that is, speed estimation is needed at both low and high speeds), one approach is to use [Equation 3](#) at low speed and have the software switch over to [Equation 2](#) when the motor speed rises above some specified threshold.

[Figure 12-367](#) shows the EQEP module overview.



A.  $i = 0$  to number of instances - 1.

**Figure 12-367. EQEP Overview**

#### 12.5.4.1.1 EQEP Features

The EQEP module includes the following features:

- Input synchronization
- Three stage/six stage digital noise filter
- Quadrature decoder unit
- Position counter and control unit for position measurement
- Quadrature edge capture unit for low-speed measurement
- Unit time base for speed and frequency measurement
- Watchdog timer for detecting stalls
- EQEP inputs (A/B/INDEX and STROBE) are available at chip level
- EQEP phase error output is also available. The status of the phase error can be observed by software through the `CTRLMMR_EQEP_STAT` register in the `CTRL_MMR0` module.

- Counting modes:
  - Quadrature
  - Clockwise / Counter Clockwise
  - Count / Direction
- Start of Convert input for on-chip Strobe
- EQEP internal strobe (EQEP Strobe input is logically ORed with EQEP A and B inputs) may be used to:
  - Initialize the Position Counter with a non-zero value (for example, due to a limit switch input becoming active)
  - Snapshot the Position Counter into the EQEP\_QPOSSLAT register
  - Gate the EQEP Index input preventing it from resetting the Position Counter

#### 12.5.4.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

##### Note

Some features may not be available. See *Module Integration* for more information.

---

### 12.5.4.2 EQEP Environment

#### 12.5.4.2.1 EQEP I/O Interface

The EQEPI (where  $i = 0$  to  $2$ ) module is hereinafter referred to as EQEP module.

This section describes the EQEP external connections (environment).

Figure 12-368 shows the EQEP interface signals.



**Figure 12-368. EQEP External Interface I/Os**

Table 12-311 describes the EQEP I/O signals.

**Table 12-311. EQEP I/O Signals**

| Module Pin                   | Device Level Signal Name | I/O Type <sup>(1)</sup> | Description                              | Module Pin Reset Value <sup>(2)</sup> |
|------------------------------|--------------------------|-------------------------|------------------------------------------|---------------------------------------|
| <b>EQEPI<sup>(4)</sup></b>   |                          |                         |                                          |                                       |
| EQEPI <sup>(4)</sup> _A      | EQEPI <sup>(4)</sup> _A  | I                       | EQEPI <sup>(4)</sup> Quadrature input A  | HiZ                                   |
| EQEPI <sup>(4)</sup> _B      | EQEPI <sup>(4)</sup> _B  | I                       | EQEPI <sup>(4)</sup> Quadrature input B  | HiZ                                   |
| EQEPI <sup>(4)</sup> _INDEX  | EQEPI <sup>(4)</sup> _I  | I/O <sup>(3)</sup>      | EQEPI <sup>(4)</sup> Index input/output  | HiZ                                   |
| EQEPI <sup>(4)</sup> _STROBE | EQEPI <sup>(4)</sup> _S  | I/O <sup>(3)</sup>      | EQEPI <sup>(4)</sup> Strobe input/output | HiZ                                   |

(1) I = Input; O = Output

(2) HiZ = High Impedance

(3) Output functionality is not supported. Only inputs are pinned out. For more information see *Device Specific EQEP Features*.

(4)  $i$  represents an EQEP instance. See the device datasheet for available domains and EQEP instances

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables Pin Attributes and Pin Multiplexing in the device-specific Datasheet.

### 12.5.4.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.5.4.4 EQEP Functional Description

This section provides the EQEP functional description and corresponding functional details about EQEPx inputs.

##### Note

Multiple identical EQEP modules can be contained in a system. For actual number of EQEP modules integrated in the device, refer to *EQEP Integration*. The letter x within a signal or module name is used to indicate a generic EQEP instance on a device. For example, output interrupt request, EQEP0\_EQEP\_INT\_0 belongs to EQEP0, EQEP1\_EQEP\_INT\_0 belongs to EQEP1, and so forth.

The EQEP peripheral contains the following major functional units (as shown in Figure 12-369):

- Programmable input qualification for each pin (part of the GPIO MUX)
- Three stage/six stage digital noise filter
- Quadrature decoder unit (QDU)
- Position counter and control unit for position measurement (PCCU)
- Quadrature edge-capture unit for low-speed measurement (QCAP)
- Unit time base for speed/frequency measurement (UTIME)
- Unit time base for speed/frequency measurement (UTIME)
- Watchdog timer for detecting stalls (QWDOG).



eqep-006

Figure 12-369. Functional Block Diagram of the EQEP Peripheral

#### 12.5.4.4.1 EQEP Inputs

The EQEP inputs include two pins for quadrature-clock mode or direction-count mode, an index (or 0 marker), and a strobe input.

- EQEPx\_A and EQEPx\_B: These two pins can be used in quadrature-clock mode or direction-count mode.
  - Quadrature-clock mode: The EQEP encoders provide two square wave signals (A and B) 90 electrical degrees out of phase whose phase relationship is used to determine the direction of rotation of the input shaft and number of EQEP pulses from the index position to derive the relative position information. For forward or clockwise rotation, QEPA signal leads QEPB signal and vice versa. The quadrature decoder uses these two inputs to generate quadrature-clock and direction signals.
  - Direction-count mode: In direction-count mode, direction and clock signals are provided directly from the external source. Some position encoders have this type of output instead of quadrature output. The EQEPx\_A pin provides the clock input and the EQEPx\_B pin provides the direction input.
- EQEPx\_I: Index or Zero Marker: The EQEP encoder uses an index signal to assign an absolute start position from which position information is incrementally encoded using quadrature pulses. This pin is connected to the index output of the EQEP encoder to optionally reset the position counter for each revolution. This signal can be used to initialize or latch the position counter on the occurrence of a desired event on the index pin.
- EQEPx\_S: Strobe Input: This general-purpose strobe signal can initialize or latch the position counter on the occurrence of a desired event on the strobe pin. This signal is typically connected to a sensor or limit switch to notify that the motor has reached a defined position.

#### 12.5.4.4.2 EQEP Quadrature Decoder Unit (QDU)

Figure 12-370 shows a functional block diagram of the QDU.



eqep-007

Figure 12-370. Functional Block Diagram of Decoder Unit

#### 12.5.4.4.2.1 EQEP Position Counter Input Modes

Clock and direction input to position counter is selected using the QSRC bit in the EQEP decoder and control register (EQEP\_QDEC\_QEP\_CTL), based on interface input requirement as follows:

- Quadrature-count mode
- Direction-count mode
- UP-count mode
- DOWN-count mode.

#### 12.5.4.4.2.1.1 Quadrature Count Mode

The quadrature decoder generates the direction and clock to the position counter in quadrature count mode.

|                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Direction Decoding</b>   | The direction decoding logic of the EQEP circuit determines which one of the sequences (EQEPA, EQEPB) is the leading sequence and accordingly updates the direction information in the QDF bit in the EQEP status register (EQEP_QEP_STS_CT). <a href="#">Table 12-312</a> and <a href="#">Figure 12-371</a> show the direction decoding logic in truth table and state machine form. Both edges of the EQEPA and EQEPB signals are sensed to generate count pulses for the position counter. Therefore, the frequency of the clock generated by the EQEP logic is four times that of each input sequence. <a href="#">Figure 12-372</a> shows the direction decoding and clock generation from the EQEP input signals. |
| <b>Phase Error Flag</b>     | In normal operating conditions, quadrature inputs EQEPA and EQEPB will be 90 degrees out of phase. The phase error flag (QPEI_FLG) is set in the EQEP_QINT_EN_FLG register when edge transition is detected simultaneously on the EQEPA and EQEPB signals to optionally generate interrupts. State transitions marked by dashed lines in <a href="#">Figure 12-371</a> are invalid transitions that generate a phase error.                                                                                                                                                                                                                                                                                             |
| <b>Count Multiplication</b> | The EQEP position counter provides 4× times the resolution of an input clock by generating a quadrature-clock (QCLK) on the rising/falling edges of both EQEP input clocks (EQEPA and EQEPB) as shown in <a href="#">Figure 12-372</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Reverse Count</b>        | In normal quadrature count operation, EQEPA input is fed to the QA input of the quadrature decoder and the EQEPB input is fed to the QB input of the quadrature decoder. Reverse counting is enabled by setting the SWAP bit in the EQEP decoder and control register (EQEP_QDEC_QEP_CTL). This will swap the input to the quadrature decoder thereby reversing the counting direction.                                                                                                                                                                                                                                                                                                                                 |

**Table 12-312. Quadrature Decoder Truth Table**

| Previous Edge | Present Edge | QDIR   | QPOSCNT                          |
|---------------|--------------|--------|----------------------------------|
| QA↑           | QB↑          | UP     | Increment (+1)                   |
|               | QB↓          | DOWN   | Decrement (-1)                   |
|               | QA↓          | TOGGLE | Increment (+1) or Decrement (-1) |
| QA↓           | QB↓          | UP     | Increment (+1)                   |
|               | QB↑          | DOWN   | Decrement(-1)                    |
|               | QA↑          | TOGGLE | Increment (+1) or Decrement (-1) |
| QB↑           | QA↑          | DOWN   | Increment (+1)                   |
|               | QA↓          | UP     | Decrement (-1)                   |
|               | QB↓          | TOGGLE | Increment (+1) or Decrement (-1) |
| QB↓           | QA↓          | DOWN   | Increment (+1)                   |
|               | QA↑          | UP     | Decrement (-1)                   |
|               | QB↑          | TOGGLE | Increment (+1) or Decrement (-1) |



Figure 12-371. Quadrature Decoder State Machine



Figure 12-372. Quadrature-clock and Direction Decoding

#### **12.5.4.4.2.1.2 EQEP Direction-count Mode**

Some position encoders provide direction and clock outputs, instead of quadrature outputs. In such cases, direction-count mode can be used. EQEPA input will provide the clock for position counter and the EQEPB input will have the direction information. The position counter is incremented on every rising edge of a EQEPA input when the direction input is high and decremented when the direction input is low.

#### **12.5.4.4.2.1.3 EQEP Up-Count Mode**

The counter direction signal is hard-wired for up count and the position counter is used to measure the frequency of the EQEPA input. Setting of the XCR bit in the EQEP decoder and control register (EQEP\_QDEC\_QEP\_CTL) enables clock generation to the position counter on both edges of the QEPA input, thereby increasing the measurement resolution by 2x factor.

#### **12.5.4.4.2.1.4 EQEP Down-Count Mode**

The counter direction signal is hardwired for a down count and the position counter is used to measure the frequency of the EQEPA input. Setting of the XCR bit in the EQEP decoder and control register (EQEP\_QDEC\_QEP\_CTL) enables clock generation to the position counter on both edges of a EQEPA input, thereby increasing the measurement resolution by 2x factor.

#### **12.5.4.4.2.2 EQEP Input Polarity Selection**

Each EQEP input can be inverted using the in the EQEP decoder and control register (EQEP\_QDEC\_QEP\_CTL[8-5]) control bits. As an example, setting of the QIP bit in EQEP\_QDEC\_QEP\_CTL inverts the index input.

#### **12.5.4.4.2.3 EQEP Position-Compare Sync Output**

The EQEP peripheral includes a position-compare unit that is used to generate the position-compare sync signal on compare match between the position counter register (EQEP\_QPOS\_CNT) and the position-compare register (EQEP\_QPOS\_CMP). This sync signal can be output using an index pin or strobe pin of the EQEP peripheral.

Setting the SOEN bit in the EQEP decoder and control register (EQEP\_QDEC\_QEP\_CTL) enables the position-compare sync output and the SPSEL bit in EQEP\_QDEC\_QEP\_CTL selects either an EQEP index pin or an EQEP strobe pin.

#### **12.5.4.4.3 EQEP Position Counter and Control Unit (PCCU)**

The position counter and control unit provides two configuration registers (EQEP\_QDEC\_QEP\_CTL and EQEP\_QCAP\_QPOS\_CTL) for setting up position counter operational modes, position counter initialization/latch modes and position-compare logic for sync signal generation.

#### **12.5.4.4.3.1 EQEP Position Counter Operating Modes**

Position counter data may be captured in different manners. In some systems, the position counter is accumulated continuously for multiple revolutions and the position counter value provides the position information with respect to the known reference. An example of this is the quadrature encoder mounted on the motor controlling the print head in the printer. Here the position counter is reset by moving the print head to the home position and then position counter provides absolute position information with respect to home position.

In other systems, the position counter is reset on every revolution using index pulse and position counter provides rotor angle with respect to index pulse position.

Position counter can be configured to operate in following four modes

- Position Counter Reset on Index Event
- Position Counter Reset on Maximum Position
- Position Counter Reset on the first Index Event
- Position Counter Reset on Unit Time Out Event (Frequency Measurement).

In all the above operating modes, position counter is reset to 0 on overflow and to QPOSMAX bfield value in EQEP\_QPOSMAX register on underflow. Overflow occurs when the position counter counts up after QPOSMAX value. Underflow occurs when position counter counts down after "0". Interrupt flag is set to indicate overflow/underflow in EQEP\_QINT\_EN\_FLG register.

#### 12.5.4.4.3.1.1 EQEP Position Counter Reset on Index Event (EQEP\_QDEC\_QEP\_CTL[29-28] PCRM] = 0b00)

If the index event occurs during the forward movement, then position counter is reset to 0 on the next EQEP clock. If the index event occurs during the reverse movement, then the position counter is reset to the value in the EQEP\_QPOSMAX register on the next EQEP clock.

First index marker is defined as the quadrature edge following the first index edge. The EQEP peripheral records the occurrence of the first index marker (EQEP\_QEP\_STS\_CT[1] FIMF) and direction on the first index event marker (EQEP\_QEP\_STS\_CT[6] FIDF) in EQEP\_QEP\_STS\_CT registers, it also remembers the quadrature edge on the first index marker so that same relative quadrature transition is used for index event reset operation.

For example, if the first reset operation occurs on the falling edge of EQEPB during the forward direction, then all the subsequent reset must be aligned with the falling edge of EQEPB for the forward rotation and on the rising edge of EQEPB for the reverse rotation as shown in [Figure 12-373](#).

The position-counter value is latched to the EQEP\_QPOSILAT register and direction information is recorded in the EQEP\_QEP\_STS\_CT[4] QDLF bit on every index event marker. The position-counter error flag (EQEP\_QEP\_STS\_CT[0] PCEF) and error interrupt flag (EQEP\_QINT\_EN\_FLG[17] PCEI\_FLG) are set if the latched value is not equal to 0 or QPOSMAX. The position-counter error flag (EQEP\_QEP\_STS\_CT[0] PCEF) is updated on every index event marker and an interrupt flag (EQEP\_QINT\_EN\_FLG[17] PCEI\_FLG) will be set on error that can be cleared only through software.

The index event latch configuration EQEP\_QDEC\_QEP\_CTL[21-20] IEL bits are ignored in this mode and position counter error flag/interrupt flag are generated only in index event reset mode.



**Figure 12-373. Position Counter Reset by Index Pulse for 1000 Line Encoder (QPOSMAX = 3999 or F9Fh)**

#### 12.5.4.4.3.1.2 EQEP Position Counter Reset on Maximum Position (EQEP\_QDEC\_QEP\_CTL[29-28] PCRM = 0b01)

If the position counter is equal to QPOSMAX (in EQEP\_QPOSMAX register), then the position counter is reset to 0 on the next EQEP clock for forward movement and position counter overflow flag is set. If the position counter is equal to 0, then the position counter is reset to QPOSMAX on the next QEP clock for reverse movement and position counter underflow flag is set. Figure 12-374 shows the position counter reset operation in this mode.

First index marker is defined as the quadrature edge following the first index edge. The EQEP peripheral records the occurrence of the first index marker (EQEP\_QEP\_STS\_CT[1] FIMF) and direction on the first index event marker (EQEP\_QEP\_STS\_CT[6] FIDF); it also remembers the quadrature edge on the first index marker so that the same relative quadrature transition is used for the software index marker (EQEP\_QDEC\_QEP\_CTL[21-20] IEL= 0b11).



Figure 12-374. Position Counter Underflow/Overflow (QPOSMAX = 4)

eqep-011

#### 12.5.4.4.3.1.3 Position Counter Reset on the First Index Event (EQEP\_QDEC\_QEP\_CTL[29-28] PCRM = 0b10)

If the index event occurs during forward movement, then the position counter is reset to 0 on the next EQEP clock. If the index event occurs during the reverse movement, then the position counter is reset to the value in the EQEP\_QPOSMAX register on the next EQEP clock. Note that this is done only on the first occurrence and subsequently the position counter value is not reset on an index event; rather, it is reset based on maximum position as described in [Section 12.5.4.4.3.1.2](#).

First index marker is defined as the quadrature edge following the first index edge. The EQEP peripheral records the occurrence of the first index marker (EQEP\_QEP\_STS\_CT[1] FIMF) and direction on the first index event marker (EQEP\_QEP\_STS\_CT[6] FIDF) in EQEP\_QEP\_STS\_CT registers. It also remembers the quadrature edge on the first index marker so that same relative quadrature transition is used for software index marker (EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b11).

#### 12.5.4.4.3.1.4 Position Counter Reset on Unit Time out Event (EQEP\_QDEC\_QEP\_CTL[29-28] PCRM = 0b11)

In this mode, the QPOSCNT value is latched to the EQEP\_QPOSLAT register and then the QPOSCNT field is reset (to 0 or the QPOSMAX value in the EQEP\_QPOSMAX register, depending on the direction mode selected by EQEP\_QDEC\_QEP\_CTL[15-14] QSRC bits on a unit time event). This is useful for frequency measurement.

#### 12.5.4.4.3.2 EQEP Position Counter Latch

The EQEP index and strobe input can be configured to latch the position counter QPOSCNT (EQEP\_QPOSCNT) into QPOSILAT (EQEP\_QPOSILAT register) and QPOSSLAT (EQEP\_QPOSSLAT register) bitfields, respectively, on occurrence of a definite event on these pins.

##### 12.5.4.4.3.2.1 Index Event Latch

In some applications, it may not be desirable to reset the position counter on every index event and instead it may be required to operate the position counter in full 32-bit mode (EQEP\_QDEC\_QEP\_CTL[29-28] PCRM = 0b01 and EQEP\_QDEC\_QEP\_CTL[29-28] PCRM = 0b10 modes).

In such cases, the EQEP position counter can be configured to latch on the following events and direction information is recorded in the EQEP\_QEP\_STS\_CT[4] QDLF bit on every index event marker.

- Latch on Rising edge (EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b01)
- Latch on Falling edge (EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b10)
- Latch on Index Event Marker (EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b11)

This is particularly useful as an error checking mechanism to check if the position counter accumulated the correct number of counts between index events. As an example, the 1000-line encoder must count 4000 times when moving in the same direction between the index events.

The index event latch interrupt flag (EQEP\_QINT\_EN\_FLG[26] IELI\_FLG) is set when the position counter is latched to the EQEP\_QPOSILAT register. The index event latch configuration bits are ignored when EQEP\_QDEC\_QEP\_CTL[29-28] PCRM = 0b00.

When Position counter reset on an index event mode is selected through EQEP\_QDEC\_QEP\_CTL[29-28] PCRM bit field (value: 0h), EQEP\_QDEC\_QEP\_CTL[21-20] IEL bit field must be configured to 0h and position counter value is latched into the EQEP\_QPOSILAT[31-0] QPOSILAT register for every index marker.

##### Latch on Rising Edge

(EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b01)

The position counter value (QPOSCNT) is latched to the EQEP\_QPOSILAT register on every rising edge of an index input.

##### Latch on Falling Edge

(EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b10)

The position counter value (QPOSCNT) is latched to the EQEP\_QPOSILAT register on every falling edge of index input.

##### Latch on Index Event

Marker/Software Index Marker  
(EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b11)

The first index marker is defined as the quadrature edge following the first index edge. The EQEP peripheral records the occurrence of the first index marker (EQEP\_QEP\_STS\_CT[1] FIMF) and

direction on the first index event marker (EQEP\_QEP\_STS\_CT[6] FIDF) in the EQEP\_QEP\_STS\_CT registers. It also remembers the quadrature edge on the first index marker so that same relative quadrature transition is used for latching the position counter (EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b11).

Figure 12-375 shows the position counter latch using an index event marker.



**Figure 12-375. Software Index Marker for 1000-line Encoder (EQEP\_QDEC\_QEP\_CTL[21-20] IEL = 0b01)**

#### 12.5.4.3.2.2 EQEP Strobe Event Latch

The position-counter value is latched to the EQEP\_QPOSSLAT register on the rising edge of the strobe input (QCLK) by clearing the EQEP\_QDEC\_QEP\_CTL[22] SEL bit. Latching on the falling edge of the strobe input (QCLK) can be done by inverting the strobe input using the EQEP\_QDEC\_QEP\_CTL[5] QSP bit.

If the EQEP\_QDEC\_QEP\_CTL[22] SEL bit is set, then the position counter value is latched to the EQEP\_QPOSSLAT register on the rising edge of the strobe input for forward direction and on the falling edge of the strobe input for reverse direction as shown in [Figure 12-376](#).

The strobe event latch interrupt flag (EQEP\_QINT\_EN\_FLG[25] SELI\_FLG) is set when the position counter is latched to the EQEP\_QPOSSLAT register.



**Figure 12-376. EQEP Strobe Event Latch (EQEP\_QDEC\_QEP\_CTL[22] SEL = 0b1)**

#### 12.5.4.4.3.3 EQEP Position Counter Initialization

The position counter can be initialized using following events:

- Index event
- Strobe event
- Software initialization

---

#### Note

When all of the above events occur simultaneously, the sequence of priority is as follows: 1) Software Initialization, 2) strobe event initialization, 3) Index Event Initialization.

---

|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Index Event Initialization (IEI)</b>  | <p>The EQEPx_I index input can be used to trigger the initialization of the position counter at the rising or falling edge of the index input.</p> <p>If the EQEP_QDEC_QEP_CTL[25-24] IEI bits are 2h, then the position counter (EQEP_QPOSCNT) is initialized with a value in the EQEP_QPOSINIT register on the rising edge of strobe input for forward direction and on the falling edge of strobe input for reverse direction.</p> <p>The index event initialization interrupt flag (EQEP_QDEC_QEP_CTL[25-24] IEI) is set when the position counter is initialized with a value in the EQEP_QPOSINIT register.</p> <p>If EQEP_QDEC_QEP_CTL[25-24] IEI bit field is configured with value 0h (default) or 1h, the index event initialization of position counter is disabled.</p> <p>If EQEP_QDEC_QEP_CTL[25-24] IEI bit field is configured with value 3h, then the the position counter (EQEP_QPOSCNT) is initialized with a value in the EQEP_QPOSINIT register on the falling edge of strobe input signal.</p> |
| <b>Strobe Event Initialization (SEI)</b> | <p>If the EQEP_QDEC_QEP_CTL[27-26] SEI bits are 2h, then the position counter is initialized with a value in the EQEP_QPOSINIT register on the rising edge of strobe input.</p> <p>If the EQEP_QDEC_QEP_CTL[27-26] SEI bits are 3h, then the position counter (EQEP_QPOSCNT) is initialized with a value in the EQEP_QPOSINIT register on the rising edge of strobe input for forward direction and on the falling edge of strobe input for reverse direction.</p> <p>The strobe event initialization interrupt flag (EQEP_QDEC_QEP_CTL[27-26] SEI) is set when the position counter is initialized with a value in the EQEP_QPOSINIT register.</p> <p>If EQEP_QDEC_QEP_CTL[27-26] SEI bit field is configured with value 0h (default) or 1h, the strobe event initialization of position counter is disabled.</p>                                                                                                                                                                                                   |
| <b>Software Initialization (SWI)</b>     | <p>The position counter can be initialized in software by writing a 1h to the EQEP_QDEC_QEP_CTL[23] SWI bit, which will automatically be cleared after initialization.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 12.5.4.4.3.4 EQEP Position-Compare Unit

The EQEP peripheral includes a position-compare unit that is used to generate a sync output and/or interrupt on a position-compare match. [Figure 12-377](#) shows a diagram. The position-compare (EQEP\_QPOSCMP) register is shadowed and shadow mode can be enabled or disabled using the EQEP\_QCAP\_QPOS\_CTL[31] PCSHDW bit. If the shadow mode is not enabled, the CPU writes directly to the active position compare register.



Figure 12-377. EQEP Position-compare Unit

In shadow mode, SW can configure the position-compare unit (EQEP\_QCAP\_QPOS\_CTL[30] PCLOAD) to load the shadow register value into the active register on the following events and to generate the position-compare ready (EQEP\_QINT\_EN\_FLG[23] PCRI\_FLG) interrupt after loading.

- Load on compare match
- Load on position-counter zero event.

The position-compare match (EQEP\_QINT\_EN\_FLG[24] PCMI\_FLG) is set when the position-counter value (QPOSCNT) matches with the active position-compare register (EQEP\_QPOSCMP) and the position-compare sync output of the programmable pulse width is generated on compare match to trigger an external device.

For example, if EQEP\_QPOSCMP bitfield POSCMP = 0x2, the position-compare unit generates a position-compare event on the transition from 1 to 2 of the EQEP position counter for forward counting direction and on the transition from 3 to 2 of the EQEP position counter for reverse counting direction (see [Figure 12-378](#)).

#### Note

When EQEP\_QCAP\_QPOS\_CTL[30] PCLOAD = 0h, the shadow register is loaded into the active register as soon as POSCNT becomes zero, and it should not generate another shadow load if the POSCNT continues to stay at zero



**Figure 12-378. EQEP Position-compare Event Generation Points**

The pulse stretcher logic in the position-compare unit generates a programmable position-compare sync pulse output on the position-compare match. In the event of a new position-compare match while a previous position-compare pulse is still active, then the pulse stretcher generates a pulse of specified duration from the new position-compare event as shown in [Figure 12-379](#).



**Figure 12-379. EQEP Position-compare Sync Output Pulse Stretcher**

#### 12.5.4.4.4 EQEP Edge Capture Unit

The EQEP peripheral includes an integrated edge capture unit to measure the elapsed time between the unit position events as shown in [Figure 12-380](#). This feature is typically used for low speed measurement using the following equation:

$$V(k) = \frac{X}{t(k) - t(k-1)} = \frac{X}{\Delta T}$$

eqep-017

(4)

where,

- X - Unit position is defined by integer multiple of quadrature edges (see [Figure 12-381](#))
- $\Delta T$  - Elapsed time between unit position events
- $v(k)$  - Velocity at time instant "k"

The EQEP capture timer (QCTMR bitfield in EQEP\_QCTMR register) runs from prescaled SYSCLKOUT and the prescaler is programmed by the EQEP\_QCAP\_QPOS\_CTL[6-4] CCPS bits. The capture timer QCTMR value is latched into the capture period register (EQEP\_QC\_PRD\_TLAT) on every unit position event and then the capture timer is reset.

Time measurement ( $\Delta T$ ) between unit position events will be correct if the following conditions are met:

- No more than 65,535 counts have occurred between unit position events.
- No direction change between unit position events.

The capture unit sets the EQEP overflow error flag (EQEP\_QEP\_STS\_CT[3] COEF) in the event of capture timer overflow between unit position events. If a direction change occurs between the unit position events, then an error flag is set in the status register (EQEP\_QEP\_STS\_CT[2] CDEF).

Capture Timer (EQEP\_QCTMR register) and Capture period register (EQEP\_QC\_PRD\_TLAT) can be configured to latch on following events.

- CPU read of EQEP\_QPOSCNT register
- Unit time-out event

If the EQEP\_QDEC\_QEP\_CTL[18] QCLM bit is cleared, then the capture timer and capture period values are latched into the EQEP\_QC\_PRD\_TLAT and EQEP\_QCPRDLAT registers, respectively, when the CPU reads the position counter in EQEP\_QPOSCNT.

---

#### Note

Capture timer and capture period values are not latched for an emulation read.

---

If the EQEP\_QDEC\_QEP\_CTL[18] QCLM bit is set, then the position counter, capture timer, and capture period values are latched into the EQEP\_QPOSLAT, EQEP\_QC\_PRD\_TLAT and EQEP\_QCPRDLAT registers, respectively, on unit time out.

[Figure 12-382](#) shows the capture unit operation along with the position counter.

---

#### Note

The EQEP\_QCAP\_QPOS\_CTL register should not be modified dynamically (such as switching CAPCLK prescaling mode from SYSCLKOUT/4 to SYSCLKOUT/8, where SYSCLKOUT is equivalent to EQEPx\_FICLK). The capture unit must be disabled before changing the prescaler.

---



eqep-018

**Figure 12-380. EQEP Edge Capture Unit**



eqep-019

N - Number of quadrature periods selected using EQEP\_QCAP\_QPOS\_CTL[UPPS] bits

**Figure 12-381. Unit Position Event for Low Speed Measurement (EQEP\_QCAP\_QPOS\_CTL[UPPS] = 0010)**



**Figure 12-382. EQEP Edge Capture Unit - Timing Details**

Velocity Calculation Equations:

$$V(k) = \frac{x(k) - x(k-1)}{T} = \frac{\Delta X}{T} \quad \text{or}$$

$$V(k) = \frac{X}{t(k) - t(k-1)} = \frac{X}{\Delta T}$$

eqep\_021 (5)

where

$v(k)$ : Velocity at time instant  $k$

$x(k)$ : Position at time instant  $k$

$x(k-1)$ : Position at time instant  $k - 1$

$T$ : Fixed unit time or inverse of velocity calculation rate

$\Delta X$ : Incremental position movement in unit time

$X$ : Fixed unit position

$\Delta T$ : Incremental time elapsed for unit position movement

$t(k)$ : Time instant "k"

$t(k-1)$ : Time instant "k - 1"

Unit time (T) and unit period (X) are configured using the EQEP\_QUPRD and EQEP\_QCAP\_QPOS\_CTL[3-0] UPPS registers. Incremental position output and incremental time output is available in the EQEP\_QPOSLAT and EQEP\_QCPRDLAT registers.

| Parameter  | Relevant Register to Configure or Read the Information                      |
|------------|-----------------------------------------------------------------------------|
| T          | Unit Period Register (EQEP_QUPRD)                                           |
| $\Delta X$ | Incremental Position = QPOSLAT(k) - QPOSLAT(k - 1)                          |
| X          | Fixed unit position defined by sensor resolution and QCAPCTL[3-0] UPPS bits |
| $\Delta T$ | Capture Period Latch (EQEP_QCPRDLAT)                                        |

#### 12.5.4.4.5 EQEP Watchdog

The EQEP peripheral contains a 16-bit watchdog timer that monitors the quadrature-clock to indicate proper operation of the motion-control system. The EQEP watchdog timer is clocked from SYSCLKOUT/64 and the quadrature clock event (pulse) resets the watchdog timer. If no quadrature-clock event is detected until a period match (QWDPRD = QWDTMR), then the watchdog timer will time out and the watchdog interrupt flag will be set (EQEP\_QINT\_EN\_FLG[20] WTOI\_FLG). The time-out value is programmable through the watchdog period bit field (EQEP\_QWD\_TMR\_PRD[31-16] QWDPRD).



**Figure 12-383. EQEP Watchdog Timer**

#### 12.5.4.4.6 Unit Timer Base

The EQEP peripheral includes a 32-bit timer (QUTMR) that is clocked by SYSCLKOUT to generate periodic interrupts for velocity calculations. The unit time out interrupt is set (EQEP\_QINT\_EN\_FLG[27] UTOI\_FLG) when the unit timer (QUTMR) matches the unit period register (EQEP\_QUPRD).

The EQEP peripheral can be configured to latch the position counter, capture timer, and capture period values on a unit time out event. The latched values are used for velocity calculation as described in Section [Section 12.5.4.4.4](#).



eqep-023

Figure 12-384. EQEP Unit Time Base

#### 12.5.4.4.7 EQEP Interrupt Structure

Figure 12-385 shows how the interrupt mechanism works in the EQEP module.



eqep-024

Figure 12-385. EQEP Interrupt Generation

Eleven interrupt events (PCE, PHE, QDC, WTO, PCU, PCO, PCR, PCM, SEL, IEL, and UTO) can be generated. The interrupt control register (EQEP\_QINT\_EN\_FLG) is used to enable/disable individual interrupt event sources. The interrupt flag register (EQEP\_QINT\_EN\_FLG) indicates if any interrupt event has been latched and contains the global interrupt flag bit (INT). An interrupt pulse is only generated to the interrupt controller if any of the interrupt events is enabled, the flag bit is 1 and the INT flag bit is 0. The interrupt service routine will need to clear the global interrupt flag bit and the serviced event, via the interrupt clear register (EQEP\_QINT\_CLR\_FRC), before any other interrupt pulses are generated. SW can force an interrupt event by way of the interrupt force register (EQEP\_QINT\_CLR\_FRC), which is useful for test purposes.

#### 12.5.4.4.8 Summary of EQEP Functional Registers

Table 12-313 lists the registers with their memory locations, sizes, and reset values.

**Table 12-313. EQEP Control and Status Functional Registers**

| Offset | Acronym            | Register Description                               | Size (x16)/ #shadow |
|--------|--------------------|----------------------------------------------------|---------------------|
| 0h     | EQEP_QPOSCNT       | EQEP Position Counter Register                     | 2/0                 |
| 4h     | EQEP_QPOSINIT      | EQEP Position Counter Initialization Register      | 2/0                 |
| 8h     | EQEP_QPOSMAX       | EQEP Maximum Position Count Register               | 2/0                 |
| Ch     | EQEP_QPOSCMP       | EQEP Position-Compare Register                     | 2/1                 |
| 10h    | EQEP_QPOSILAT      | EQEP Index Position Latch Register                 | 2/0                 |
| 14h    | EQEP_QPOSSLAT      | EQEP Strobe Position Latch Register                | 2/0                 |
| 18h    | EQEP_QPOSLAT       | EQEP Position Counter Latch Register               | 2/0                 |
| 1Ch    | EQEP_QUTMR         | EQEP Unit Timer Register                           | 2/0                 |
| 20h    | EQEP_QUPRD         | EQEP Unit Period Register                          | 2/0                 |
| 24h    | EQEP_QWD_TMR_PRD   | EQEP Watchdog Timer and Period Register            | 2/0                 |
| 28h    | EQEP_QDEC_QEP_CTL  | EQEP Decoder and EQEP Control Register             | 2/0                 |
| 2Ch    | EQEP_QCAP_QPOS_CTL | EQEP Capture and Position Compare Control Register | 2/0                 |
| 30h    | EQEP_QINT_EN_FLG   | EQEP Interrupt Enable and Flag Register            | 2/0                 |
| 34h    | EQEP_QINT_CLR_FRC  | EQEP Interrupt Clear and Forcing Register          | 2/0                 |
| 38h    | EQEP_QEP_STS_CT    | EQEP Status and Capture Timer Register             | 2/0                 |
| 3Ch    | EQEP_QC_PRD_TLAT   | EQEP Capture Period ant Timer Latch Register       | 2/0                 |
| 40h    | EQEP_QCPRDLAT      | EQEP Capture Period Latch Register                 | 1/0                 |
| 5Ch    | EQEP_PID           | EQEP Revision ID Register                          | 2/0                 |

## 12.6 Camera Subsystem

### 12.6.1 Camera Serial Interface Receiver (CSI\_RX\_IF)

The following sections describe the Camera Serial Interface Receiver (CSI\_RX\_IF) modules in the device.

#### 12.6.1.1 CSI\_RX\_IF Overview

The integration of the CSI\_RX\_IF module allows the device to stream video inputs from multiple cameras to internal memory.

Figure 12-386 shows the CSI\_RX\_IF module overview.



Figure 12-386. CSI\_RX\_IF Module Overview

#### 12.6.1.1.1 CSI\_RX\_IF Features

The CSI\_RX\_IF module supports the following features:

- Compliant to MIPI CSI v1.3
- Supports up to 16 virtual channels per input (partial MIPI CSI v2.0 feature)
- Data rate up to 2.5 Gbps per lane (wire rate)
- Supports 1, 2, 3, or 4 Data Lane connection to DPHY\_RX
- Programmable formats including YUV420, YUV422, RGB, Raw, and User Defined (over 25 different formats supported)
- One independent (simultaneous) output stream:
  - One (up to 32 Channels) DMA interface through a 128-bit PSI\_L connection to DMSS for transfers to memory:
    - Byte packed (32x4) format, elastic buffer mode
    - Max rate 1 data cycle every 4 main clocks
    - ByteValid per byte in Last Data Phase (LDP)
    - 32 thread ID's supported (virtual channel & data type combinations); Flexible number of threads (32 Max)

- Virtual channels and data types mapped via mmr to PSI\_L thread ID's
- Internal FF based FIFO; RAM based buffer (2kx128)
- Functional and data path error interrupts
- ECC support

#### **12.6.1.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

---

##### **Note**

Some features may not be available. See *Module Integration* for more information.

---

#### **12.6.1.2 CSI\_RX\_IF Environment**

The CSI\_RX\_IF has no dedicated pins. At the device level, video inputs come from the DPHY\_RX, see [Section 12.6.2](#).

#### **12.6.1.3 Integration**

See the *Module Integration* section for information about clocks, resets and hardware requests.

### 12.6.1.4 CSI\_RX\_IF Functional Description

#### 12.6.1.4.1 CSI\_RX\_IF Block Diagram

Figure 12-387 depicts a simplified internal block diagram of the CSI\_RX\_IF and its surroundings.



Figure 12-387. CSI\_RX\_IF Block Diagram

The CSI2 core streams 4 channels of data to the export path.

**Stream0** (high BW DMA up to 32 channel contexts) streams 32-bits worth of data, that is re-formatted and sent as pixel format into 128 bits as PSIL data. There are 32 sets of MMRs/Registers that map virtual channels and data type to PSIL threads. Data is sent out PSIL in FIFO order as it is received. There is no priority. Data re-formatting is done to end up with correct data organization in memory so that other ip can use the data. The data type must be configured in MMRs to ensure proper reformatting. See [Section 12.6.1.4.5](#). The large buffer of PSIL data (2048x128) has ECC protection, see [Section 12.6.1.4.7](#)

#### 12.6.1.4.2 CSI\_RX\_IF Hardware and Software Reset

An active low asynchronous hardware reset is provided to CSI\_RX\_IF by device LPSC. It is internally resynchronized to the functional clock domain.

A software reset is triggered by configuring the CSI\_RX\_IF\_VBUS2APB\_SOFT\_RESET bit-fields for protocol reset and/or module reset.

#### 12.6.1.4.3 CSI\_RX\_IF Clock Configuration

There are four clock domain in the CSI\_RX\_IF.

1. The CSI\_RX\_MAIN\_CLK clock runs the CSI2 core and PSIL DMA. The minimum clock rate for the CSI\_RX\_MAIN\_CLK is 312.5MHz when DPHY is at max data rate (slower clock permissible when DPHY is at lower data rates). When CSI\_RX\_MAIN\_CLK is operating lower than 312.5MHz, then the clock is

essentially limiting the clock rate of the DPHY\_RX. Said another way, CSI\_RX\_MAIN\_CLK must be at least the CSI\_RX\_BYTE\_CLK rate, else FIFOs will overflow.

The maximum clock rate is 500MHz 16ffc, 650 Max

$f(\text{CSI\_RX\_BYTE\_CLK}) \times \text{nb\_lanes} / 4$ ; where  $f(\text{CSI\_RX\_BYTE\_CLK})$  is the minimum frequency of CSI\_RX\_BYTE\_CLK.

2. The CSI\_RX\_VBUS\_CLK is the interface configuration clock that runs at half the speed of the CSI\_RX\_MAIN\_CLK.
3. The CSI\_RX\_BYTE\_CLK is the clock supplied by the DPHY\_RX PLL and is divided down to byte clock. The DPHY\_RX is designed for max of 10gbps. This translates to a max byte clock of 312.5MHz. The clock is inactive when DPHY\_RX is not in HS operation.

Table 12-314 shows the CSI\_RX\_IF and DPHY\_RX inter-clock dependencies.

**Table 12-314. CSI\_RX\_IF Inter-clock Dependencies**

|                 | CSI_RX_MAIN_CLK      | CSI_RX_VBUS_CLK          | CSI_RX_VP_CLK        | CSI_RX_BYTE_CLK |
|-----------------|----------------------|--------------------------|----------------------|-----------------|
| <b>Min freq</b> | CSI_RX_BYTE_CLK freq | CSI_RX_MAIN_CLK / 2 freq | CSI_RX_BYTE_CLK freq | N/A             |
| <b>Max freq</b> | 500MHz               | CSI_RX_MAIN_CLK / 2 freq | 720MHz               | 312.5MHz        |

#### 12.6.1.4.4 CSI\_RX\_IF Interrupt Events

This section describes the register configuration of the interrupt events that can trigger the several CSI\_RX\_IF interrupt signals. For detailed description and mapping of the interrupt of the device interrupt processors see *CSI\_RX\_IF Integration*.

The interrupts are generally handled within the INTD module of the CSI\_RX\_IF, although there are several interrupt registers in the ECC\_AGGR for ECC errors and in the VBUS2APB for stream monitoring errors/flags.

Table 12-315 lists the event generation and corresponding registers of the CSI\_RX\_IF controller.

**Table 12-315. CSI\_RX\_IF Interrupt Events Cross Table**

| Event               | Mask Register                                                                   | Status Register                                                                                                                                                                                                               | Description                                                                                                                                                                                                                                                                            |
|---------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CSI_RX_CSI_ERR_I_RQ | CSI_RX_IF_VBUS2APB_ERROR_I_RQS_MASK_CFG                                         | CSI_RX_IF_VBUS2APB_ERROR_IIRQS                                                                                                                                                                                                | Stream error detected. The CSI_RX_IF0 will detect the error condition and capture the associated VC, DT and WC information for the packet header before generating an error interrupt flag on CSI_RX_CSI_ERR_IRQ. Read the status register bitfields to trace the source of the event. |
| CSI_RX_CSI_IRQ      | CSI_RX_IF_CP_INTD_ENABLE_REG_LEVEL_0<br>CSI_RX_IF_VBUS2APB_ERROR_I_RQS_MASK_CFG | CSI_RX_IF_CP_INTD_STATUS_REG_LEVEL_0<br>CSI_RX_IF_VBUS2APB_ERROR_IIRQS                                                                                                                                                        | Global functional interrupt that various resynchronized sources converge into interrupt generation.                                                                                                                                                                                    |
| CSI_RX_CSI_LEVEL    | CSI_RX_IF_VBUS2APB_MONITOR_IIRQS_MASK_CFG                                       | CSI_RX_IF_VBUS2APB_STREA_M0_FIFO_FILL_LVL<br>CSI_RX_IF_VBUS2APB_STREA_M1_FIFO_FILL_LVL<br>CSI_RX_IF_VBUS2APB_STREA_M2_FIFO_FILL_LVL<br>CSI_RX_IF_VBUS2APB_STREA_M3_FIFO_FILL_LVL<br>CSI_RX_IF_VBUS2APB_STREA_M0_FIFO_FILL_LVL | PSI_L fifo overflow or VP0/VP1 frame/line mismatch (at the minimum an error interrupt will occur at the end of frame but may be issued within the frame as well). Read the status register bitfields to trace the source of the event.                                                 |
| CSI_RX_CORR_LEVEL   | CSI_RX_IF_VBUS2APB ASF_INT_MASK                                                 | CSI_RX_IF_VBUS2APB ASF_IN_T_STATUS                                                                                                                                                                                            | This interrupt is for checking the interface signals of the CSI_RX_IF0 controller for parity.                                                                                                                                                                                          |
| CSI_RX_UNCORR_LEVEL | CSI_RX_IF_VBUS2APB ASF_INT_MASK                                                 | CSI_RX_IF_VBUS2APB ASF_IN_T_STATUS                                                                                                                                                                                            | This interrupt is for checking the interface signals of the CSI_RX_IF0 controller for parity.                                                                                                                                                                                          |

**Table 12-315. CSI\_RX\_IF Interrupt Events Cross Table (continued)**

| Event               | Mask Register                   | Status Register                   | Description                                                                                                                                                                                                                                                                                   |
|---------------------|---------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CSI_RX_CSI_FATAL    | CSI_RX_IF_VBUS2APB ASF_INT_MASK | CSI_RX_IF_VBUS2APB ASF_INT_STATUS | ASF port fatal interrupt. Level sensitive. Set CSI_RX_IF_VBUS2APB ASF_FATAL_N ONFATAL_SELECT for whether fatal or non-fatal ASF interrupt is triggered. If any of the CSI_RX_IF_VBUS2APB ASF_INT_STAT US bit is set, the CSI_RX_CSI_FATAL or CSI_RX_CSI_NONFATAL event signal is asserted.    |
| CSI_RX_CSI_NONFATAL | CSI_RX_IF_VBUS2APB ASF_INT_MASK | CSI_RX_IF_VBUS2APB ASF_INT_STATUS | ASF port non-fatal interrupt. Level sensitive. Set CSI_RX_IF_VBUS2APB ASF_FATAL_N ONFATAL_SELECT to whether fatal or non-fatal ASF interrupt is triggered. If any of the CSI_RX_IF_VBUS2APB ASF_INT_STAT US bit is set, the CSI_RX_CSI_FATAL or CSI_RX_CSI_NONFATAL event signal is asserted. |

#### 12.6.1.4.5 CSI\_RX\_IF Data Memory Organization Details

Figure 12-388 shows the YUV422-8 data organization in memory.



csi\_rx\_if-007

**Figure 12-388. CSI\_RX\_IF YUV422-8 Memory Data Organization**

Figure 12-389 shows the YUV422-10 data organization in memory.

**Address**
**YUV422-10**
**MODE**


csi\_rx\_if-008

**Figure 12-389. CSI\_RX\_IF YUV422-10 memory data organization**

Figure 12-390 shows the YUV420-8 data organization in memory.



csi\_rx\_if-009

**Figure 12-390. CSI\_RX\_IF YUV420-8 memory data organization**

Figure 12-391 shows the YUV420-10 data organization in memory.



csi\_rx\_if-010

**Figure 12-391. CSI\_RX\_IF YUV420-10 memory data organization**

Figure 12-392 shows the RAW data organization in memory.

Address **RAW(8-6)**



Address **RAW(16-9)**



Address **RAW(20)**



csi\_rx\_if-011

**Figure 12-392. CSI\_RX\_IF RAW (UNPACKED) memory data organization**

Figure 12-393 shows the RGB data organization in memory.

## Address

## RGB444



## RGB555



## RGB565



## RGB666



## RGB888



csi\_rx\_if-012

**Figure 12-393. CSI\_RX\_IF RGB memory data organization**

Figure 12-394 shows the RAW12 (PACKED) data organization in memory.

## Address RAW12, PACKED



csi\_rx\_if-012

- A. Where data does not fill out to a byte boundary it is zero extended.

**Figure 12-394. CSI\_RX\_IF RAW12 (PACKED) memory data organization**

### 12.6.1.4.6 CSI\_RX\_IF PSI\_L (DMA) Interface

#### Note

This section describes CSI\_RX\_IF PSI\_L specific functionality related to the camera interface. The general PSI\_L functional description and registers are described in the PSI\_L specific chapter (see *PSI\_L Subsystem (PSILSS)*).

#### 12.6.1.4.6.1 PSI\_L DMA framing

The CSI\_RX\_IF stream interface provides the usual VSYNC/HSYNC signals. The signals are per virtual channel where the transition from 1-to-0 or 0-to-1 represents SOF/EOF or SOL/EOL. VSYNC/HSYNC transition is usually not coincident with a valid data phase, though there are use cases where it can be. Because of the nature of CSI protocol, the VSYNC and HSYNC transactions require at least a single clock cycle and can only transition sequentially (important fact in handling of VSYNC events).

There is a rarely used mode of CSI where an entire frame is passed in a single packets without line breaks. In this mode, there are no HSYNC transitions at line starts/ends.

Lastly, there is redundant information provided with each CSI packet where the packet length is supplied in bytes.

To overcome these framing restrictions, the CSI\_RX\_IF PSILSS0 passes metadata through the DMA FIFO. Anytime metadata is inserted into the FIFO, the CSI\_RX\_IF stream is stalled for a clock cycle. The forms of supported meta tags are:

- SOF for a given virtChan
- EOF for a given virtChan
- Packet length in bytes for a given dmaCntr

The PSILSS0 will disregard the HSYNC signal entirely. The long packet beginning is used as SOL and the EOL will be "counted" using the packet length provided. In the special case where packets are of FRAME length, the SOL/EOL handling is identical.

The PSILSS0 solution for VSYNC handling is to create the concept of metadata FIFO entry which is indicated by a metadata bit. The SOF or EOF VSYNC information plus the virtualChan index is fed into the FIFO. On the output of the FIFO, the SOF is saved for each context of that virtualChan type. The very next data phase of that channel context will be marked as SOF. Additionally a state bit per context is maintained indicating the channel is MOP (middle of packet). Once the EOF arrives at the FIFO output, all contexts of that type virtual channel (and currently in MOP state) will receive a PSI\_EOP with zero active bytes of data.

**CAUTION**

The line and frame size is not known outside the CSI core (i.e. not passed to the DMA interface). Therefore any mismatches at system level programming will be unknown. If the DMA line/frame size does not match the CSI\_RX\_IF line/frame size, it is assumed the DMA will not result in any adverse side affects as a result of not enough data or too much data.

**12.6.1.4.6.2 PSI\_L DMA error handling due to FIFO overflow**

The DMA error handling is also called a PSI\_L protocol enforcer. It is intended to prevent hang of the PSILSS0. Unnatural packet size should not cause hang so only SOP/SOL/EOL/EOP framing is enforced. The following list highlights the error handling mechanism:

- For context cleanup the protocol enforcer:
  - cycle through each context index checking if context is in MOL or MOP
  - close out MOP with EOP and MOL&MOP with EOL&EOP
- dropOnFloor SOP if currently in MOPstate
- dropOnFloor EOP if not currently in MOPstate
- dropOnFloor FIFO data
- EOL context if EOP and MOLstate
- After closing out all open contexts the PSILSS0 logic will then wait till end of frame per virtual channel. Once a new frame starts it will then start sending out data from that new frame

**12.6.1.4.7 CSI\_RX\_IF ECC Protection Support**

ECC is a mechanism for providing increased system reliability (via reduction of memory soft errors) by allowing single bit errors to be detected and corrected and double bit errors to be detected.

The ECC protection on the CSI\_RX\_IF RAM provides Single Error Correction and Double Error Detection (SEC/DED). This logic detects and corrects a single bit error (1 bit error per ECC word or per ECC data segment). For memories that contain critical and/or persistent data, automatic (immediate or delayed) write-back of the corrected data to the corresponding memory address is supported. In addition, the ECC also supports multiple options for partial word writes, such as read-modify-write or multiple ECC code segments per word.

The ECC protection also provides Double Error Detection (DED). This logic only detects (does not correct) double errors (2 bit errors per ECC word or per ECC data segment).

The ECC aggregator in the CSI\_RX\_IF subsystem level consolidates the ECC configuration and status bits for all the ECC supported memories in the subsystem. It provides a single EOI-handshake based interrupt to the interrupt processors (for both single and double error detections) and a standard 32-bit VBUSP interface for configuring and querying the ECC register set, see *CSI\_RX\_IS\_ECC\_AGGR\_0 Registers*. For complete details on the features and functions of the ECC aggregator, see chapter *ECC Aggregator*.

**12.6.1.4.8 CSI\_RX\_IF Programming Guide****12.6.1.4.8.1 Overview**

This section details specific steps on how to program the CSI\_RX\_IF controller.

**12.6.1.4.8.2 Controller Configuration**

The CSI\_RX\_IF streams will default to accept all virtual channels and all data types after reset, so the user must program the stream configuration and pixel interface to match the system use case.

**Note**

The CSI\_RX\_IF controller can be configured so that the reset values can adopt the users Power\_On state. This can reduce the programming steps required by the system.

The CSI\_RX\_IF controller is designed to operate all the defined streams with all virtual channels and all data types passed to the pixel interface. Also, the connection to the front interface adopts reset values that will allow the connection of the lanes to expect no remapping.

The basic system configuration steps are then programming the number of enabled data lanes and starting the streams.

The system can also decrease the virtual channel and data type processed by the stream by configuring the data config (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_DATA\_CFG - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_DATA\_CFG) registers.

The user must perform a read from the stream config register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_CFG - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_CFG) at power up to identify the number of streams and pixel interface mode. The stream FIFO depth must be determined from the system configuration information defined at build time to ensure that any programmed [31-16] FIFO\_FILL level is valid for the available FIFO depth.

#### 12.6.1.4.8.3 Power on Configuration

The CSI\_RX\_IF requires the system to perform the configuration of the DPHY\_RX interface before starting the streams of the controller. The default configuration of the controller and each stream can be identified by reading the device ID CSI\_RX\_IF\_VBUS2APB\_DEVICE\_CONFIG register.

The FW must read the CSI\_RX\_IF\_VBUS2APB\_DEVICE\_CONFIG register at power up. This will provide the FW the number of streams that will need to be configured, and all the default system information for the FIFO structures in the available streams.

**Table 12-316. CSI\_RX\_IF\_VBUS2APB\_DEVICE\_CONFIG bitfield details**

|                    |                                                                                                                                                                                                                                                                            |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STREAMx_NUM_PIXELS | The width of the pixel interface and the bits per pixel for the selected datatype will determine how many pixels can be output in a single cycle.<br>Default will be 1 pixel per clock.<br>00 -> 1 pixel per clock<br>01 -> 2 pixels per clock<br>10 -> 4 pixels per clock |
| DATAPATH_SIZE      | Internal Datapath width 00 - 32 bit, all other values are reserved.                                                                                                                                                                                                        |
| NUM_STREAMS        | Number of Stream interfaces (1-4) = (value+1)                                                                                                                                                                                                                              |
| MAX_LANE_NB        | Max Number of Lanes (1-4) = (value+1)                                                                                                                                                                                                                                      |

Figure 12-395 shows the minimal sequence of registers that will configure the DPHY\_RX and then start the stream; this will output all the pixel information for all virtual channels and all data types detected in the link data stream.



**Figure 12-395. Minimal Stream Control - Start and Stop**

#### 12.6.1.4.8.4 Stream Start and Stop

The CSI\_RX\_IF will perform management of the stop and halt control to the pixel stream during functional operation to allow any stream to change the virtual channel or data type information that the stream will process.

- The FW will use the stream control register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_CTRL) to perform a stop (set bit 1) and wait for the end of any current frame, and wait for the stream to return its state to IDLE, which can be read from stream status register register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_STATUS - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_STATUS)[31] RUNNING = 1.
- The FW will use the stream control register to perform an abort and wait for the end of any current line, and wait for the stream to return its state to IDLE, which can be read from register STREAM\_STATUS[31] RUNNING = 1.



**Figure 12-396. Stream Reconfiguration Using Start Stop Start Flow**

The CSI\_RX\_IF will use the monitor control or STOP mechanism to stop the stream processing at the end of the active frame. The stream monitor, configuration and interrupt registers can be redefined and then the stream restarted. The pixel interface will begin processing at the next frame start.



**Figure 12-397. Stream Start and Stop Using Monitor Control**

#### 12.6.1.4.8.5 Error Control With Soft Resets

The CSI\_RX\_IF will perform control of the soft reset either for error event recovery or to clear a stream FIFO or internal state machine.

- The FRONT block can be soft reset if the DPHY\_RX becomes unresponsive and the controller wishes to maintain its configuration. In this case the DPHY\_RX resets can be applied and the DPHY\_RX enabled to begin the transfer again.
- The Protocol block can be soft reset if the FRONT soft reset is required, and the protocol is not in the IDLE state.
- The stream soft resets (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_CTRL)[4] SOFT\_RST can be used to clear the stream to the stop state and reset all the stream state machines and FIFO. If the system has a failure and wishes to clear the stream FIFO and return to a safe state on the pixel interface, the stream soft reset should be asserted.

#### 12.6.1.4.8.6 Stream Error Detected – No Error Bypass Mode

The CSI\_RX\_IF will default to stop processing the frame whenever a header Reserved DT or ECC error is detected, or when a long packet payload CRC is identified.

The CSI\_RX\_IF will detect the error condition and capture the associated VC, DT and WC information for the packet header before generating an error interrupt flag on CSI\_RX\_IF\_VBUS2APB\_ERROR IRQS.

The CSI\_RX\_IF will stop processing the current frame and stop the stream.



**Figure 12-398. Stream Error Detection Causing Stop**

#### 12.6.1.4.8.7 Stream Error Detected – Error Bypass Mode

The CSI\_RX\_IF will detect the error condition and capture the associated VC, DT and WC information for the packet header before generating an error interrupt flag on CSI\_RX\_IF\_VBUS2APB\_ERROR\_IRQS.

The CSI\_RX\_IF will continue processing the current frame and continue the stream when a header Reserved DT or a long packet payload CRC error is detected.

The CSI\_RX\_IF will stop processing the current frame and continue the stream when a packet header ECC error is detected, as the current frame synchronisation cannot be maintained.



**Figure 12-399. Stream Error Bypass - CRC Error During Payload**

#### 12.6.1.4.8.8 Stream Error Detected – Soft Reset Recovery

The CSI\_RX\_IF will stop processing the current frame and continue the stream when a packet header ECC error is detected, as the current frame synchronisation cannot be maintained.

The system can perform a soft reset on the individual stream to clear the pixel interface and payload FIFO and allow the system to restart the stream from the next frame start.



**Figure 12-400. Stream Soft Reset After ECC Non-Recoverable Error**

#### 12.6.1.4.8.9 Stream Monitor Configuration

The CSI\_RX\_IF will use the monitor control (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_MONITOR\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_MONITOR\_CTRL) or STOP mechanism to stop the stream processing at the end of the active frame. The stream monitor, configuration and interrupt registers can be redefined and then the stream restarted. The pixel interface will begin processing at the next frame start.



**Figure 12-401. Stream Start and Stop Using Monitor Control**

The FW will use the FCC config control register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CFG - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CFG) to perform a start and stop as soon as a frame count is detected. The FCC config control register will define the start and stop frame count and the

stream will identify when these values are matched. The stream output will begin when start frame is detected and then stop once the stop frame is reached. The virtual channel can be defined in CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CTRL[4-1] FCC\_VC, and must match the virtual channels that are available to the stream in the CSI\_RX\_IF\_VBUS2APB\_STREAM0\_DATA\_CFG - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_DATA\_CFG register.

The frame capture is enabled when CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CTRL[0] FCC\_EN is set '1'

The FW can check the current frame counter value from the CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CTRL[31:16] FRAME\_COUNTER

#### 12.6.1.4.8.10 Stream Monitor Frame Capture Control

To use Monitor Frame Capture Control Start and Stop operations:

1. Set Stop and Start values in config register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CFG - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CFG). Set to '0' for free-running.
  - a. [31:16] FRAME\_COUNT\_STOP -> define desired value
  - b. [15:0] FRAME\_COUNT\_START -> define desired value
2. Set the Virtual Channel to the one that is enabled and the enable in register CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CTRL.
  - a. [4:1] FCC\_VC -> define VC used
  - b. [0] FCC\_EN -> set to '1'

This will allow visual checking, by setting the Start/Stop as the following examples, this is the behaviour to be observed:

- Stop = 1 / Start = 1: Output (i.e. display) will show a Frame of the Input (i.e. camera)
- Stop = F / Start = 1: Output will show live image from the input during 14 frames and then will freeze in the last one.

Optionally software can read back the frame count value from register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CTRL).

In order to do that, software will first need to enable the monitor control register.

1. Define the same Virtual Channel as above and enable the monitor control register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_MONITOR\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_MONITOR\_CTRL).
  - a. [15] FRAME\_MON\_EN -> set to '1'
  - b. [14:11] FRAME\_MON\_VC -> define VC used
2. Read frame\_counter containing the current frame number being processed from CSI\_RX\_IF\_VBUS2APB\_STREAM0\_FCC\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_FCC\_CTRL (only when frame numbers are coming from the protocol, not when internal counter)
  - a. [31:16] FRAME\_COUNTER -> read frame number value

The easiest way to check that the frame number matches the Start and/or Stop values defined, is to use the interrupts in CSI\_RX\_IF\_VBUS2APB\_MONITOR IRQS register. To be able to do that you will need to allow those interrupts through the mask register CSI\_RX\_IF\_VBUS2APB\_MONITOR IRQS\_MASK\_CFG.

1. By default, the CSI\_RX\_IF\_VBUS2APB\_MONITOR IRQS\_MASK\_CFG register is set to all '0's, meaning all interrupts are disabled.
  - a. [4] STREAM0\_FCC\_STOP\_IRQM -> set to '1'
  - b. [3] STREAM0\_FCC\_START\_IRQM -> set to '1'
2. Create an interrupt handler to read from CSI\_RX\_IF\_VBUS2APB\_MONITOR IRQS.
  - a. [4] STREAM0\_FCC\_STOP\_IRQ -> read, if '1', Stop interrupt triggered
  - b. [3] STREAM0\_FCC\_START\_IRQ -> read, if '1', Start interrupt triggered

To ensure correct functionality, it is highly recommended that the input device (i.e. camera) should be configured after the CSI\_RX\_IF has been configured and enabled if software is using Frame Counter Control features.

Software must make sure all the Virtual Channel fields in the registers explained above are set to the correct VC being used by the stream.



**Figure 12-402. Stream Frame Capture Control Flow Diagram**

#### 12.6.1.4.8.11 Stream Monitor Timer interrupt

To use the Stream Monitor Timer operations:

1. Set Count value in timer register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_TIMER - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_TIMER). If set to 0 won't count but interrupt will still trigger every EOF or SOF.
  - a. [24:0] COUNT -> define desired value
2. Set the Virtual Channel to the one that is enabled, define timer\_eof and set enable in the monitor controll register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_MONITOR\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_MONITOR\_CTRL).
  - a. [15] FRAME\_MON\_EN -> set to '1'
  - b. [14:11] FRAME\_MON\_VC -> define VC used
  - c. [10] TIMER\_EOF -> set to '1' to count from EOF, set to '0' to count from SOF
  - d. [9] TIMER\_EN -> set to '1'
  - e. [8:5] TIMER\_VC -> define VC used

Software should now use the interrupts in register CSI\_RX\_IF\_VBUS2APB\_MONITOR\_IRQS. To be able to do that you will need to allow those interrupts through the mask register CSI\_RX\_IF\_VBUS2APB\_MONITOR\_IRQS\_MASK\_CFG.

1. By default, the CSI\_RX\_IF\_VBUS2APB\_MONITOR\_IRQS\_MASK\_CFG register is set to all '0', meaning all interrupts are disabled.
  - a. [0] STREAM0\_TIMER\_IRQM -> set to '1'
2. Create an interrupt handler to read from monitor\_irqs.
  - a. [0] STREAM0\_TIMER\_IRQ -> read, if '1', timer interrupt is triggered

To ensure correct functionality, it is highly recommended that the input device (i.e. camera) should be configured after the CSI\_RX\_IF has been configured and enabled.

Software must make sure all the Virtual Channel fields in the registers explained above are set to the correct VC being used by the stream.



Figure 12-403. Timer Interrupt Flow Diagram

#### 12.6.1.4.8.12 Stream Monitor Line/Byte Counters Interrupt

To use the stream Monitor Line and Byte counters operations:

1. Set LineCount and ByteCount values in register (CSI\_RX\_IF\_VBUS2APB\_STREAM0\_MONITOR\_LB - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_MONITOR\_LB).
  - a. [31:16] LINE\_COUNT -> define desired value
  - b. [15:0] BYTE\_COUNT -> define desired value
2. Set the Virtual Channel to the one that is enabled, and set enable in register SI\_RX\_IF\_VBUS2APB\_STREAM0\_MONITOR\_CTRL.
  - a. [15] FRAME\_MON\_EN -> set to '1'
  - b. [14:11] FRAME\_MON\_VC -> define VC used
  - c. [4] LB\_EN -> set to '1'
  - d. [3:0] LB\_VC -> set to VC used

Software should now use the interrupts in register CSI\_RX\_IF\_VBUS2APB\_MONITOR\_IRQS. To be able to do that you will need to allow those interrupts through the mask register CSI\_RX\_IF\_VBUS2APB\_MONITOR\_IRQS\_MASK\_CFG.

1. By default, the CSI\_RX\_IF\_VBUS2APB\_MONITOR\_IRQS\_MASK\_CFG register is set to all '0', meaning all interrupts are disabled.
  - a. [7] STREAM0\_LINE\_CNT\_E RROR\_IRQM -> set to '1'
  - b. STREAM0\_LB\_IRQM [1] -> set to '1'
2. Create an interrupt handler to read from CSI\_RX\_IF\_VBUS2APB\_MONITOR\_IRQS.
  - a. [7] STREAM0\_LINE\_CNT\_E RROR\_IRQ -> read, if '1', line count error interrupt is triggered
  - b. [1] STREAM0\_LB\_IRQ -> read, if '1', line/byte counter interrupt is triggered

Note that the interrupt will trigger on each frame when it reaches byte number BYTE\_COUNT in line number LINE\_COUNT.

To ensure correct functionality, it is highly recommended that the input device (i.e. camera) should be configured after the CSI\_RX\_IF has been configured and enabled.

Software must make sure all the Virtual Channel fields in the registers explained above are set to the correct VC being used by the stream.



**Figure 12-404. Line/Byte Counters Interrupt Flow Diagram**

#### 12.6.1.4.8.13 Example Controller Programming Sequence (Single Stream Operation)

The single stream operation will provide the smallest multi-lane IP configuration with the reduced registers configuration removing some control and status registers. The stream will not require a large FIFO configuration and the clock rates will be matched to simplify the implementation to single pixel transfers using all the available interface bits, (i.e. up to 32).



**Figure 12-405. Basic Single Stream Use Case Illustration**

For single pixel stream configuration, elastic buffer, RAW8 Data type on VC2, one pixel per cycle:

1. Configure the number of DPHY\_RX lanes:
  - a. See `CSI_RX_IF_VBUS2APB_STATIC_CFG` register
2. Set Error Interrupt mask:
  - a. See `CSI_RX_IF_VBUS2APB_ERROR_IRQS_MASK_CFG` register
3. Set the Pixel Interface and FIFO configuration. See `CSI_RX_IF_VBUS2APB_STREAM0_CFG` - `CSI_RX_IF_VBUS2APB_STREAM3_CFG`.
  - a. Set [9-8] `FIFO_MODE` to select the elastic buffer configuration -> '1'

- b. Set the FIFO fill level that will determines the FIFO depth that must be reached before data is output -> 0x0000
  - c. Select the number of pixels to be output on each cycle -> '0'.
  - d. Set the type of stream interface to "pixel" mode -> '0'
4. Select the virtual channel and data types to be processed. See  
CSI\_RX\_IF\_VBUS2APB\_STREAM0\_DATA\_CFG - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_DATA\_CFG  
register.
- a. Set [31-16] VC\_SELECT and virtual channel bits if not supporting all virtual channels -> 1h, 2h
  - b. Set [7] ENABLE\_DT0 and [5-0] DATATYPE\_SELECT0 values for one or both data types (default all DT)  
-> 0h, 1h, 2Ah
5. Enable the stream to begin processing the incoming data from the DPHY\_RX. See  
CSI\_RX\_IF\_VBUS2APB\_STREAM0\_CTRL - CSI\_RX\_IF\_VBUS2APB\_STREAM3\_CTRL.
- a. Set [0] START bit -> '1'

The stream will begin to pass pixel data matching the configuration on the next frame start.

#### 12.6.1.4.8.14 CSI\_RX\_IF Programming Restrictions

The following CSI\_RX\_IF programming restrictions apply:

- Full line buffer mode is not supported.
- LS/LE detection has a restriction to be disabled
- Only use Pixel transmit mode can be used, never packet mode
  - In pixel mode only single, dual, or quad mode can be used. It is not allowed to mix these based on data format or virtual channels.
- LSB alignment only
- Video port(VP) stream interfaces must be programmed in the CSI\_RX\_IF to meet the following restrictions:
  - Raw 8-16 formats only
  - Dual pixel mode
  - Filtering for single virtual channel and single data type

---

#### Note

CSI\_RX\_IF has a limitation that any line must fully be exported on its stream interface before a new line or even end of frame is sent on the D-PHY interface. To meet this requirement, software will need to take into account export rates on stream interface(single, dual, quad modes) at 500MHz versus D-PHY 32-bits @ byte clock frequency to know when a new line or end of frame can be sent in after last line was sent over D-PHY interface.

---

Table 12-317 shows the CSI\_RX\_IF programming requirements for pixel modes and data sizes.

**Table 12-317. CSI\_RX\_IF Programming requirements for pixel modes and data sizes**

| Format                          | Pixel transmit mode used | Size | Details              |
|---------------------------------|--------------------------|------|----------------------|
| RAW(6-8), user defined 8-bit    | Single                   | 0    |                      |
| RAW(6-8), user defined 8-bit    | Dual                     | 1    |                      |
| RAW(6-8), user defined 8-bit    | Quad                     | 2    |                      |
| RAW(10-16), user defined 16-bit | Single                   | 1    |                      |
| RAW(10-16), user defined 16-bit | Dual                     | 2    |                      |
| RAW20                           | Single                   | 2    |                      |
| YUV422-8                        | Single                   | 0    | must set dual mode=0 |
| YUV422-8                        | Dual                     | 0    | must set dual mode=1 |
| YUV422-10                       | Single                   | 1    |                      |
| YUV420-8                        | Single                   | 0    | must set dual mode=0 |
| YUV420-8                        | Dual                     | 0    | must set dual mode=1 |

**Table 12-317. CSI\_RX\_IF Programming requirements for pixel modes and data sizes (continued)**

| Format    | Pixel transmit mode used | Size | Details |
|-----------|--------------------------|------|---------|
| YUV420-10 | Single                   | 1    |         |

**12.6.1.4.8.15 CSI\_RX\_IF Real-time operating requirements**

Care must be taken on blanking requirements for next line, end of frame, or start of frame. The previous packets(long or short) must be fully consumed before any new line, end of frame, or start frame can be sent over the CSI interface. Software will get various error conditions if these are not met. Below are some sample equations to determine this blanking time. Note that this is not blanking data. High level details are that the internal FIFO must be completely empty prior to sending any thing new into it. below are some sample equations to determine how much time is needed to empty the FIFO and blanking time needed. Byte clock rates, pixel data type, and export modes play into the calculation as well.

$$\text{Byte\_clock\_rate} \times 8 \times \# \text{lanes} \times T_{csi} = \text{pixel\_clock\_rate} \times \text{BPP} \times T_{pix} = \text{total bits} \quad (6)$$

BPP = Bits Per Pixel. This number is how many bits are sent per pixel clock cycle is based on single, dual, quad modes and data type.

$T_{csi}$  = Time for csi interface to complete 1 line

$T_{pix}$  = Time for pixel interface to complete 1 line

$T_{pix16} = T_{pix} + 16 / \text{pixel\_clock\_rate}$

$(T_{pix16} - T_{csi})$  = required blanking time on CSI interface

$T_{pix16} - T_{csi} \leq 0$  implies 0

## 12.6.2 MIPI D-PHY Receiver (DPHY\_RX)

The following sections describe the MIPI D-PHY receiver (DPHY\_RX) module(s) in the device.

### 12.6.2.1 DPHY\_RX Overview

The integration of the DPHY\_RX camera physical port module allows the device to grab video streams from external sensor cameras and other CSI2 compliant sources.

Figure 12-406 shows the DPHY\_RX module overview.



A. <sup>(1)</sup> i represents a DPHY\_RX instance. See the device datasheet for available domains and DPHY\_RX instances.

**Figure 12-406. DPHY\_RX Module Overview**

### 12.6.2.1.1 DPHY\_RX Features

The DPHY\_RX module supports the following features:

- Compliant to MIPI D-PHY standard v1.2
- Supports up to 4 data and 1 clock lanes
- Supports up to 2.5 Gbps (with deskew) and 1.5 Gbps (without deskew) per data lane
- Clock lane control / interface logic type is **CIL-SCNN** for HS and low power receiving:
  1. **(S)** Peripheral
  2. Clock
  3. N/A forward, N/A reverse escape mode features
- Data lane control / interface logic type is **CIL-SFAN** for HS and low power receiving:
  1. **(S)** Peripheral
  2. Forward direction only for high speed mode
  3. All forward direction escape mode features are supported
  4. No reverse direction escape mode features are supported

- Data lanes can be independently operated in HS or ULP mode
- Swapping of DP/DN signals within each clock/data pair (Facilitated by CSI\_RX\_IF controller)

#### **12.6.2.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

---

##### **Note**

Some features may not be available. See *Module Integration* for more information.

---

### 12.6.2.2 DPHY\_RX Environment

This section describes the DPHY\_RX application fields from an environment point of view (external connections).



A. i represents a DPHY\_RX instance. See the device datasheet for available domains and DPHY\_RX instances.

**Figure 12-407. DPHY\_RX Environment**

Table 12-318 describes the external signals of the DPHY\_RX.

**Table 12-318. DPHY\_RX I/O Signals**

| Device Level Signal           | I/O | Description                                                                                                                                                                                 |
|-------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DPHY_RXi<sup>(1)</sup></b> |     |                                                                                                                                                                                             |
| CSli <sup>(1)</sup> _RXN0     | I   | Lane 0 Receive Differential Data (Negative)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXP0     | I   | Lane 0 Receive Differential Data (Positive)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXN1     | I   | Lane 1 Receive Differential Data (Negative)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXP1     | I   | Lane 1 Receive Differential Data (Positive)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXN2     | I   | Lane 2 Receive Differential Data (Negative)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXP2     | I   | Lane 2 Receive Differential Data (Positive)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXN3     | I   | Lane 3 Receive Differential Data (Negative)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXP3     | I   | Lane 3 Receive Differential Data (Positive)                                                                                                                                                 |
| CSli <sup>(1)</sup> _RXCLKN   | I   | Lane 3 Receive Differential Clock (Negative)                                                                                                                                                |
| CSli <sup>(1)</sup> _RXCLKP   | I   | Lane 3 Receive Differential Clock (Positive)                                                                                                                                                |
| CSli <sup>(1)</sup> _RXRCALIB | A   | Pin for external calibration resistor. An external resistor must be connected between this pin and package ground. Refer to the device-specific Datasheet for a recommended resistor value. |

(1) i represents a DPHY\_RX instance. See the device datasheet for available domains and DPHY\_RX instances

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

#### 12.6.2.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.6.2.4 DPHY\_RX Functional Description

##### 12.6.2.4.1 DPHY\_RX Programming Guide

###### 12.6.2.4.1.1 Overview

This section details specific steps on how to program the DPHY\_RX

###### 12.6.2.4.1.2 Initial Configuration Programming

The DPHY\_RX operation shows the registers that are written during the startup sequence.

This section provides description and timing diagrams for DPHY\_RX operation. Unless otherwise described in this subsection, the DPHY\_RX PPI interface is compliant with the timing diagrams described in the MIPI D-PHY v1.2 specification.

###### 12.6.2.4.1.2.1 Start-up Sequence Timing Diagram

The common configuration pins noted in [Figure 12-408](#) are ipconfig\_cmn, pll\_ipdiv, pll\_fbdv, pll\_opdiv, psm\_clock\_freq\_cmn. Drive these pins as per the pin description given in PHY pin list.



**Figure 12-408. Common Power Up and Initialization Timing Diagram**



**Figure 12-409. Lane Power Up and Initialization Timing Diagram**



Figure 12-410. PHY Disable Timing Diagram

For initial set up, the DPHY\_RX must be configured/set (registers and configuration input pins) for the common module prior to releasing it from reset, and the lane modules prior to releasing them from reset. Registers shall be configured (as required) between releasing the APB from reset and releasing the common / lanes from reset.

Note that in some cases, the option exists to configure a function using either a pin or a register. In such cases, both options will be specified and the you can select the preferred option.

#### 12.6.2.4.1.3 Common Configuration

**Table 12-319. Common Configuration-Related Setup**

| Configuration Register / Pin                                                                                                                   | Configuration Requirement                                                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PHY Pin: psm_clock_freq<br>PHY Register:<br>DPHY_RX_VBUS2APB_PCS_TX_DIG_TBIT 1                                                                 | Set the PMA state machine clock frequency divider.<br>Set either the pin or the register, as specified in the respective description, for the required PMA state machine clock. |
| PHY Pin: ipconfig_cmn<br>PHY Register:<br>DPHY_RX_MMR_SLV_LANE[11-9]<br>IPCONFIG_CMN                                                           | Set the clock lane configuration.<br>Set as specified in the description for the required clock lane configuration.                                                             |
| PMA Register:<br>DPHY_RX_VBUS2APB_CMNO_CMN_DIG_TBIT2[0] O_CMN_SSM_EN,<br>DPHY_RX_VBUS2APB_CMNO_CMN_DIG_TBIT2[10] O_CMN_RX_MODE_EN              | Enable the startup state machines for TX mode of operation.<br>Set both register bits to 1'b1.                                                                                  |
| PHY Register:<br>DPHY_RX_VBUS2APB_PCS_TX_DIG_TBIT 2                                                                                            | Set the required power island phase 2 time.<br>Set the register to 32'hAAAAAAAA.                                                                                                |
| PHY Register:<br>DPHY_RX_VBUS2APB_PCS_TX_DIG_TBIT 3[7:4] POWER_SW_2_TIME_CL_R,<br>DPHY_RX_VBUS2APB_PCS_TX_DIG_TBIT 3[3:0] POWER_SW_2_TIME_CL_L | Set the required power island phase 2 time.<br>Set the register to 8'hAA                                                                                                        |

#### 12.6.2.4.1.4 Lane Configuration

**Table 12-320. Lane Configuration-Related Setup**

| Configuration Register / Pin                        | Configuration Requirement                                                                                                         |
|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| PHY Register:<br>DPHY_RX_VBUS2APB_PCS_TX_DIG_TBIT 0 | Set the lane band control value.<br>Set the register fields, as specified in the register description for the required data rate. |

## 12.7 Timer Modules

This section describes the timer modules in the device.

### 12.7.1 Global Timebase Counter (GTC)

This section describes the global timebase counter (GTC) in the device.

#### 12.7.1.1 Global Timebase Counter (GTC)

This section describes the Global Timebase Counter (GTC) in the device.

##### 12.7.1.1.1 GTC Overview

The GTC module provides a continuous running counter that can be used for time synchronization and debug trace time stamping.

##### 12.7.1.1.1.1 GTC Features

The GTC supports the following features:

- 64-bit up counter
- No rollover during the lifetime of the device
- Compatible with ARMv8 system counter requirements:
  - Disabled at power-up
  - Register definition and memory map aligned to ARMv8 definition
  - Implements memory-mapped counter control and status frames
- Outputs reflected binary (Gray) encoded timer value for system timer bus distribution to other modules
- Selectable counter bit output as a push event that can be used by CPTS modules, timers or interface protocols

##### 12.7.1.1.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

##### Note

Some features may not be available. See *Module Integration* for more information.

---

### 12.7.1.2 GTC Functional Description

#### 12.7.1.2.1 GTC Block Diagram

The GTC is essentially comprised of a 64-bit up counter, a Gray encoder, a 64-bit multiplexer, and memory-mapped control registers. Figure 12-411 shows a high-level block diagram of the GTC.



**Figure 12-411. GTC Block Diagram**

#### 12.7.1.2.2 GTC Counter

The counter is a 64-bit binary up counter that increments on every GTC\_CLK rising edge. The source for GTC\_CLK is selected through a mux which is controlled via the CTRLMMR\_GTC\_CLKSEL[2-0] CLK\_SEL register bit field.

The counter is disabled by default (at power-on-reset) and increments only when enabled by setting the GTC\_CNTCR[0] EN bit to '1'. The current counter value is readable via the combined COUNTVALUE bit field of both GTC\_CNTCV\_HI (upper 32 bits) and GTC\_CNTCV\_LO (lower 32 bits) registers.

When counting is disabled, a new counter value can be loaded via a software write to the combined COUNTVALUE bit field. In this case, when the counter gets re-enabled, it will start counting from the last value written to this field.

The counter can be optionally configured to stop incrementing when a debug halt signal is issued, by writing a '1' to the GTC\_CNTCR[1] HDBG bit. This condition is indicated through the GTC\_CNTSR[1] DBGH status bit.

##### 12.7.1.2.2.1 Steps to Clear the Counter Value to Zero

1. Disable the GTC
2. Clear GTC\_CNTCV\_LO (First)
3. Clear GTC\_CNTCV\_HI (Second)
4. Enable the GTC

Once the GTC is enabled, the GTC\_CNTCV\_HI bit will be cleared to zero.

##### 12.7.1.2.3 GTC Register Partitioning

The ARMv8 architecture spec requires specific system-level components, each with one or two register frames. To accommodate this, the GTC memory-mapped registers (MMRs) are divided into four separate regions (4KB each):

- Peripheral MMRs (GTC0\_GTC\_CFG0): This region includes standard peripheral identification registers and any other control registers not associated with the ARMv8 system timer functions.

- Counter control MMRs (GTC0\_GTC\_CFG1): This region includes registers that provide control over the operation of the system timer.
- Counter status MMRs (GTC0\_GTC\_CFG2): This region includes registers that provide a mechanism for reading the status of the system timer.
- Timer control MMRs (GTC0\_GTC\_CFG3): This region includes registers that identify and provide a control mechanism for memory-mapped timer implementations. For this device, no memory-mapped timers are implemented and only the minimum registers required to indicate the presence of no timers are necessary.

### 12.7.2 RTI-Windows Watchdog Timer (WWDT)

This section describes the Windowed Watchdog Timer (WWDT), implemented by using the Digital Windowed Watchdog (DWWD) function of the Real Time Interrupt (RTI) module in the device.

#### CAUTION

The RTI module shall be used to serve only as a Digital Windowed Watchdog (DWWD).

The Real Time Interrupt module provides timer functionality for operating systems and for benchmarking code. The module incorporates several counters, which define the timebases needed for scheduling in the operating system.

This module is specifically designed to fulfill the requirements for OSEK ("Offene Systeme und deren Schnittstellen für die Elektronik im Kraftfahrzeug"; "Open Systems and the Corresponding Interfaces for Automotive Electronics") as well as OSEK/Time compliant operating systems.

The timers also provide the ability to benchmark certain areas of code by reading the counter contents at the beginning and the end of the desired code range and calculating the difference between the values.

#### 12.7.2.1 RTI Features

The RTI modules include the following main features:

- Windowed Watchdog Timer (WWDT) feature.
- Two independent 64 bit counter blocks (counter block0 or counter block1). Each block consists of
  - One 32 bit up counter
  - One 32 bit free running counter
  - Two capture registers for capturing the prescale and free running counter on a special event.
- Free running counter 0 can be incremented by either the internal prescale counter or by an external event.
- Four configurable compare registers for generating operating system ticks . Each event can be driven by either counter block0 or counter block1.
- Fast enabling/disabling of events.
- RTI clock input derived from any of the available clock sources, selectable in the System Module
- Optional capability to drive a pulse-width modulated signal out on an interrupt line.

#### 12.7.2.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

#### Note

Some features may not be available. See *Module Integration* for more information.

### 12.7.2.3 RTI Functional Description

The MCU\_RTI0 and RTI modules are hereinafter referred to as RTI module.

#### 12.7.2.3.1 RTI Digital Windowed Watchdog

---

##### Note

Some of the RTI features described in this section may not be supported on this family of devices. For more information, see *RTI Not Supported Features*.

---

---

##### Note

Digital windowed watchdog (DWWD) timer is implemented using the digital windowed watchdog function of the RTI modules. Real time interrupt functionality is not supported. In this mode, the timer should default to disabled and user can adjust the period as desired before enabling the watchdog.

---

In addition to the time-out boundary configurable via the digital watchdog (DWD), some applications may also want to configure the start-time boundary of the watchdog. This is enabled by the digital windowed watchdog (DWWD) feature.

#### Functional Behavior

The DWWD opens a configurable time window in which the watchdog must be serviced. Any attempt to service the watchdog outside this time window, or a failure to service the watchdog in this time window, will cause the watchdog to generate either a reset or a non-maskable interrupt to the CPU. This is controlled by configuring the RTI\_WWDRXNCTRL register. As stated earlier, when the watchdog needs to be enabled by software, the watchdog counter is disabled on a system reset. When the DWWD is configured to generate a non-maskable interrupt on a window violation, the watchdog counter continues to count down. The RTI\_INTR\_WWD interrupt handler needs to clear the watchdog violation status flag(s) and then service the watchdog by writing the correct sequence in the watchdog key RTI\_WDKEY register. This service will cause the watchdog counter to get reloaded from the preload value and start counting down. If the RTI\_INTR\_WWD handler does not service the watchdog in time, it could count down all the way to zero and wrap around. No second exception for a time out is generated in this case.

#### Configuration of DWWD

The DWWD preload value (same as DWD preload) can only be configured when the DWWD counter is disabled. The window size and watchdog reaction to a violation can be configured even after the watchdog has been enabled. Any changes to the window size and watchdog reaction configurations will only take effect after the next servicing of the DWWD.



Figure 12-412. RTI Digital Windowed Watchdog Timing Example



Figure 12-413. RTI Digital Windowed Watchdog Operation Block Diagram

### 12.7.2.3.1.1 RTI Debug Mode Behavior

---

#### Note

Some of the RTI features described in this section may not be supported on this family of devices. For more information, see *RTI Not Supported Features*.

---

Once the system enters debug mode, the behavior of the RTI depends on the RTI\_GCTRL[15] COS bit. If the bit is cleared and debug mode is active, all counters will stop operation. If the bit is set to one, all counters will be clocked normally and the RTI will work like in normal mode.

The DWD counter will not decrement in debug mode and will hold its current value, regardless of the RTI\_GCTRL[15] COS bit.

---

#### Note

The user must not service the watchdog while in debug mode.

---

### 12.7.2.3.1.2 RTI Low Power Mode Operation

The operation of the RTI module is guaranteed in run, doze and snooze mode. In sleep or hibernate mode all clocks will be switched off and the RTI module will not work.

In doze and snooze modes all parts of the RTI are active, since it has to be able to wake up the device with compare and timebases interrupts. Capturing events generated by the interrupt module is also possible since in both modes the peripheral modules are able to generate interrupts, which can trigger capture events. The RTI module will generate compare and timebases interrupts. The compare interrupts will periodically wake up the device.

---

#### Note

In the special case of doze mode with DPLL off, RTI\_FCLK might have a different period than with DPLL enabled, since RTI\_FCLK will be derived from the oscillator output. It has to be ensured that the RTI\_ICLK to RTI\_FCLK ratio is at least 3:1.

---

The DWD/DWWWD remains active when the device enters low power mode as long as the RTI\_FCLK is kept active.

Whenever the LPSC that controls an RTI is in any state other than Enable (see *Module States*), the RTI cannot count or generate interrupts. For more information, see *Power Control Modules*.

During standard SoC warm reset the RTI and the rest of the SoC are reset. In this case, the RTI counters are stopped and interrupts are not issued. During reset-isolated warm reset, if an R5FSS is put in reset-isolation, then the associated RTI also becomes reset isolated. As such, the R5FSS and the RTI are not reset, but RTI stops counting and cannot generate interrupts until R5FSS is taken out of CLKSTOP (brought to Enable state).

### 12.7.2.3.2 RTI Digital Watchdog

---

#### Note

Some of the RTI features described in this section may not be supported on this family of devices. For more information, see *RTI Not Supported Features*.

---

Some applications might use a digital watchdog (DWD) integrated in the RTI module. The digital watchdog generates resets after a programmable period, if no correct key sequence is written to the RTI\_WDKEY register. Figure 12-414 shows the digital watchdog functional block.



Figure 12-414. RTI Digital Watchdog Functional Block Diagram

The digital watchdog functionality is implemented such that it can be enabled by software.

The DWD starts counting down from the reset value of the RTI\_DWDCNTR (DWD Counter Register). The DWD preload register can be configured at any time by the application according to the desired time-out period.

When enabled by software, the digital watchdog is disabled after system reset. If it should be used, it has to be enabled by writing A98559DAh to the RTI\_DWDCTRL register. The DWD timeout period must be configured using the DWD preload register before the DWD is enabled. The DWD cannot be disabled by the application once it is enabled.

---

#### Note

When the DWD is enabled by software, any system reset will disable the DWD. This reset could have been generated by the watchdog itself.

If the correct key sequence is written to the RTI\_WDKEY register (E51Ah followed by A35Ch), the 25-bit DWD Down Counter is reloaded with the 12-bit preload value stored in RTI\_DWDPRLD register. If any incorrect value is written to the RTI\_WDKEY register, a watchdog reset will occur immediately. A reset will also be generated, when the DWD Down Counter is decremented to 0.

The user has to take into account that the write to the RTI\_WDKEY register takes 3 RTI\_ICLK cycles. This needs to be considered for the DWD expiration calculation.

The DWD Down Counter will be decremented with RTI\_FCLK frequency. If the RTI\_FCLK is switched off via the disable registers of the Clock management, the DWD counter stops decrementing. The DWD module cannot generate a reset under this condition.



**Figure 12-415. RTI Digital Watchdog Operation**

The expiration time of the DWD Down Counter can be determined with following equation:

$$t_{exp} = (RTI\_DWDPRLD + 1) \times 2^{13} / RTI\_FCLK \quad (7)$$

where  $RTI\_DWDPRLD = 0 \dots 4095$

#### 12.7.2.3.3 RTI Counter Operation

---

##### Note

Some of the RTI features described in this section may not be supported on this family of devices. For more information, see *RTI Not Supported Features*.

---

Figure 12-416 shows the RTI module counter blocks. The RTI module supports two counter blocks.



rti-004

**Figure 12-416. RTI Counters Block Diagram**

Each block consists of two 32 bit up counters - Up Counter (UC) and Free Running Counter (FRC). The Up Counter (RTI\_UC0 or RTI\_UC1 register) is driven by the RTI\_FCLK and counts up until the compare value in the Compare Up Counter register (RTI\_CPUC0 or RTI\_CPUC1) is reached. When the compare matches, the second counter (RTI\_FRC0 or RTI\_FRC1 register), which is a free running counter, is incremented. At the same time UCx is reset to zero.

To ensure the consistency of the counters, when both counter value have to be determined, the Free Running Counter has to be read first. This will ensure that at the CPU read cycle, the Up Counter value is stored in the counter register. The second read is done on the Up Counter register, which holds then the value of the counter cycle of the previous read on the Free Running Counter register.

Both blocks provide also a capture feature on external events. Two capture sources can trigger the capture event. Which event triggers block 0 or block 1 is configurable from the RTI\_CAPCTRL register. The sources are coming from the interrupt manager, in order to be able to generate a capture event when one of the peripheral modules has generated an interrupt. The peripheral, which can generate an event is configured in the interrupt manager. When the event is detected, UCx and FRCx are stored in Capture Up Counter (RTI\_CAU0 or RTI\_CAU1) and Capture Free Running Counter (RTI\_CAFRC0 or RTI\_CAFRC1) registers. The read order of the captured values has to be like the order of the actual counters. So the CAFRCx has to be read first and the CAUCx registers has to be read after the CAFRCx value was determined. While the CAFRCx is read the CAUCx

value is loaded into a shadow register to ensure data consistency, if during the two reads of the captured data another capture event happens. If the application fails to read the two registers before a second capture event happens, the previous data will be overwritten.

Figure 12-417 shows the block diagram for one compare block. The RTI module supports four compare blocks.



**Figure 12-417. RTI Compare Block Diagram**

In order to generate interrupt requests to the interrupt manager, there are four compare registers (RTI\_COMP0, RTI\_COMP1, RTI\_COMP2, and RTI\_COMP3). Each of the compare registers can be configured to work either on FRC0 (Counter block0) or FRC1 (Counter block1). When the counter value matches the compare value, an interrupt is generated. This sets an interrupt request line to the interrupt manager. The compare value gets updated automatically with the value stored in Update Compare (RTI\_UDCP0, RTI\_UDCP1, RTI\_UDCP2, and RTI\_UDCP3) registers when the compare matches. This gives the ability to generate periodic interrupts/DMA requests without having to update the compare value by software.

An optional feature allows an application to program another compare value which is then used to clear the interrupt request line. This feature is supported by four compare clear registers (RTI\_COMP0CLR, RTI\_COMP1CLR, RTI\_COMP2CLR, and RTI\_COMP3CLR). When the counter value matches the compare clear value, the interrupt line is cleared. This clears the interrupt request line to the interrupt manager. The compare clear value gets updated automatically with the value stored in Update Compare (RTI\_UDCPx) registers when the compare matches.

### 12.7.3 Real-Time Clock (RTC)

#### 12.7.3.1 RTC Overview

The basic purpose for the RTC is to keep time of day. The other equally important purpose of RTC is for Digital Rights management. Some degree of tamper proofing is needed to ensure that simply stopping, resetting, or corrupting the RTC does not go unnoticed so that if this occurs, the application can re-acquire the time of day from a trusted source. The final purpose of the RTC is to wake the rest of chip up from a power down state.

#### 12.7.3.1.1 RTC Features

The real-time clock (RTC) provides the following features:

- With Analog IP block
  - 2 digital voltage domains with integrated LVL/ISO cells
    - CORE or volatile domain, same as core SOC
    - RTC or Always ON domain
  - Without Analog IP block
    - 1 digital voltage domain, no lvl.iso
- 15 bit 32768Hz counter
- 48 bit seconds counter with +/- 1 30uS upto +/- 1 S drift adjustment every 4048 Seconds
- 256 bits of Scratch PAD
- 1 ON\_OFF compare event, 48-bits
- 1 OFF\_ON compare event, 48-bits
- 2 event outputs OFF\_ON and ON\_OFF to CORE
- Support active external 32768 Hz and inactive/gated 32768 Hz
- This allows HOST PROCESSOR to use some of the counter registers as general purpose
- CORE protection logic which enables loose ISO assertion
- Functional lockout, unlock by special vbusp sequence
- DFT lockout, unlock by special 1500 sequence
- HOST PROCESSOR can issue OFF now cmd
- HOST PROCESSOR can update MMRs without polling, thanks to HW Shadow/Auto Sync
- HOST PROCESSOR can read time without polling, thanks to HW Shadow/Auto Sync
- External IOs (*Optional*)
  - 4 wakeup inputs with active high/low including optional debounce
    - Async wake up supported
  - 1 pmic\_enable output
- Analog Interface (*Optional*)
  - 32 bit Analog Config output
  - ISO input
  - 32KHz input

#### 12.7.3.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

##### Note

Some features may not be available. See *Module Integration* for more information.

---

#### 12.7.3.2 RTC Integration

This device includes a Real-Time (RTC) module to allow easy tracking of time and date and the generation of real time alarms.

The following tables provide pin level detail for each of the interfaces on this module.

**Table 12-321** describes the 1500 Interface for the DFT unlock circuit.

**Table 12-321. 1500 Interface**

| Signal Name    | Direction | Default Value | Description                              |
|----------------|-----------|---------------|------------------------------------------|
| jtag_wrck      | In        | 1'd0          | 1500 wrapper clock                       |
| jtag_wrstn_n   | In        | 1'd1          | 1500 wrapper reset (active low)          |
| jtag_wsi       | In        | 1'd0          | 1500 wrapper serial input                |
| jtag_selectwir | In        | 1'd0          | 1500 select wrapper instruction register |
| jtag_shiftwr   | In        | 1'd0          | 1500 shift wrapper register              |
| jtag_updatewr  | In        | 1'd0          | 1500 update wrapper register             |

**Table 12-321. 1500 Interface (continued)**

| Signal Name    | Direction | Default Value | Description                   |
|----------------|-----------|---------------|-------------------------------|
| jtag_capturewr | In        | 1'd0          | 1500 capture wrapper register |
| jtag_wso       | Out       | 1'd0          | 1500 wrapper serial out       |

Table 12-322 describes the PMIC Control External Wakeup and PMIC ON/OFF Control IOs.

**Table 12-322. PMIC Control IOs**

| Signal Name         | Direction | Default Value | Description                          |
|---------------------|-----------|---------------|--------------------------------------|
| pmic_ext_wakeup0_io | In        | 1'd0          | RTC Wakeup0                          |
| pmic_ext_wakeup1_io | In        | 1'd0          | RTC Wakeup1                          |
| pmic_ext_wakeup2_io | In        | 1'd0          | RTC Wakeup2                          |
| pmic_ext_wakeup3_io | In        | 1'd0          | RTC Wakeup3                          |
| pmic_pmic_enable_io | Out       | 1'd1          | RTC PMIC Enable<br>1 = ON<br>0 = OFF |

**Table 12-323. Analog Interface**

| Signal Name    | Direction | Default Value | Description                                                                                                                                                                                                                                                          |
|----------------|-----------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ana_osc32k_clk | In        | NA            | Analog 32768 buffered<br>Crystal clock<br>If no analog, provide a near<br>32768 clock                                                                                                                                                                                |
| ana_iso        | In        | 1'd0          | Analog ISO<br>1 = Isolated<br>0 = Not Isolated<br>If no analog, tie 1'b0                                                                                                                                                                                             |
| ana_porz       | In        | NA            | Analog PowerOnReset<br>1 = not asserted<br>0 = asserted<br>This will assert when ON/BAT<br>domain is powering up<br>If no analog, then you can<br>connect same reset which was<br>used for rst_mod_g_rst_n<br>You can also use por_rst_n class,<br>it's a don't care |
| ana_cfg[31:0]  | Out       | TBD           | Analog config<br>If no analog, NC                                                                                                                                                                                                                                    |

**Table 12-324. PSC Interface**

| Signal            | Direction | Default Value | Description                                 |
|-------------------|-----------|---------------|---------------------------------------------|
| pwri_clkstop_idle | Out       | 1'd1          | The IP is in IDLE state, output of<br>an IP |
| pwrs_clkstop_req  | In        | 1'd0          | Clock stop request                          |
| pwrs_clkstop_ack  | Out       | 1'd0          | Clock stop acknowledge                      |

**Table 12-324. PSC Interface (continued)**

| Signal              | Direction | Default Value  | Description                                                                |
|---------------------|-----------|----------------|----------------------------------------------------------------------------|
| pwrw_clkstop_wakeup | Out       | 1'd0           | Wakeup<br>It requires clock stop protocol to be active and active vclk_clk |
| pwr_clk_clk_en      | In        | 1'd1           | Clock-gate enable to IP                                                    |
| pwr_clk_clk_en_ack  | Out       | pwr_clk_clk_en | Clock-gate enable acknowledge from IP                                      |

Table 12-325 describes the Main IP DFT Interface.

**Table 12-325. IP DFT Interface**

| Signal Name          | Direction | Default Value | Description                   |
|----------------------|-----------|---------------|-------------------------------|
| dft_partition_en     | In        | 1'd0          | dft_partition_en              |
| dft_scan_en          | In        | 1'd0          | dft_scan_en                   |
| dft_clk_force_en     | In        | 1'd0          | dft_clk_force_en              |
| dft_async_rst_sel    | In        | 1'd0          | dft_async_rst_sel             |
| dft_test_async_rst_n | In        | 1'd1          | dft_test_async_rst_n          |
| dft_tft_mcp_dis      | In        | 1'd0          | Assert High to block MCP path |
| dft_local_clk_en     | In        | 1'd0          | dft_local_clk_en              |
| dft_mode_atpg        | In        | 1'd0          | ATPG                          |

The reset shown in Table 12-326 only goes to the core domain.

**Table 12-326. Reset Interface**

| Signal Name     | Direction | Default Value | Description             |
|-----------------|-----------|---------------|-------------------------|
| rst_mod_g_rst_n | In        | 1'd1          | Module level main reset |

The clock shown in Table 12-327 is used for all VBUS ports ref pll clock.

**Table 12-327. VBUS Clock Interface**

| Signal Name         | Direction | Default Value | Description                           |
|---------------------|-----------|---------------|---------------------------------------|
| vclk_clk            | In        | 1'd0          | Single ended clock<br>Nom freq 50MHz  |
| vclk_cs_func_clk_en | In        | 1'd0          | catscan enable on<br>kp_ti_ipg_clk_l1 |

The clock shown in Table 12-328 is a buffered copy from the crystal oscillator clock.

**Table 12-328. OSC 32768Hz Clock Interface**

| Signal Name | Direction | Default Value | Description                               |
|-------------|-----------|---------------|-------------------------------------------|
| osc_32k_clk | Out       | 1'd0          | Buffered clock out from<br>ana_osc32k_clk |

The clock shown in Table 12-329 is for the core domain in DFT mode.

**Table 12-329. DFT Clock Interface**

| Signal Name | Direction | Default Value | Description        |
|-------------|-----------|---------------|--------------------|
| dftclk_clk  | In        | 1'd0          | Single ended clock |

Table 12-330 describes the RTC Level Event OFF\_ON and/or ON\_OFF.

**Table 12-330. RTC Level Event**

| Signal Name         | Direction | Default Value | Description                                                                                                                                                                               |
|---------------------|-----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rtc_event_pend_intr | Out       | 1'd0          | Interrupt signal active high level<br>It has no dependency vclk_clk<br>and clock stop protocol<br>SOC will use it for wakeup vs<br>the wakeup pin which has stop<br>protocol requirements |

Table 12-331 describes the RTC pulse event OFF\_ON and/or ON\_OFF.

**Table 12-331. RTC Pulse Event**

| Signal Name        | Direction | Default Value | Description                        |
|--------------------|-----------|---------------|------------------------------------|
| rtc_event_req_intr | Out       | 1'd0          | Interrupt signal active high pulse |

Table 12-332 describes the Main on only VBUSP target port

**Table 12-332. VBUSP Target Port**

| Signal Name           | Direction | Default Value | Description               |
|-----------------------|-----------|---------------|---------------------------|
| pr1_slv_req           | In        | 1'b0          | Request                   |
| pr1_slv_dir           | In        | 1'b0          | Direction                 |
| pr1_slv_address[31:0] | In        | 32'd0         | Address                   |
| pr1_slv_xcnt[2:0]     | In        | 3'd4          | Good Byte Count           |
| pr1_slv_byten[3:0]    | In        | {4{1'b1}}     | Byte Enables              |
| pr1_slv_wdata[31:0]   | In        | 32'd0         | Write Data                |
| pr1_slv_wready        | Out       | 1'b1          | Write Ready               |
| pr1_slv_rdatap[31:0]  | Out       | 32'd0         | Read Data (Pipelined)     |
| pr1_slv_rready        | Out       | 1'b1          | Read Ready                |
| pr1_slv_emudbg        | In        | 1'b0          | Emulation Debug Attribute |

### 12.7.3.3 RTC Functional Description

#### 12.7.3.3.1 RTC Block Diagram



**Figure 12-418. RTC Block Diagram**

The RTC is composed of 3 major blocks, DIG\_CORE, DIG\_ON, and LVL\_ISO.

#### 12.7.3.3.1.1 DIG\_CORE uARCH

The DIG\_CORE block is on the CORE power domain which will power OFF/ON when the SOC powers OFF/ON. It contains, CORE IF logic, Shadow MMRs and MMR Sync logic.

The MMR Sync logic has 2 modes of operation

- Refresh/Sync after Core Reset
- Sync after HOST PROCESSOR Updates Shadow MMRs

#### Refresh/Sync after Core Reset Deassertion

After every Core Reset event, the MMR Sync logic we refresh ALL Shadow MMRs by copying the contents of ON MMRs into the Shadow MMRs.

#### Core Reset DeAssertion

The internal state machine Reads All MMRs in linear order

- If(GENRAL\_CTL..32K\_CLK\_EN = 1)

- Max delay of 2 32768Hz period delay
- If(GENRAL\_CTL..32K\_CLK\_EN = 0)
  - Max delay 1.2uS = 32 \* vbus\_clk period delay(27MHz)
  - It will not wait for high to low 32768 event to read MMRs

The internal state machine Sets SYNCPEND.RD\_DONE bit when the copy from the ON domain is completed. The host processor needs to wait for this status bit assertion before it reads the other MMRs

### Sync after HOST PROCESSOR Updates Shadow MMRs

host processor UNLOCK

host processor Wrts to MMRs

The ON domain MMRs will get updated after a finite delay

- If(GENRAL\_CTL..32K\_CLK\_EN = 1)
  - Max delay of 2 32768Hz period delay
- If(GENRAL\_CTL..32K\_CLK\_EN = 0)
  - Max delay 8uS = 32 \* vbus\_clk period delay
  - It will not wait for high to low 32768 event to read MMRs

The internal state machine sets SYNCPEND.WR\_DONE bit. This needs to get cleared before the next **HOST PROCESSOR Updates Shadow MMRs**

---

#### Note

The CORE domain has its own copy of the sub-second counter and second counter along with the compensation logic. The 2 domains will always be in sync after a reset or after host processor does a update to the counters or compensation

#### 12.7.3.3.1.2 DIG\_ON uARCH

The DIG\_ON block is in the always ON domain, the power is provided by the ANALOG Block. It contains the always ON MMRs which will preserve state of the Shadow MMRs when the CORE is OFF state.

The 15 bit 32786Hz counter and the 48 bit second counter maintains count when the CORE is OFF. It has 2 comparators one for OFF\_ON and one for ON\_OFF event. It has External Wakeup events which can get de-bounced to control the PMIC\_ENABLE. It controls the PMIC\_ENABLE output which can change state based on ON\_OFF, OFF\_ON, and HOST PROCESSOR OFF now events.

The functional lockout and the dft lockout (1500) logic resides in this domain.

#### 12.7.3.3.1.3 ISO\_LVL uARCH

The ISO\_LVL module constrains all DIG\_CORE <-> DIG\_ON Level/Isolation cells between these 2 domains. They use tibox to instantiate them. If No Analog support, then SOC integration team will not add in these RTC.

#### 12.7.3.3.1.4 DIG\_CORE to DIG\_ON updates uARCH

---

#### Note

If No Analog support, then DIG\_CORE and DIG\_ON will be on a common V domain.

This section defines how the DIG\_CORE Shadow MMRs maintain coherences with the DIG\_ON Live MMR domain. All vbusp transactions terminate in the DIG\_CORE block. All vbusp write transaction which require DIG\_ON updates is completed by the Shadow to Live HW sequencer.

This HW sequencer has 2 modes of operation.

- Immediate Write Mode
  - When GENRAL\_CTL.32K\_OSC\_DEP\_EN = 0
  - It will start the write updates immediately

- Delayed Write Mode
  - When GENRAL\_CTL.32K\_OSC\_DEP\_EN = 1
  - It will start the write updates after the first 32khz\_clk high to low transition

In Delayed Write Mode

For example, HOST PROCESSOR updates OFF\_ON\_S\_CNT\_LSW and OFF\_ON\_S\_CNT\_MSW.

After the HOST PROCESSOR completes the OFF\_ON\_S\_CNT\_MSW, the HW sequencer will start the process of updating the DIG\_ON domain at the first available 32khz\_clk is low cycle.

---

**Note**

32khz\_clk is already low, the circuit will wait next low cycle to insure we have the full low period to do all pending updates. The HOST PROCESSOR can observe the SYNCPEND.WR\_DONE bit, when set the write operations has completed to the DIG\_ON domain

---

---

**Note**

If GENRAL\_CTL..32K\_CLK\_EN = 0, then the HW sequencer will not wait for 32khz\_clk high to low event, since this will force 32khz\_clk low. This removes the dependency of an active 32768Hz clock

---

ALL MMR write transaction require full 4 Bytes writes in order to reduce the logic size of the DIG\_ON domain.

**RULE:** Require 4 Bytes writes (less logic and iso)

---

**Note**

ON domain MMRs have a write lock protection circuit to prevent corruption of the DIG\_ON domain during a power down event since ISO assertion can be late.

---

Due to this fact, the HOST PROCESSOR must first unlock write access by performing the unlock sequence, by simply writing Kick0 and Kick1 with the correct pattern and sequence. After this is done, the RTC is in an unlock state. The HOST PROCESSOR will need to relocking by writing any pattern to Kick1

### **12.7.3.3.2 CPU Interrupt Support**

#### **12.7.3.3.2.1 CPU Interrupts**

The RTC can produce one HW event output active high level and active high pulse. This one output will assert on 3 internal HW events.

1. Timer ON\_OFF event
2. Timer OFF\_ON event
3. External Wakeup event

HOST PROCESSOR can read the Interrupt MMR status to determine which events caused the RTC event output to assert. vbus\_clk can be on or off, the active high level will assert on either scenario. The 32768Hz clock must be active to cause a ON\_OFF or OFF\_ON event. The External Wakeup event can occur without 32768Hz clock if debounce is not enabled.

The Interrupt MMR programing model uses the standard Keystone3 schema which allows HOST PROCESSOR to issue debug event. Also, the enabling of the events are backed up in the ON domain, so HOST PROCESSOR will not enable to enable events on every power cycle of the CORE domain.

### **12.7.3.3.3 Programming Usage Guide**

#### **12.7.3.3.3.1 No Analog Support**

#### **DIG\_ON domain MMR Write Rules**

- UnLock DIG\_CORE (Wrt Kick0 and Wrt Kick1)

- Keep it UnLock
- Write all MMRs in the same address order has MMRs from low to high
  - For example . Wrt Scratch Storage 0 through Scratch Storage 7
- HOST PROCESSOR poles until SYNCPEND.WR\_PEND is 0
  - Max completion is 60 uSeconds when GENRAL\_CTL. 32K\_OSC\_DEP\_EN is set
  - Max completion is 10 uSeconds when GENRAL\_CTL. 32K\_OSC\_DEP\_EN is clr
- HOST PROCESSOR is not allowed to perform new write without waiting for clearing of SYNCPEND.WR\_PEND

#### **After every new power up of the SOC**

- Unlock RTC by writing correct pattern in Kick0 and Kick1
- Keep it UnLock
- HOST PROCESSOR can verify that 32Khz\_osc\_clk is toggling by reading SYNCPEND. 32K\_CLK\_OBS
- Should not be required, since the 32Khz\_osc\_clk will always will be active
- HOST PROCESSOR sets GENRAL\_CTL.32K\_OSC\_DEP\_EN
- Wait for 60 uSec
- Initialize ALL RTC MMRs in the DIG\_ON domain in the same order as the address map
- The RTCs MMRs do not have a reset state in general, only a few required MMRs bits have one.
- HOST PROCESSOR must initialize all bits of the MMRs which reside in DIG\_ON domain
  - Ie wrt <value>@0x00, <value>@0x04, <value>@0x08 ....<value>@0x50
- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null
  - This means all DIG\_ON domain MMRs have been written to

RTC is now in an operational state and fully configured.

#### **32768 MHz time adjustment**

- HOST PROCESSOR UnLock RTC(required for writes to DIG\_ON domain)
- HOST PROCESSOR can readSUB\_S\_CNT(1st), S\_CNT\_LSW(2nd), S\_CNT\_MSW(3rd)
- HOST PROCESSOR can write new time by writing to SUB\_S\_CNT(1st), S\_CNT\_LSW(2nd), S\_CNT\_MSW(3rd)
- HOST PROCESSOR ReLock RTC(writing 0x0000\_0000 to KICK1)
- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null

#### **32768 MHz time drift adjustment**

- HOST PROCESSOR UnLocks RTC(required for writes to DIG\_ON domain)
- HOST PROCESSOR can readSUB\_S\_CNT(1st), S\_CNT\_LSW(2nd), S\_CNT\_MSW(3rd)
- SW determines drift rate
- HOST PROCESSOR updates or enables drift adjustment by HOST PROCESSOR write new COMP\_LSB and COMP\_MSB
- HOST PROCESSOR ReLock RTC(writing 0x0000\_0000 to KICK1)
- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null

#### **12.7.3.3.3.2 With Analog Support**

##### **DIG\_ON domain MMR Write Rules**

- UnLock DIG\_CORE (Wrt Kick0 and Wrt Kick1)
- Write all MMRs in the same address order has MMRs from low to high
- For example . Wrt Scratch Storage 0 through Scratch Storage 7
- ReLock DIG\_CORE (Wrt 0x0000\_0000 to Kick1)
- HOST PROCESSOR poles until SYNCPEND.WR\_PEND is 0
  - Max completion is 60 uSeconds when GENRAL\_CTL. 32K\_OSC\_DEP\_EN is set
  - Max completion is 10 uSeconds when GENRAL\_CTL. 32K\_OSC\_DEP\_EN is clr
- HOST PROCESSOR is not allowed to perform new write without waiting for clearing of SYNCPEND.WR\_PEND

#### **First Time Powered ON(DIG\_ON)**

- Unlock RTC by writing correct pattern in Kick0 and Kick1
- HOST PROCESSOR updates ANALOG\_CTRL MMR
  - Set the correct parameters
  - Enable 32768Hz OSC
  - Wait for 3 seconds to allow the 32768Hz OSC to lock
- HOST PROCESSOR can verify that 32Khz\_osc\_clk is toggling by reading SYNCPEND.32K\_CLK\_OBS
- HOST PROCESSOR sets GENRAL\_CTL.32K\_OSC\_DEP\_EN
- HOST PROCESSOR ReLock DIG\_CORE (Wrt 0x0000\_0000 to Kick1)

Initialize ALL RTC MMRs in the DIG\_ON domain in the same order as the address map except for the first 2 writes which should always be to the 2 KICK0/KICK1 MMRs to unlock write transaction and the last write which should relock by writing 0x0 to KICK1

- The RTCs MMRs do not have a reset state in general, only a few required MMRs bits have one.
- HOST PROCESSOR must initialize all bits of the MMRs which reside in DIG\_ON domain
- HOST PROCESSOR UnLock
- le wrt <value>@0x00, <value>@0x04, <value>@0x08 ....<value>@0x50
- HOST PROCESSOR ReLock RTC(writing 0x0000\_0000 to KICK1)
- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null
- This means all DIG\_ON domain MMRs have been written to

RTC is now in an operational state and fully configured

### 32768 MHz time adjustment

- HOST PROCESSOR UnLock RTC(required for writes to DIG\_ON domain)
- HOST PROCESSOR can readSUB\_S\_CNT(1st), S\_CNT\_LSW(2nd), S\_CNT\_MSW(3rd)
- HOST PROCESSOR can write new time by writing to SUB\_S\_CNT(1st), S\_CNT\_LSW(2nd), S\_CNT\_MSW(3rd)
- HOST PROCESSOR ReLock RTC(writing 0x0000\_0000 to KICK1)
- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null

### 32768 MHz time drift adjustment

- HOST PROCESSOR UnLocks RTC(required for writes to DIG\_ON domain)
- HOST PROCESSOR can readSUB\_S\_CNT(1st), S\_CNT\_LSW(2nd), S\_CNT\_MSW(3rd)
- SW determines drift rate
- HOST PROCESSOR updates or enables drift adjustment by
  - HOST PROCESSOR write new COMP\_LSB and COMP\_MSB
- HOST PROCESSOR ReLock RTC(writing 0x0000\_0000 to KICK1)
- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null

### Update OFF\_ON and/or ON\_OFF times

- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null (ACTION PRE vs POST)
- HOST PROCESSOR UnLocks RTC(required for writes to DIG\_ON domain)
- HOST PROCESSOR update OFF\_ON\_S\_CNT\_LSW/MSW and/or ON\_FF\_S\_CNT\_LSW/MSW
- HOST PROCESSOR can update SCRATCH0/7
- HOST PROCESSOR update GENRAL\_CTL to enable if required
- HOST PROCESSOR ReLock RTC(writing 0x0000\_0000 to KICK1)
- HOST PROCESSOR poll SYNCPEND.WR\_PEND until null

---

#### Note

The new OFF time must be at least 2 seconds in the future

---

### OFF NOW

- HOST PROCESSOR UnLocks RTC(required for writes to DIG\_ON domain)
- Optional (HOST PROCESSOR can update SCRATCH0/7)

- HOST PROCESSOR issues a SW\_OFF in GENRAL\_CTL
- HOST PROCESSOR does a dead loop, wait for power OFF

**Note**

Note any Write to SW\_OFF will cause a Auto ReLock

#### 12.7.3.3.3.2.1 MMR Spurious WRT Protection

The module also contains a kicker mechanism (Figure 12-419) to prevent any spurious writes from changing the register values. This mechanism requires two MMR writes to the Kick0 and Kick1 registers with exact data values before the kicker lock mechanism is released. Once released, the MMRs are writeable. The Kick0 data is 83E7 0B13h; the Kick1 data is 95A4 F1E0h. Note that it remains in an unlocked state until an OCP reset or invalid data pattern is written to one of the Kick0 or Kick1 registers.



- Key0 = 83E7 0B13h
- Key1 = 95A4 F1E0h
- Locked = Write protection enabled
- Unlocked = Write protection disabled

**Figure 12-419. Kick Register State Machine Diagram**

- S0 is the Reset/Idle state
- S1 is an wrt cycle of 83E7 0B13h at Kick0 completed state
- S2 is the UNLOCK MMR WRT state
- S0 → S1 when wrt cycle of 83E7 0B13h at Kick0
- S1 → S2 when wrt cycle of 95A4 F1E0h at Kick1
- S1 → S0 when reset event
- S2 → S0 when reset event OR OCP wrt cycle of NOT 83E7 0B13h at Kick0 OR OCP wrt cycle at Kick1
- S2 → S1 when wrt cycle of 83E7 0B13h at Kick0

#### 12.7.3.3.3.2.2 Crystal Compensation

In order to compensate for any inaccuracy of the 32768HZ oscillator, the HOST can perform a calibration of the oscillator frequency, calculate the drift compensation versus one-hour period and load the compensation registers with the drift compensation value. If the COMP\_REG value is positive, compensation occurs after the second change event. COMP\_REG cycles are removed from the next second. If the COMP\_REG value is negative, compensation occurs before the second change event. -COMP\_REG cycles are added to the current second. This enables to compensate with a 132 kHz period accuracy each 4096 Seconds. The waveform below summarizes positive and negative compensation effect.



**Figure 12-420. Compensation Illustration**

#### 12.7.3.3.4 Scratch Registers

The RTC provides eight general-purpose registers (SCRATCHx\_REG) that can be used to store 32-bit words -- these registers have no functional purpose for the RTC. Software using the RTC may find the SCRATCHx registers to be useful in indicating RTC states. For example, the SCRATCHx\_REG registers may be used to indicate write-protection lock status or unintentional power downs. To indicate write-protection, the software

should write a unique value to one of the SCRATCHx\_REG registers when write-protection is disabled and another unique value when write-protection is enabled again. In this way, the lock-status of the registers can be determined quickly by reading the SCRATCH register. To indicate unintentional power downs, the software should write a unique value to one of the SCRATCHx\_REG registers when RTC is configured and enabled. If the RTC is unintentionally powered down, the value written to the SCRATCH register is cleared. For more information, see *RTCSS Registers*.

#### 12.7.3.3.5 KS3 Clock Stop Protocol

The IP is complaint to KS3 Clock Stop Protocol, please refer to its spec.

For this IP

- `pwri_clkstop_idle` = !( RD\_PEND or WR\_PEND or EVENT\_OFF\_ON or EVENT\_ON\_OFF )
- If any of these MMRs are set, `pwri_clkstop_idle` = 0 or busy
- `pwrs_clkstop_ack` will not assert per spec unless `pwrs_clkstop_req` == 1 and `pwri_clkstop_idle` == 1
- `pwrw_clkstop_wakeup` will not assert unless `pwrs_clkstop_ack` == 1 AND `vclk_clk` is active

It will assert `rtc_event_pend_intr` asserts

- The integration guideline is to always use `rtc_event_pend_intr` for wakeup event since it has NO dependencies on clock stop protocol nor active `vclk_clk` is required, just `32k_clk` needs to be active

## 12.7.4 Timers

This section describes the Timer modules for the device.

### 12.7.4.1 Timers Overview

All timers include specific functions to generate accurate tick interrupts to the operating system.

Each timer can be clocked from several different independent clocks. The selection of clock source is made from registers in the MCU\_CTRL\_MMR0/CTRL\_MMR0.

In the MCU domain the device provides 4 timer pins, one for each instance, to be used as MCU Timer Capture inputs or as MCU Timer PWM outputs.

In the MAIN domain the device provides 11 timer pins, one for each instance, to be used as Timer Capture inputs or as Timer PWM outputs.

Each odd numbered timer instance from each of the domains may be optionally cascaded with the previous even numbered timer instance from the same domain to form up to a 64-bit timer. For example, TIMER1 may be cascaded to TIMER0, MCU\_TIMER1 may be cascaded to MCU\_TIMER0, etc.

When cascaded, TIMERi acts as a 32-bit prescaler to TIMERi+1, as well as MCU\_TIMERn acts as a 32-bit prescaler to MCU\_TIMERn+1. TIMERi / MCU\_TIMERn must be configured to generate a PWM output edge at the desired rate to increment the TIMERi+1/ MCU\_TIMERn+1 counter.

Figure 12-421 is an overview of the timers.



m = even instances of MCU Timer.

$x$  = even instances of Timer.

### Note

$n$  = odd instances of MCU Timer.

---

### Note

$v$  = odd instances of Timer.

### Figure 12-421. Timers Overview

#### 12.7.4.1.1 Timers Features

The following are the main features of the timer controllers:

- Target interface supports:
  - 32-bit data bus width
  - 32-bit access supported
  - 10-bit address bus width
  - Write nonposted transaction mode supported
- Interrupts generated on overflow, compare, and capture
- Free-running 32-bit upward counter
- Compare and capture modes
- Autoreload mode
- Start/stop mode
- Programmable divider clock source ( $2^n$ , where  $n = [0-8]$ )
- Dedicated input trigger for capture mode and dedicated output trigger/PWM signal
- On-the-fly read/write register (while counting)
- Generates a 1-ms tick clock with a 32.768 kHz functional clock sourced from the LFOSC

#### 12.7.4.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### 12.7.4.2 Timers Environment

The MCU\_TIMER[3-0] and TIMER[11-0] modules are hereinafter referred to as timer module.

This section describes the timers external connections (environment).

##### 12.7.4.2.1 Timer External System Interface

Each timer can send or receive stimulus to/from the external (off-chip) system. In the device all timers are configured to output a PWM pulse or receive an external event signal used as a trigger to capture the current timer count.

Figure 12-422 shows the external system interface for the timers, and Table 12-333 describes the timer inputs and outputs.



##### Note

i represents a TIMER instance. See the device datasheet for available domains and TIMER instances.

**Figure 12-422. Timers External System Interface**

**Table 12-333. Timer I/O Signals**

| Module Pin                      | Device Level Signal                    | I/O <sup>(1)</sup> | Description                                | Module Pin<br>Reset Value <sup>(2)</sup> |
|---------------------------------|----------------------------------------|--------------------|--------------------------------------------|------------------------------------------|
| <b>MCU_TIMERi<sup>(2)</sup></b> |                                        |                    |                                            |                                          |
| MCU_TIMER_Io_i <sup>(2)</sup>   | MCU_TIMERi <sup>(2)</sup> _PIEVENTCAPT | I/O                | MCU_TIMERi <sup>(2)</sup> trigger input or | 0                                        |
|                                 | MCU_TIMERi <sup>(2)</sup> _POTIMERPWM  |                    | MCU_TIMERi <sup>(2)</sup> output           |                                          |
| <b>TIMERi<sup>(2)</sup></b>     |                                        |                    |                                            |                                          |
| TIMER_Io_i <sup>(2)</sup>       | TIMERi <sup>(2)</sup> _PIEVENTCAPT     | I/O                | TIMERi <sup>(2)</sup> trigger input or     | 0                                        |
|                                 | TIMERi <sup>(2)</sup> _POTIMERPWM      |                    | TIMERi <sup>(2)</sup> PWM output           |                                          |

(1) When configured for that function; I = Input, O = Output

(2) i represents a TIMER instance. See the device datasheet for available domains and TIMER instances.

##### Note

Each MCU\_TIMER\_PO\_GPOCFG and TIMER\_PO\_GPOCFG signals are used as an output enable to control the function of the MCU\_TIMER\_IO[3-0], and respectively TIMER\_IO[11-0], as the PWM output (PO\_GPOCFG = 0) or capture input (PO\_GPOCFG = 1).

---

**Note**

For more information about device level signals (pull-up/down resistors, buffer type, and others), see tables *Pin Attributes* in the device-specific Datasheet.

---

**12.7.4.3 Integration**

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.7.4.4 Timers Functional Description

Each timer contains a free-running upward counter with autoreload capability on overflow. The timer counter can be read and written on-the-fly (while counting). Each timer includes compare logic to allow an interrupt event on a programmable counter matching value. A dedicated output signal can be pulsed or toggled on either an overflow or a match event. This offers time-stamp trigger signaling or PWM signal sources. A dedicated input signal can be used to trigger an automatic timer counter capture or an interrupt event on a programmable input signal transition. A programmable clock divider (prescaler) allows reduction of the timer input clock frequency. All internal timer interrupt sources are merged into one module interrupt line and one wake-up line.

Each internal interrupt source can be independently enabled and disabled by a dedicated bit in the TIMER\_IRQSTATUS\_SET and TIMER\_IRQSTATUS\_CLR register for the interrupt features, and a dedicated bit of the TIMER\_IRQWAKEEN register for a wake-up. In addition, timers have a mechanism implemented to generate an accurate tick interrupt.

For each timer implemented in the device, there are two possible clock sources:

- 32-kHz clock (sourced from the LFOSC)
- System clock

For more information of the selection of the input clock source, see *Clocking*.

Each timer supports three functional modes:

- Timer mode
- Capture mode
- Compare mode

The capture and compare modes are disabled by default after core reset.

##### 12.7.4.4.1 Timer Block Diagram

Figure 12-423 is a block diagram of the timers.



**Figure 12-423. Timer Block Diagram**

#### 12.7.4.4.2 Timer Power Management

##### Note

Some of the timers features described in this section may not be supported on this family of devices. For more information, see *Module Integration* for specifics..

The way the timer acknowledges the LPSC clock stop request is configurable through the TIMER\_TIOCP\_CFG[3-2] IDLEMODE bit field.

Table 12-334 lists the IDLEMODE settings and the related acknowledgment modes.

**Table 12-334. IDLEMODE Settings**

| IDLEMODE Value | Selected Mode | Description                                                                                                                                                                                                                  |
|----------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00             | Force-idle    | The clock stop request is unconditionally acknowledged from the timer, regardless of its internal operations. This mode must be used carefully, because it does not prevent the loss of data when the clock is switched off. |

Table 12-334. IDLEMODE Settings (continued)

| IDLEMODE Value | Selected Mode    | Description                                                                                                                                                                                                                                                            |
|----------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 01             | No-idle          | The clock stop request is never acknowledged from the timer. This mode is safe from a module point of view but is not efficient from a power-saving perspective because the clocks remain active.                                                                      |
| 10             | Smart-idle       | The timer acknowledges the clock stop request, basing its decision on its internal activity. The acknowledge signal is asserted only when all pending transactions and interrupt requests are treated. This is the best approach to efficient system power management. |
| 11             | Smart-idleWakeup | The module behaves like in Smart-idle mode, with the exception, that it can issue a wake-up request in sleep mode, if the functional clock is not cut off.                                                                                                             |

#### 12.7.4.4.2.1 Wake-Up Capability

##### Note

Some of the timers features described in this section may not be supported on this family of devices.

For more information, see *Timers Not Supported Features*.

If the TIMER\_TIOCP\_CFG[3-2] IDLEMODE bit field sets the smart-idle mode or smart-idle with wake-up mode, the timer evaluates its internal capability to have the interface clock switched off. When there is no further internal activity (no pending interrupt sources: match, overflow, or timer capture events), the clock stop acknowledge signal is asserted and the timer enters sleep mode, ready to issue a wake-up request if configured in smart-idle with wake-up mode.

Figure 12-424 shows the wake-up request generation.



timers-006

Figure 12-424. Wake-Up Request Generation

The timer wake-up-enable register allows masking of the expected source of the wake-up event that generates a wake-up request. The register is synchronously programmed with the interface clock before the Clock magagemet sends a clock stop request. The expected source of the wake-up event is an overflow (TIMER\_TCRR), a timer match (the compare result of TIMER\_TCRR and TIMER\_TMAR matches the counter value), and a timer capture (detection of an external pulse transition of the correct polarity on the TIMER\_PIEVENTCAPT).

When the wake-up event is issued, the associated interrupt status bit is set in the timer status register (TIMER\_IRQSTATUS). The pending wake-up event is reset when the set status bit is overwritten with 1.

---

**Note**

The status bit must be reset to re-enter idle mode.

---

#### 12.7.4.4.3 Timer Software Reset

TIMER\_TIOCP\_CFG[0] SOFTRESET bit can initiate a software reset of the timer. This bit is autocleared to 0 when the reset is complete.

Before accessing or using the timer, the local host must ensure that internal reset is released by reading the TIMER\_TIOCP\_CFG[0] SOFTRESET bit. This bit monitors the internal reset status.

#### 12.7.4.4.4 Timer Interrupts

The timer can issue an overflow interrupt, a timer match interrupt, and a timer capture interrupt. Each internal interrupt source can be independently enabled and disabled in the interrupt-enable register (TIMER\_IRQSTATUS\_SET) and disabled in the interrupt-disable register (TIMER\_IRQSTATUS\_CLR). When the interrupt event is issued, the associated interrupt status bit is set in the timer status register (TIMER\_IRQSTATUS).

#### 12.7.4.4.5 Timer Mode Functionality

The timer is an upward counter that can be started and stopped at any time through the timer control register (the TIMER\_TCLR[0] ST bit). The timer counter register (TIMER\_TCRR) can be loaded when stopped or on-the-fly (while counting). TIMER\_TCRR can be loaded directly by a TIMER\_TCRR write access with a new timer value. TIMER\_TCRR can also be loaded with the value held in the timer load register (TIMER\_TLDR) by a trigger register (TIMER\_TTGR) write access. The loading of TIMER\_TCRR is done regardless of the written value of TIMER\_TTGR. The value of TIMER\_TCRR can be read when stopped or captured on-the-fly by a TIMER\_TCRR read access. The timer is stopped and the counter value is set to 0 when the module reset is asserted. The timer is maintained at stop after the reset is released.

In one-shot mode (the TIMER\_TCLR[1] AR bit is set to 0), the counter is stopped after counting overflow occurs (the counter value remains at 0).

When the autoreload mode is enabled (the TIMER\_TCLR[1] AR bit is set to 1), TIMER\_TCRR is reloaded with the value of TIMER\_TLDR after a counting overflow occurs.

**CAUTION**

Do not put the overflow value (0xFFFF FFFF) in the TIMER\_TLDR register because it can lead to undesirable results.

An interrupt can be issued on overflow if the overflow interrupt-enable bit is set in the timer interrupt-enable register (the TIMER\_IRQSTATUS\_SET[1] OVF\_EN\_FLAG bit is set to 1). A dedicated output pin (POTIMERPWM) can be programmed in the TIMER\_TCLR[12] PT bit through the TIMER\_TCLR[11-10] (PT and TRG bits) to generate one positive pulse (prescaler duration) or to invert the current value (toggle mode) when an overflow occurs. The TIMER\_TCLR[12] PT bit selects pulse/toggle modulation (the TIMER\_TCLR[11-10] TRG bit field selects trigger mode).

Figure 12-425 shows the TIMER\_TCRR timing value.



timers-008

Figure 12-425. TIMER\_TCRR Timing Value

#### 12.7.4.4.5.1 1-ms Tick Generation

The interrupt period is not exactly 1 ms, because the timer input clock is 32.768 kHz. If the clock counts up to 32, it obtains a 0.977-ms period; if it counts up to 33, it obtains a 1.007-ms period. For large granularity, the error is cumulative and can generate important deviations from the standard value.

To minimize the error between a true 1-ms tick and the tick generated by the 32.768-kHz timer, the sequencing of periods less than 1 ms and periods greater than 1 ms must be shuffled. An additional 1-ms block is used to correct this error. See [Figure 12-426](#).

---

#### Note

The only available source for a 32.768-kHz clock is the LFOSC. The HFOSC is not capable of generating a true 32.768-kHz frequency.

---

In this implementation, the increment sequencing is automatically managed by the timer to minimize the error. The user must define only the value of the timer positive increment register (the TIMER\_TPIR[31-0] POSITIVE\_INC\_VALUE bit field) and the timer negative increment register (the TIMER\_TNIR[31-0] NEGATIVE\_INC\_VALUE bit field). An automatic adaptation mechanism is used to simplify the programming model.



timers-009

**Figure 12-426. Block Diagram of the 1-ms Tick Module**

The TIMER\_TPIR, TIMER\_TNIR, and TIMER\_TCVR registers and adders Add1, Add2, and Add3 are used to define whether the next value loaded in the timer counter register (the TIMER\_TCRR[31-0] TIMER\_COUNTER bit field) is the value of the TIMER\_TLDR[31-0] LOAD\_VALUE bit field (period less than 1 ms) or the value of TIMER\_TLDR[31-0] LOAD\_VALUE -1 (period greater than 1 ms).

Table 12-335 lists the value loaded in the TIMER\_TCRR according to the sign of the result of Add1, Add2, and Add3.

MSB = 0: Positive value; MSB = 1: Negative value

**Table 12-335. Value Loaded in TIMER\_TCRR to Generate 1-ms Tick**

| Add1 MSB | Add2 MSB | Add3 MSB | Value of TIMER_TCRR Register          |
|----------|----------|----------|---------------------------------------|
| 0        | 0        | 0        | TIMER_TLDR[31-0] LOAD_VALUE bit field |
| 0        | 0        | 1        | TIMER_TLDR[31-0] LOAD_VALUE bit field |
| 0        | 1        | 0        | TIMER_TLDR[31-0] LOAD_VALUE bit field |
| 0        | 1        | 1        | TIMER_TLDR[31-0] LOAD_VALUE -1        |
| 1        | 0        | 0        | N/A                                   |
| 1        | 0        | 1        | N/A                                   |
| 1        | 1        | 0        | TIMER_TLDR[31-0] LOAD_VALUE -1        |
| 1        | 1        | 1        | TIMER_TLDR[31-0] LOAD_VALUE -1        |

The values of the TIMER\_TPIR and TIMER\_TNIR registers are calculated using the following formulas:

- Positive increment value =  $(\text{INTEGER}[F_{\text{clk}} \times T_{\text{tick}}] + 1) \times 1\text{e}6 - (F_{\text{clk}} \times T_{\text{tick}} \times 1\text{e}6)$
- Negative increment value =  $(\text{INTEGER}[F_{\text{clk}} \times T_{\text{tick}}] \times 1\text{e}6) - (F_{\text{clk}} \times T_{\text{tick}} \times 1\text{e}6)$

---

#### Note

$F_{\text{clk}}$  clock frequency (kHz)

$T_{\text{tick}}$  tick period (ms)

---

The timer overflow counter register (TIMER\_TOCR) and the timer overflow wrapping register (TIMER\_TOWR) are used to filter interrupts. When the timer overflows, it increments the 24-bit TIMER\_TOCR. When the values in the 24-bit TIMER\_TOCR match the values in the 24-bit TIMER\_TOWR and the timer overflow is asserted, the TIMER\_TOCR is reset and an interrupt is generated to the TIMER\_IRQSTATUS register.

---

#### Note

TIMER\_TOWR has to be set to requested value. For example, if no interrupt needs to be masked TIMER\_TOWR must be set to 0, if one interrupt needs to be masked TIMER\_TOWR must be set to 1, if two interrupts need to be masked TIMER\_TOWR must be set to 2 and so on.

It is important to have in mind that the case when FFFFFFFF interrupts need to be masked is not possible.

---

With the conversion block in reset state (the positive increment register, negative increment register, and counter value register are zeroed), the programming model and the behavior of timers remain unchanged.

For 1-ms tick with a 32.768-kHz clock:

- TIMER\_TPIR[31-0] POSITIVE\_INC\_VALUE = 232,000
- TIMER\_TNIR[31-0] NEGATIVE\_INC\_VALUE = -768,000
- TIMER\_TLDR[31-0] LOAD\_VALUE = 0xFFFF FFE0

---

#### Note

Any value of the tick period can be generated with the appropriate value of the TIMER\_TPIR, TIMER\_TNIR, and TIMER\_TLDR.

By default, the TIMER\_TPIR, TIMER\_TNIR, TIMER\_TCVR, TIMER\_TOCR, and TIMER\_TOWR and the associated logic are in reset mode (all 0s) and have no effect on the programming model.

---

#### 12.7.4.4.6 Timer Capture Mode Functionality

When a transition is detected on the module input pin (PIEVENTCAPT), the timer value in the TIMER\_TCRR can be captured and saved in the TIMER\_TCAR1 or TIMER\_TCAR2 register function of the mode selected in the TIMER\_TCLR[13] CAPT\_MODE bit. The edge detection circuitry monitors transitions on the input pin (PIEVENTCAPT).

The rising edge, falling edge, or both, can be selected in the TIMER\_TCLR[9-8] TCM bit field to trigger the timer counter capture. The module sets the TIMER\_IRQSTATUS[2] TCAR\_IT\_FLAG bit when an active edge is detected, and at the same time, the counter value TIMER\_TCRR is stored in timer capture register TIMER\_TCAR1 or TIMER\_TCAR2, as follows:

- If the TIMER\_TCLR[13] CAPT\_MODE bit is 0, on the first enabled capture event, the value of the counter register is saved in the TIMER\_TCAR1 register, and the next events are ignored (no update on the TIMER\_TCAR1 register and no interrupt triggering) until the detection logic is reset or the TIMER\_IRQSTATUS[2] TCAR\_IT\_FLAG is cleared by writing 1 to it.
- If the TIMER\_TCLR[13] CAPT\_MODE bit is 1, on the first enabled capture event, the value of the counter register is saved in the TIMER\_TCAR1 register, and on the second enabled capture event, the value of the

counter register is saved in the TIMER\_TCAR2 register. If a capture interrupt is enabled, the interrupt triggers on the second event capture. All other events are ignored (no update on TIMER\_TCAR1/TIMER\_TCAR2 and no interrupt triggering) until the detection logic is reset or the TIMER\_IRQSTATUS[2] TCAR\_IT\_FLAG bit is cleared by writing 1 to it. This mechanism is useful for period calculation of a clock, if that clock is connected to the PIEVENTCAPT input pin.

The edge detection logic is reset (a new capture is enabled) when the active capture interrupt is served. The TIMER\_IRQSTATUS[2] TCAR\_IT\_FLAG bit is cleared by writing 1 to it or when the edge detection mode bits (the TIMER\_TCLR[9-8] TCM bit field) are changed from no-capture mode detection to any other mode. The timer functional clock (input to prescaler) is used to sample the input pin (PIEVENTCAPT). A negative or positive pulse input can be detected when the pulse time is greater than the functional clock period. An interrupt is issued on edge detection if the capture interrupt-enable bit is set in the TIMER\_IRQSTATUS\_SET[2] TCAR\_EN\_FLAG bit. See the examples in [Figure 12-427](#) and [Figure 12-428](#).

In [Figure 12-427](#), the value of the TIMER\_TCLR[9-8] TCM bit field is 1h, and the TIMER\_TCLR[13] CAPT\_MODE bit is 0. Only the rising edge of PIEVENTCAPT triggers a capture in the TIMER\_TCAR1 and TIMER\_TCAR2 registers, and only the TIMER\_TCAR1 register updates.



**Figure 12-427. Capture Wave Example for TIMER\_TCLR[13] CAPT\_MODE = 0**

In [Figure 12-428](#), the value of the TIMER\_TCLR[9-8] TCM bit field is 1h, and the TIMER\_TCLR[13] CAPT\_MODE bit is 1. Only the rising edge of PIEVENTCAPT triggers a capture in the TIMER\_TCAR1 register on the first enabled event, and the TIMER\_TCAR2 register updates on the second enabled event.



Figure 12-428. Capture Wave Example for TIMER\_TCLR[13] CAPT\_MODE = 1

#### 12.7.4.4.7 Timer Compare Mode Functionality

When the compare-enable register TIMER\_TCLR[6] CE bit is set to 1, the timer value (the TIMER\_TCRR[31-0] TIMER\_COUNTER bit field) is continuously compared to the value held in the timer match register (TIMER\_TMAR). The value of the TIMER\_TMAR[31-0] COMPARE\_VALUE bit field can be loaded at any time (timer counting or stopped). When the TIMER\_TCRR and the TIMER\_TMAR values match, an interrupt is issued, if the TIMER\_IRQSTATUS\_SET[0] MAT\_EN\_FLAG bit is set.

To prevent any unwanted interrupts due to reset value matching effect, write a compare value to the TIMER\_TMAR before setting the TIMER\_TCLR[6] CE bit.

The dedicated output pin (POTIMERPWM) can be programmed in the TIMER\_TCLR[12] PT bit through the TIMER\_TCLR[11-10] TRG bit field to generate one positive pulse (timer clock duration) or to invert the current value (toggle mode) when an overflow or a match occurs.

#### 12.7.4.4.8 Timer Prescaler Functionality

A prescaler can be used to divide the timer counter input clock frequency. The prescaler is enabled when the TIMER\_TCLR[5] PRE bit is set. The TIMER\_TCLR[4-2] PTV bit field sets the  $2^n$  division ratio (prescaler value is  $2^{(PTV + 1)}$ ). The prescaler counter is reset when the timer counter is stopped or reloaded on-the-fly.

Table 12-336 lists the prescaler/timer reload values versus contexts.

Table 12-336. Prescaler/Timer Reload Values Versus Contexts

| Context                          | Prescaler | Timer Counter    |
|----------------------------------|-----------|------------------|
| Overflow (when autoreload is on) | Reset     | TIMER_TLDR[31-0] |
| TIMER_TCRR write                 | Reset     | TIMER_TCRR[31-0] |
| TIMER_TTGR write                 | Reset     | TIMER_TLDR[31-0] |
| Stop                             | Reset     | Frozen           |

#### 12.7.4.4.9 Timer Pulse-Width Modulation

The timer can be configured to provide a programmable PWM output. The timer PWM (POTIMERPWM) output pin can be configured to toggle on an event. The TIMER\_TCLR[11-10] TRG bit field determines on which register value the PWM pin toggles. Either overflow or both overflow and match can be selected to toggle the timer PWM pin when a compare condition occurs.

**Note**

In toggle mode, when **TIMER\_TCLR[11-10]** **TRG** = 0x2 (overflow and match), the first event that toggles the PWM line is an overflow event.

The **TIMER\_TCLR[7]** SCPWM bit can be programmed to set or clear the timer PWM output signal only while the counter is stopped or the trigger is off. This allows setting the output pin to a known state before modulation starts. Modulation synchronously stops when the **TIMER\_TCLR[11-10]** **TRG** bit field is cleared and overflow occurs. This allows fixing a deterministic state of the output pin when modulation stops.

In [Figure 12-429](#), the internal overflow pulse is set each time the (0xFFFF FFFF – **TIMER\_TLDR[31-0]** **LOAD\_VALUE** + 1) value is reached, and the internal match pulse is set when the counter reaches the value of **TIMER\_TMAR**. Depending on the value of the **TIMER\_TCLR[12]** **PT** bit and **TIMER\_TCLR[11-10]** **TRG** bit field, the timer provides pulse or PWM event on the output pin (POTIMERPWM).

The **TIMER\_TLDR** and **TIMER\_TMAR** must keep values below the overflow value (0xFFFF FFFF) by at least two units. If the PWM trigger events are both overflow and match, the difference between the values kept in the **TIMER\_TMAR** and the value in the **TIMER\_TLDR** must be at least two units. When match event is used, the compare mode **TIMER\_TCLR[6]** **CE** bit must be set.

In [Figure 12-429](#), the **TIMER\_TCLR[7]** SCPWM bit is set to 0. In [Figure 12-430](#), the **TIMER\_TCLR[7]** SCPWM bit is set to 1. To obtain the desired wave form, start the counter at 0xFFFF FFFE value (to ensure an overflow first) or adjust the line polarity (**TIMER\_TCLR[7]** SCPWM bit).



**Figure 12-429. Timing Diagram of PWM With **TIMER\_TCLR[7]** SCPWM Bit = 0**



Figure 12-430. Timing Diagram of PWM With TIMER\_TCLR[7] SCPWM Bit = 1

#### 12.7.4.4.10 Timer Counting Rate

The timer rate is defined by the following values:

- Value of the prescaler fields (the TIMER\_TCLR[5] PRE bit and TIMER\_TCLR[4-2] PTV bit field)
- Value loaded into the TIMER\_TLDR

Table 12-337 lists the prescaler clock ratio values.

Table 12-337. Prescaler Clock Ratio Values

| TIMER_TCLR[5] PRE | TIMER_TCLR[4-2] PTV | Divisor (PS) |
|-------------------|---------------------|--------------|
| 0                 | X                   | 1            |
| 1                 | 0                   | 2            |
| 1                 | 1                   | 4            |
| 1                 | 2                   | 8            |
| 1                 | 3                   | 16           |
| 1                 | 4                   | 32           |
| 1                 | 5                   | 64           |
| 1                 | 6                   | 128          |
| 1                 | 7                   | 256          |

Thus, the timer overflow rate is expressed as:

$$\text{OVF\_Rate} = (0xFFFF FFFF - \text{TIMER\_TLDR} + 1) \times (\text{timer-functional clock period}) \times \text{PS}$$

With (timer-functional clock period) = 1/(timer-functional clock frequency) and PS =  $2^{(\text{PTV} + 1)}$  if prescaler is enabled, or PS = 1 if prescaler is disabled.

#### CAUTION

Internal resynchronization causes any write to the TIMER\_TCLR[1] ST bit to have some latency before the register is updated:

2.5 × functional clock cycles write\_TIMER\_TCLR\_latency 3.5 × functional clock cycles

Remember to consider this latency whenever the timer must be started or stopped by a software change to the TIMER\_TCLR[1] ST bit.

**CAUTION**

- In non-PWM mode, TIMER\_TLDR must be maintained at less than or equal to 0xFFFF FFFE.
- In PWM mode, TIMER\_TLDR must be maintained at less than or equal to 0xFFFF FFFD.

For example, with a timer clock input of 32 kHz and the TIMER\_TCLR[5] PRE bit set to 0, the timer output period is as listed in [Table 12-338](#).

**Table 12-338. Value and Corresponding Interrupt Period**

| TIMER_TLDR[31-0] LOAD_VALUE | Interrupt Period |
|-----------------------------|------------------|
| 0x0000 0000                 | 37 h             |
| 0xFFFF 0000                 | 2 s              |
| 0xFFFF FFF0                 | 500 $\mu$ s      |
| 0xFFFF FFFE                 | 62.5 $\mu$ s     |

#### 12.7.4.4.11 Timer Under Emulation

During emulation mode, the timer continues to run according to the value of the TIMER\_TIOCP\_CFG[1] EMUFREE bit.

If the TIMER\_TIOCP\_CFG[1] EMUFREE bit is set to 1, timer execution is not stopped in emulation mode and the interrupt is still generated when overflow or match is reached.

If the TIMER\_TIOCP\_CFG[1] EMUFREE bit is set to 0, the prescaler and timer are frozen and both resume on exit from emulation mode. The asynchronous external input pin (MCU\_TIMER\_IO[9-0] or TIMER\_IO[7-0]) is internally synchronized on two timer-clock rising edges.

#### 12.7.4.4.12 Accessing Timer Registers

All accesses are posted mode, under the assumption that freq(timer clock) < freq(interface clock)/4, until software reconfiguration. In addition, it is not recommended to access the timer registers prior to the PLLs generating the timer and interface clocks have been configured and the clocks have stabilized. All registers are 32 bits wide, accessible through the configuration interface with 32-bit access (read/write).

Write operations to the following functional registers must be complete (the MSB must be written even if the MSB data is not used):

- TIMER\_TCLR
- TIMER\_TCRR
- TIMER\_TLDR
- TIMER\_TTGR
- TIMER\_TMAR
- TIMER\_TPIR
- TIMER\_TNIR
- TIMER\_TCVR
- TIMER\_TOCR
- TIMER\_TOWR

The following registers are not affected by the posted/nonposted mode selection; the write/read operation is effective and acknowledged (command accepted) after one interface clock cycle from command assertion:

- TIMER\_TIDR
- TIMER\_TIOCP\_CFG
- TIMER\_IRQSTATUS
- TIMER\_IRQSTATUS\_RAW
- TIMER\_IRQSTATUS\_SET
- TIMER\_IRQSTATUS\_CLR
- TIMER\_IRQWAKEEN
- TIMER\_TWPS

- TIMER\_TSICR

#### 12.7.4.4.12.1 Writing to Timer Registers

The host uses the configuration interface to write to the following registers synchronously with the timer interface clock:

- TIMER\_TLDR
- TIMER\_TCRR
- TIMER\_TCLR
- TIMER\_TIOCP\_CFG
- TIMER\_IRQSTATUS
- TIMER\_IRQSTATUS\_SET
- TIMER\_IRQSTATUS\_CLR
- TIMER\_IRQWAKEEN
- TIMER\_TTGR
- TIMER\_TSICR
- TIMER\_TMAR
- TIMER\_TPIR
- TIMER\_TNIR
- TIMER\_TCVR
- TIMER\_TOCR
- TIMER\_TOWR

##### 12.7.4.4.12.1.1 Write Posting Synchronization Mode

This mode is used if the TIMER\_TSICR[2] POSTED bit is set to 1 (default value).

This mode uses a posted write scheme to update any internal register (TIMER\_TCLR, TIMER\_TCRR, TIMER\_TLDR, TIMER\_TTGR, TIMER\_TMAR, TIMER\_TPIR, TIMER\_TNIR, TIMER\_TCVR, TIMER\_TOCR, and TIMER\_TOWR). Therefore, the write transaction is immediately acknowledged on the configuration interface, although the effective write operation occurs later because of a resynchronization in the timer clock domain. The advantage is that neither the interconnect, nor the device that requested the write transaction is stalled.

For each register, a status bit is provided in the timer write-posted status (TIMER\_TWPS) register. In this mode, it is mandatory that software check this status bit before any write access. If a write is attempted to a register with a previous access pending, the previous access is discarded without notice.

The timer module updates the value of the timer counter register synchronously with the interface clock. Consequently, any read access to TIMER\_TCRR does not add any resynchronization latency; the current value is always available.

---

#### Note

Because the overflow IRQ is generated when the value of TIMER\_TCRR reaches 0xFFFF FFFF, and not when it changes its value to the value after overflow, it is necessary to wait a delay of  $(1 \times PS \times \text{timer functional clock period})$  before any read access to TIMER\_TCRR to ensure a correct reading of its content.

---

#### Note

If TIMER\_TTGR register is written during a posted write to TIMER\_TCRR, the value to be written to TIMER\_TCRR will be discarded.

If a posted write to TIMER\_TCVR is started, the user must not write to TIMER\_TPIR or TIMER\_TNIR before the TIMER\_TCVR write is finished, because the value of TIMER\_TCVR is re-evaluated, so both the value to be written, and the recalculated value will be discarded.

If a write access is pending for a register, reading from this register does not yield a correct result. Software synchronization must be used to avoid incorrect results.

Functional frequency range:  $\text{freq(timer clock)} < \text{freq(interface clock)}/4$ .

#### **12.7.4.4.12.1.2 Write Nonposting Synchronization Mode**

This mode is used if the TIMER\_TSICR[2] POSTED bit is set to 0. It uses a nonposted write scheme to update any internal register. Therefore, the write transaction is not acknowledged on the configuration interface until the effective write operation occurs after the resynchronization in the timer functional clock domain. The drawback is that the interconnect and the device that requested the write transaction are stalled during this period.

The same full resynchronization scheme is used for a read transaction, and the same stall period applies. A register read following a write to the same register is always coherent.

This mode is functional regardless of the ratio between the configuration interface frequency and the timer clock frequency.

#### **12.7.4.4.12.2 Reading From Timer Counter Registers**

---

##### **Note**

LSB/MSB accesses cannot be interleaved (that is, the sequence LSB register 1, LSB register 2, MSB register 1, MSB register 2 is not supported).

---

The TIMER\_TCRR is a 32-bit “atomic datum” and its 16-bit capture is done on the 16-bit LSB first to allow atomic LSB16 + MSB16 capture. This capture scheme is also performed for the TIMER\_TCAR1 and TIMER\_TCAR2 registers as they can be changed due to internal processes too.

#### **12.7.4.4.12.2.1 Read Posted**

This mode is functional regardless of the ratio between the configuration interface frequency and the functional clock frequency. The recommended functional frequency range is  $\text{freq(timer)} < \text{freq(interface clock)}/4$ .

Read posted mode is used if TIMER\_TSICR[2] POSTED = 0x1 or TIMER\_TSICR[3] READ\_MODE is set to 0. This mode uses a posted-read scheme for reading any internal timer register. The read transaction is immediately acknowledged on the configuration interface, prior to the value to be read has been resynchronized. With this method, neither the interconnect nor the device that requested the read transaction are stalled.

Read posted mode applies to TIMER\_TCRR, TIMER\_TCAR1, TIMER\_TCAR2, TIMER\_TCVR, and TIMER\_TOWR, which needs resynchronization from functional to interface clock domains.

Note that in Posted mode, if the TIMER\_TCRR is read immediately after wake-up and the interface clock is off during idle state, then it is possible to get an old value from just before going to idle state due to the fact the interface clock is needed for synchronization.

In order to avoid this situation, another synchronization mechanism is used for the first read operation after idle state. The TIMER\_TSICR[4] READ\_AFTER\_IDLE bit is used to enable/disable the mechanism.

When the synchronization mechanism is disabled (READ\_AFTER\_IDLE bit is set to 1), first read transaction takes only 2 interface clock cycles, but the read value of TIMER\_TCRR could be wrong.

When the synchronization mechanism is enabled (READ\_AFTER\_IDLE bit is set to 0), first read value of TIMER\_TCRR is correct, but the read transaction takes more than 2 interface clock cycles.

#### **12.7.4.4.12.2.2 Read Non-Posted**

This mode is functional regardless of the ratio between the configuration interface frequency and the functional clock frequency. Recommended functional frequency range is  $\text{freq(timer)} \geq \text{freq(interface clock)}/4$ .

Read non-posted mode is used if TIMER\_TSICR[2] POSTED = 0x0 and TIMER\_TSICR[3] READ\_MODE = 0x1. This mode uses a non-posted read scheme for reading internal timer registers. The read transaction is not acknowledged on the configuration interface until the effective read operation occurs, after the resynchronization

in the timer clock domain. The result is that both the interconnect and the device that requested the read transaction are stalled during this period.

This mode applies to TIMER\_TCRR, TIMER\_TCAR1, TIMER\_TCAR2, TIMER\_TCVR, and TIMER\_TOWR, which need resynchronization from functional to interface clock domains.

#### 12.7.4.4.13 Timer Posted Mode Selection

A choice between two synchronization modes is made taking into account the frequency ratio and the stall periods that can be supported by the system, without impacting the global performance.

The posted mode selection applies only to registers that require synchronization on or from the timer clock domain. For write operation, the registers affected by posted and non-posted selection are TIMER\_TCLR, TIMER\_TLDR, TIMER\_TCRR, TIMER\_TTGR, TIMER\_TMAR, TIMER\_TPIR, TIMER\_TNIR, TIMER\_TCVR, TIMER\_TOCR, and TIMER\_TOWR. For read operation, the registers affected by this selection are: TIMER\_TCRR, TIMER\_TCAR1, TIMER\_TCAR2, TIMER\_TCVR, and TIMER\_TOWR.

The interface clock domain synchronous registers TIMER\_TIDR, TIMER\_TIOCP\_CFG, TIMER\_IRQSTATUS, TIMER\_IRQSTATUS\_SET, TIMER\_IRQWAKEEN, TIMER\_TWPS, and TIMER\_TSICR are not affected by posted and non-posted mode selection. The operation (read or write) is effective and acknowledged after one interface clock cycle from the command assertion.

The configuration of posted or non-posted mode can be changed (overwritten) by software by writing in TIMER\_TSICR[2] POSTED bit. The TIMER\_TSICR[3] READ\_MODE defines how the read operation is performed when the module is configured in non-posted mode (see TIMER\_TSICR). The following cases are possible:

- TIMER\_TSICR[2] POSTED = 0x1 and TIMER\_TSICR[3] READ\_MODE = x (don't care): read and write operations are expected in posted mode.
- TIMER\_TSICR[2] POSTED = 0x0 and TIMER\_TSICR[3] READ\_MODE = 0x0: the write operation is executed in non-posted mode and read is executed in posted mode.
- TIMER\_TSICR[2] POSTED = 0x0 and TIMER\_TSICR[3] READ\_MODE = 0x1: write is executed in non-posted mode and read is executed in non-posted mode.

#### 12.7.4.5 Timers Low-Level Programming Models

This section describes the low-level hardware programming sequences for the configuration and use of the module.

##### 12.7.4.5.1 Timer Global Initialization

###### 12.7.4.5.1.1 Main Sequence – Timer Module Global Initialization

Table 12-339 identifies the main steps for initializing the timer module when the module is to be used for the first time.

**Table 12-339. Timer Module Global Initialization**

| Step                             | Register/Bit Field/Programming Model | Value |
|----------------------------------|--------------------------------------|-------|
| Execute software reset.          | TIMER_TIOCP_CFG[0] SOFTRESET         | 0x1   |
| Wait until reset release?        | TIMER_TIOCP_CFG[0] SOFTRESET         | 0x0   |
| Configure idle mode.             | TIMER_TIOCP_CFG[3-2] IDLEMODE        | 0x-   |
| Enable wake-up interrupt events. | TIMER_IRQWAKEEN[2-0]                 | 0x-   |
| Select posted mode.              | TIMER_TSICR[2] POSTED                | 0x-   |

#### 12.7.4.5.2 Timer Operational Mode Configuration

##### 12.7.4.5.2.1 Timer Mode

###### 12.7.4.5.2.1.1 Main Sequence – Timer Mode Configuration

Table 12-340 lists the steps in the timer mode configuration.

**Table 12-340. Timer Mode Configuration**

| Step                       | Register/Bit Field/Programming Model | Value |
|----------------------------|--------------------------------------|-------|
| Select autoreload mode.    | TIMER_TCLR[1] AR                     | 0x-   |
| Set prescale timer value.  | TIMER_TCLR[4-2] PTV                  | 0x-   |
| Enable prescaler.          | TIMER_TCLR[5] PRE                    | 0x1   |
| Enable overflow interrupt. | TIMER_IRQSTATUS_SET[1] OVF_EN_FLAG   | 0x1   |
| Load timer counter value.  | TIMER_TCRR                           | 0x-   |
| Load timer load value.     | TIMER_TLDR                           | 0x-   |
| Start the timer.           | TIMER_TCLR[0] ST                     | 0x1   |

##### 12.7.4.5.2.2 Timer Compare Mode

###### 12.7.4.5.2.2.1 Main Sequence – Timer Compare Mode Configuration

Table 12-341 lists the steps in the timer compare mode configuration.

**Table 12-341. Timer Compare Mode Configuration**

| Step                      | Register/Bit Field/Programming Model | Value |
|---------------------------|--------------------------------------|-------|
| Select autoreload mode.   | TIMER_TCLR[1] AR                     | 0x-   |
| Set prescale timer value. | TIMER_TCLR[4-2] PTV                  | 0x-   |
| Enable prescaler.         | TIMER_TCLR[5] PRE                    | 0x1   |
| Enable match interrupt.   | TIMER_IRQSTATUS_SET[0] MAT_EN_FLAG   | 0x1   |
| Load timer counter value. | TIMER_TCRR                           | 0x-   |
| Load timer compare value. | TIMER_TMAR                           | 0x-   |
| Enable compare mode.      | TIMER_TCLR[6] CE                     | 0x1   |
| Start the timer.          | TIMER_TCLR[0] ST                     | 0x1   |

#### 12.7.4.5.2.3 Timer Capture Mode

##### 12.7.4.5.2.3.1 Main Sequence – Timer Capture Mode Configuration

Table 12-342 lists the steps in the timer capture mode configuration.

**Table 12-342. Timer Capture Mode Configuration**

| Step                      | Register/Bit Field/Programming Model         | Value |
|---------------------------|----------------------------------------------|-------|
| Initialize capture mode.  | See <a href="#">Section 12.7.4.5.2.3.2</a> . |       |
| Enable capture interrupt. | TIMER IRQSTATUS_SET[2] TCAR_EN_FLAG          | 0x1   |
| Start the timer.          | TIMER_TCLR[0] ST                             | 0x1   |
| Detect event.             | See <a href="#">Section 12.7.4.5.2.3.3</a> . |       |

##### 12.7.4.5.2.3.2 Subsequence – Initialize Capture Mode

Table 12-343 lists the steps to initialize capture mode.

**Table 12-343. Initialize Capture Mode**

| Step                                                                                                                                                       | Register/Bit Field/Programming Model | Value |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Select autoreload mode.                                                                                                                                    | TIMER_TCLR[1] AR                     | 0x-   |
| Set prescale timer value.                                                                                                                                  | TIMER_TCLR[4-2] PTV                  | 0x-   |
| Enable prescaler.                                                                                                                                          | TIMER_TCLR[5] PRE                    | 0x1   |
| Select TIMER[11-0] or MCU_TIMER[3-0]<br>Capture input at device pins<br>TIMER_IO[11-0] for TIMER[11-0] or at pins<br>MCU_TIMER_IO[3-0] for MCU_TIMER[3-0]. | TIMER_TCLR[14] GPO_CFG               | 0x1   |
| Select single or second event capture.                                                                                                                     | TIMER_TCLR[13] CAPT_MODE             | 0x-   |
| Select transition capture mode.                                                                                                                            | TIMER_TCLR[9-8] TCM                  | 0x-   |

##### 12.7.4.5.2.3.3 Subsequence – Detect Event

Table 12-344 lists the steps in detecting an event.

**Table 12-344. Detect Event**

| Step                             | Register/Bit Field/Programming Model | Value |
|----------------------------------|--------------------------------------|-------|
| Wait until event detected?       | TIMER IRQSTATUS[2] TCAR_IT_FLAG      | = 0x1 |
| Read timer capture value.        | TIMER_TCAR1 and/or<br>TIMER_TCAR2    |       |
| Clear capture interrupt request. | TIMER IRQSTATUS[2] TCAR_IT_FLAG      | 0x1   |

#### 12.7.4.5.2.4 Timer PWM Mode

##### 12.7.4.5.2.4.1 Main Sequence – Timer PWM Mode Configuration

Table 12-345 lists the steps in the timer PWM mode configuration.

**Table 12-345. Timer PWM Mode Configuration**

| Step                                                                                                                                                    | Register/Bit Field/Programming Model | Value |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------|
| Select autoreload mode.                                                                                                                                 | TIMER_TCLR[1] AR                     | 0x-   |
| Set prescale timer value.                                                                                                                               | TIMER_TCLR[4-2] PTV                  | 0x-   |
| Enable prescaler.                                                                                                                                       | TIMER_TCLR[5] PRE                    | 0x1   |
| Select trigger output mode.                                                                                                                             | TIMER_TCLR[11-10] TRG                | 0x-   |
| Select pulse or toggle modulation PWM mode.                                                                                                             | TIMER_TCLR[12] PT                    | 0x-   |
| Select TIMER[11-0] or MCU_TIMER[3-0]<br>PWM output at device pins<br>TIMER_IO[11-0] for TIMER[11-0] or at pins<br>MCU_TIMER_IO[3-0] for MCU_TIMER[3-0]. | TIMER_TCLR[14] GPO_CFG               | 0x0   |
| Configure PWM output pin default value.                                                                                                                 | TIMER_TCLR[7] SCPWM                  | 0x-   |

**Table 12-345. Timer PWM Mode Configuration (continued)**

| Step                      | Register/Bit Field/Programming Model | Value |
|---------------------------|--------------------------------------|-------|
| Load timer load value.    | TIMER_TLDR                           | 0x-   |
| Load timer compare value. | TIMER_TMAR                           | 0x-   |
| Enable compare.           | TIMER_TCLR[6] CE                     | 0x1   |
| Start the timer.          | TIMER_TCLR[0] ST                     | 0x1   |

## 12.8 Internal Diagnostics Modules

This section describes the internal diagnostics modules in the device.

### 12.8.1 Dual Clock Comparator (DCC)

This section describes the Dual Clock Comparator (DCC) modules in the device.

#### 12.8.1.1 DCC Overview

The Dual Clock Comparator (DCC) is used to determine the accuracy of a clock signal during the time execution of an application. Specifically, the DCC is designed to detect drifts from the expected clock frequency. The desired accuracy can be programmed based on calculation for each application. The DCC measures the frequency of a selectable clock source using another input clock as a reference.

The device has instances of DCC modules.

Figure 12-431 shows the DCC modules overview.



dcc-001

1.  $i = 0$  to number of instances in MCU Domain.

2.  $i = 0$  to number of instances in MAIN Domain.

**Figure 12-431. DCC Modules Overview**

#### **12.8.1.1.1 DCC Features**

The DCC uses two independent clock sources to detect when one is out of specification. Each DCC module implements the following features:

- Two independent counter blocks count clock pulses from each clock source
- Each counter block is programmable, however, for proper operation the counters must be programmed with seed values that respect the ratio of the two clock frequencies
- Configurable timebase for error signal
- Error signal generation when one of the clocks is out of specification
- Clock frequency measurement

#### **12.8.1.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

---

#### **Note**

Some features may not be available. See *Module Integration* for more information.

---

## 12.8.1.2 DCC Functional Description

### 12.8.1.2.1 DCC Counter Operation

---

#### Note

For detailed DCC compute calculations, refer to [Continuous Monitor of the PLL Frequency With the DCC App Note](#).

---

The DCC has two parallel counters that count clock pulses for two independent clock sources:

- Counter0 generates a fixed-width counting window (VALID0) after a pre-programmed number of pulses (COUNT0). The values for VALID0 and COUNT0 can be programmed in DCCVALIDSEED0 and DCCCNTSEED0 registers respectively.
- Counter1 generates a fixed-width pulse (1 cycle) after a pre-programmed number of pulses (COUNT1). This pulse sets an error signal if Counter1 does not reach 0 during the time when VALID0 is running. The seed value for COUNT1 can be programmed in DCCCNTSEED1 register.

The error signal is generated by any one of the following conditions:

- Clock1 expires before the COUNT0 reaches 0.
- Clock1 expires after both COUNT0 and VALID0 reach 0.
- Clock1 not present.
- Clock0 not present.

Any of these errors causes the counters to stop counting. An application must then read out the counter values to determine what caused the error. Once the error is detected, the counters are stopped after 3 FICLK and 2 source clock cycles due to the cross clock domain synchronisation.

Reloads or restarts occur under two conditions:

- The module is reset or restarted through software (that is, software starts the module after reset, or software checks an error condition and decides to restart the module).
- COUNT0, COUNT1, and VALID0 all reach 0 without error.

#### CAUTION

The DCC module does not check jitter for Clock0 or Clock1.

As the counter preset signal is synchronized to either of the source clock domains, the counters begin downcounting after two corresponding source clock cycles.

The error signal is captured to the FICLK domain. There is 1 FICLK period uncertainty on either side of the fixed width counting window (VALID0) in generating the error signal since the counters work in different clock domains. This should be accounted for when setting the count value for VALID0.

Figure 12-432 through Figure 12-436 shows examples of counters relationship and error generation.



**Figure 12-432. DCC Clock0 and Clock1 With no Error**



**Figure 12-433. DCC Clock1 slower than Clock0 results in an error and stops counting**



**Figure 12-434. DCC Clock1 faster than Clock0 results in an error and stops counting**



**Figure 12-435. DCC Clock1 not present results in an error and stops counting**



**Figure 12-436. DCC Clock0 not present results in an error and stops counting**

#### 12.8.1.2.2 DCC Low Power Mode Operation

The DCC module does not function in Low Power Mode. It is the responsibility of software to stop the module before entering low power mode and to restart the module after exiting low power mode.

#### 12.8.1.2.3 DCC Suspend Mode Behavior

The DCC module will continue running regardless of the state of emulation. All registers are readable via emulation reads.

#### 12.8.1.2.4 DCC Single-Shot Mode

The DCC can be programmed to count down one time using single-shot mode. In this mode, the DCC stops operation when both COUNT0 and VALID0 reach 0.

At the end of one sequence in single-shot mode the DCCGCTRL[3-0] DCCENA bitfield is set to disabled, which stops further counting. Single-shot mode is enabled from the DCCGCTRL[11-8] SINGLESHT bitfield.

At the end of one sequence in single-shot mode, if there is no error which stops counting, then the done status bit is set in the DCCSTAT[1] DONEFLG bitfield and a done interrupt DCC\_x\_INT is generated. Software must clear the done bit before restarting the counting.

#### **12.8.1.2.5 DCC Continuous mode**

When DCC runs in continuous mode both the counts shall get reloaded with seed value upon completion of counts without error. If the counts end in error DCC stops the operation and counts are not reloaded.

##### **12.8.1.2.5.1 DCC Continue on Error**

During debug, if there are events which are causing clocks to be anomalous over short period covering more than one evaluation window then it would be important to capture trajectory of error event and period around such event. To allow capturing the successive error events DCC can be programmed to continue after error. [3-0] CONT\_ON\_ERR shall be set to value other than "0101" to enable this mode. It is recommended to write "1010" to avoid single soft errors.

##### **12.8.1.2.5.2 DCC Error Count**

DCC also counts the number of error pulses generated since reset or since last time the error count is cleared. This is read/write register for CPU to clear when new trace of number of errors is required to be maintained.

#### **12.8.1.2.6 DCC Control and count hand-off across clock domains**

As the counters run in two different selectable clock domains and the register interface runs on the fixed bus clock domain, control signals and counter value hand-off have synchronizers implemented. These add to the margins of error while comparing the counts.

1. With all three counts synchronized to FICLK domain for comparison error detection there is delay in terms of FICLK domain.
2. Based on the error signal, the enable for the counters is synchronized back to the respective clock domains of the counters, which adds latency in terms of clock periods which are different, this would create a skew between start of count. Depending upon frequency ratios of the clocks used, the difference between two could vary.

Application needs to consider the worst case delay differences while measuring the clocks.

##### **12.8.1.2.7 DCC Error Trajectory record**

Once the clock errors out, the host can read the counter values to determine the extent of error to analyze type of failure. For short window comparisons this would become difficult, specially if there are back to back errors due to some transient event. Secondly, for random events which can cause an interrupt during the critical phase of application running, then event if not recorded may get overwritten and also not provide meaningful trace of error.

##### **12.8.1.2.7.1 DCC FIFO capturing for Errors**

DCC provides the FIFO for capturing COUNT0, VALID0, and COUNT1 information which captures all three counts upon "Error" event. For "Done" event no results are captured by default.

##### **12.8.1.2.7.2 DCC FIFO in continuous capture mode**

To track the VALID0 counter values regardless of "Error" or not, FIFOs can be configured to capture the count for each compare window. This is useful in validation and characterization exercise. [11-7] FIFO\_NONERR control when set to value other than "0101" this mode is set; it is recommended to write "1010" to avoid single soft errors. Note, this capture is applicable only in continuous mode and not in single shot mode.

##### **12.8.1.2.7.3 DCC FIFO Details**

The FIFO is 4 deep for each count and updates new count information for all the non-full FIFOs. Information is updated on every configured trigger of error or cycle completion. If full, the next values are not written till at-least one entry is read. Application owns responsibility to read the FIFOs uniformly to keep synchronisation between three entries of the FIFO. Both empty and full indications for individual FIFOs is provided through the .

##### **12.8.1.2.7.4 DCC FIFO Debug mode behavior**

Upon debug access, the FIFO pointers should not advance hence not impacting the functional behavior. This requirement is same as other functional blocks in the device.

#### 12.8.1.2.8 DCC Count read registers

DCC has provision to read the counts during operation. This is performed using , , and registers. Read from these registers in default mode allows reading the present value of count. This is useful when in single shot mode or mode where DCC stops upon error.

These registers can be used to read the FIFO through the [7-4] FIFO\_READ configuration. Reads on the empty FIFO shall provide the contents of last pointed location. Application shall track the empty/full conditions of the FIFOs to track the count records consistently.

Regardless of FIFO\_READ configuration, the FIFO internally keeps updating records based on configured triggers till full.

### 12.8.2 Error Signaling Module (ESM)

This section describes the Error Signaling Module (ESM) in the device.

#### 12.8.2.1 ESM Overview

The Error Signaling Module (ESM) aggregates events and/or errors from throughout the device into one location. It can signal both low and high priority interrupts to a processor to deal with an event and/or manipulate an I/O error pin to signal an external hardware that an error has occurred. Therefore an external controller is able to reset the device or keep the system in a safe, known state.

Figure 12-437 shows the ESM modules overview.



- i represents a valid instance of ESM in a domain. Consult the device datasheet for available domains and ESM instances.
- i represents a valid instance of ESM in a MCU or WKUP domain. Consult the device datasheet for available domains and ESM instances.
- Not all pins are valid for all devices. Consult the device datasheet for specifics.

#### Note

The MAIN\_ERRORn pin, if valid, is used for observation only.

**Figure 12-437. ESM Modules Overview**

#### 12.8.2.1.1 ESM Features

Each ESM module implements the following features:

- Up to 1024 error event inputs
  - Implemented in groups of 32 events
  - Level or Pulse inputs (Pulse inputs are triple redundant)
- Selectable low and high priority interrupt error pin prioritization of each error event
- Error pin to signal severe device failure
  - Support of level or PWM modes
- Configurable timebase for error signal
- Error forcing capability
- Internal redundant flops on critical fields

#### 12.8.2.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

##### Note

Some features may not be available. See *Module Integration* for more information.

---

### 12.8.2.2 ESM Environment

The MCU\_ESM0 and ESM0 modules are hereinafter referred to as ESM module.

This section describes the ESM external connections (environment).

Figure 12-438 shows the ESM pins used for typical connections with external devices.



1. i represents a valid instance of ESM in a domain. See the device specific datasheet for available domains and ESM instances.
2. i represents a valid instance of ESM in a MCU or WKUP domain. See the device specific datasheet for available domains and ESM instances.
3. Not all pins are valid. See the device datasheet for specifics.

#### Note

The MAIN\_ERRORRn pin, if valid, is used for observation only.

**Figure 12-438. ESM Modules Environment**

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

### 12.8.2.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.8.2.4 ESM Functional Description

The Error Signaling Module (ESM) centralizes fault reports. It provides mechanisms to classify errors by severity and to provide programmable error response. The error classification in the ESM is determined by programmed configuration for each individual error input. For each individual error input the configuration can be set to assert an output error pin, or generate an interrupt to a CPU, or both. When an individual error input is configured to generate an interrupt, the configuration will also select whether the interrupt that is generated will be one of high priority or low priority.

By reporting the faults in a central location, the system may determine what caused the fault and what action can be taken. In general, the faults can be split into two categories:

- Corrected faults
- Non-corrected faults

The ESM reports errors in two ways:

- An interrupt to a processor in the device. This allows the device to analyze and try to recover from an error.
- An external ERROR pin. This allows the system outside of the SoC to monitor for potentially fatal errors(errors that the device cannot self-recover from). Moreover, the external I/O (ERROR pin) can operate in level or PWM modes. In level mode, the output will remain asserted (active low) for a minimum period of time. After that period of time, if the error has been cleared by an internal processor, the pin will go inactive (high). If it does not go inactive in that time, then an external agent should intervene, as there may be an unrecoverable error. In PWM mode, the error will cause the output pin to maintain its value for a minimum period of time. After that period of time, if the error has been cleared by an internal processor, the pin will continue the PWM pattern. If it does not go inactive in that time, then an external agent should intervene, as there may be an unrecoverable error.

Both mechanisms can be used at the same time for the same fault, signaling both an interrupt and the external ERROR pin. This allows the device to attempt to recover, but if it fails, then the external system is still alerted. If it succeeds, then it can remove the ERROR pin assertion so that the external system knows that a potentially unsafe condition was avoided.

Lastly, the ESM does not specify any methods of intervention, only the process of alerting internal CPUs and external monitor(s) of an existing error event.

Figure 12-439 shows the ESM module block diagram. Note that not all instances may be pinned out in the device. For more information, see [Section 12.8.2.2, ESM Environment](#).



esm-006

**Figure 12-439. ESM Block Diagram**

#### 12.8.2.4.1 ESM Interrupt Requests

The ESM module generates three output interrupts to the device interrupt controllers:

- Configuration error interrupt (see [Section 12.8.2.4.1.1](#))
- High priority error interrupt (see [Section 12.8.2.4.1.2](#))
- Low priority error interrupt (see [Section 12.8.2.4.1.3](#))

The error interrupt outputs are provided so that a processor in the device can be signaled to intervene when an error event occurs. Each error event input can be enabled, via software, to cause an error interrupt to occur (via the `ESM_INTR_EN_SET_j` register). Additionally, each error event input can be programmed to influence either the low priority (default) interrupt or the high priority interrupt (via the `ESM_INT_PRIO_j`). The low priority interrupt is intended for events that are of interest, but do not require immediate intervention. For example, an indication that there was a single bit error that was corrected may signal a low priority interrupt, so that information can be collected for statistical purposes. A high priority interrupt is intended for events that need immediate attention. For example, an indication that there was an uncorrected two-bit error may be signaled as a high priority interrupt.

##### 12.8.2.4.1.1 ESM Configuration Error Interrupt

The configuration error interrupt (`ESM_INT_CFG_LVL_0`) indicates that there is an inconsistency in the configuration of one (or more) error group *j* registers (MMRs).

In such inconsistency in the internal copies of any of the MMRs caused by fault associated with error group *j*, the corresponding raw status will be set in the `ESM_ERR_RAW` register. If the corresponding bit is enabled in the `ESM_ERR_EN_SET` register, a configuration error interrupt will be triggered.

When a configuration error interrupt is received, the acting processor must perform the following steps:

1. Read the `ESM_ERR_STS` register to determine which group has a configuration error
2. Write the correct values to the following group registers:

---

### Note

If there has been a configuration error, the values in the below registers cannot be guaranteed to be correct anymore. Therefore, software should maintain a copy of the correct values prior to an error to ensure that they can be re-programmed with the correct configuration.

---

- a. ESM\_INTR\_EN\_SET\_j
  - b. ESM\_INTR\_EN\_CLR\_j
  - c. ESM\_INT\_PRIO\_j
  - d. ESM\_PIN\_EN\_SET\_j
  - e. ESM\_PIN\_EN\_CLR\_j
3. Service any pending interrupts in steps 4, 5, and 6 below

---

### Note

The raw status of any pending interrupts may be inconsistent. Servicing the interrupt will return it to consistency via the error group ESM\_RAW\_j register.

---

4. Write 0x1 to the appropriate bits in the ESM\_ERR\_STS register. This step will clear the raw status
  - a. If the error event is still asserted (or re-asserted) the raw status will be set back to 0x1
  - b. If there are no additional errors, the level interrupt will go low
5. Write the end of interrupt vector to the ESM\_EOI register
  - a. If there are additional configuration error interrupts pending, then a new pulse will be generated and the level interrupt will remain asserted
  - b. If there are no additional low priority error interrupts pending, there will be no new pulse.

#### **12.8.2.4.1.2 ESM Low Priority Error Interrupt**

Events mapped to the low priority error interrupt (ESM\_INT\_LOW\_LVL\_0) are intended to be events of interest that should be addressed eventually, not events that require immediate attention. An example would be an event indicating a corrected error. The system may want to track this for statistical purposes, but it does not require immediate attention.

Any error event can be mapped to the low priority error interrupt. A low priority error interrupt will be generated when an event is enabled to cause an interrupt (via the ESM\_INTR\_EN\_SET\_j register) and mapped to the low priority error interrupt (via ESM\_INT\_PRIO\_j register) and the raw status is set (via the ESM\_RAW\_j register).

When a low priority error interrupt is received, the acting processor must perform the following steps:

1. Read the ESM\_LOW\_PRI register
  - a. If both [31-16]PLS and [15-0]LVL bit fields are equal to 0xFFFF, then interrupt is no longer asserted and the interrupt routine has ended.
  - b. If either [31-16]PLS or [15-0]LVL bit fields are not equal to 0xFFFF, software has two options for determining what event to service:
    - i. First option: Record the value in [31-16]PLS and [15-0]LVL bit fields. Determine which is higher priority. This is based on the global event map number of the highest priority low priority error event

---

### Note

The global event map is neither defined by nor maintained in ESM. The global event map must be defined and maintained by software using software determined memory resources. It is conceivable that the global event map will be predefined and loaded during the execution of a secondary boot loader.

- ii. Second option:
  1. Read the ESM\_LOW register to determine which event group(s) have pending low priority error interrupts

2. Read the desired error group  $j$  ESM\_STS<sub>j</sub> register
3. Identify which low priority interrupt to service
2. Determine, based on the global event map for the device, where the error event came from
3. Service the error event based on the IP's specification:
  - a. The system may take several actions including (but not limited to):
    - i. Fixing the error
    - ii. Resetting the errored IP peripheral
    - iii. Resetting the device
    - iv. Communicating outside the device via the error pin for outside intervention

The rest of the steps assume that the error has been handled and the system wants to clear the error event. Clearing the error event depends on whether the event is a level (see [Section 12.8.2.4.1.2.1](#)) or pulse (see [Section 12.8.2.4.1.2.2](#)) event.

#### **12.8.2.4.1.2.1 ESM Low Priority Error Level Event**

When a low priority error level event has to be cleared, the acting processor must perform the following steps:

1. Clear the low priority error level event at the source
2. Write 0x1 to the appropriate bit in the error group  $j$  of the ESM\_STS<sub>j</sub> register. This step will clear the raw status
  - a. If the error event is still asserted (or re-asserted) the raw status will be set back to 0x1
  - b. If there are no error events, the level will de-assert

---

#### **Note**

There is a possible software race condition if software manages to write to the Clear register before the de-asserted level from the source has been synchronized to the ESM clock. If this is an issue, software may perform a read-back at the source IP before writing the clear register to insure order.

3. Write the end of interrupt vector to the ESM\_EOI interrupt register
  - a. If there are low priority error level events enabled and pending, then a new pulse will be generated
  - b. If there are no additional low priority error level events enabled and pending, there will be no new pulse
4. Write a CLEAR (0x5) to the ESM\_PIN\_CTRL register. This step is optional if the event is not enabled to influence the error pin (error group  $j$  ESM\_PIN\_EN\_SET<sub>j</sub> register), but may be done regardless as an extra CLEAR is not harmful.

#### **12.8.2.4.1.2.2 ESM Low Priority Error Pulse Event**

When a low priority error pulse event has to be cleared, the acting processor must perform the following steps:

1. Write 0x1 to the appropriate bit in the error group  $j$  of the ESM\_STS<sub>j</sub> register. This will clear the raw status and will de-assert the level interrupt.
2. Write the end of interrupt vector to the ESM\_EOI interrupt register
  - a. If there are additional low priority error pulse events enabled and pending, then a new pulse will be generated and the level interrupt will remain asserted
  - b. If there are no additional low priority error pulse events enabled and pending, there will be no new pulse
3. Clear the error event at the source. The source may generate a new pulse which will show up as a new error event at the ESM
4. Write a CLEAR (0x5) to the ESM\_PIN\_CTRL register. This step is optional if the event is not enabled to influence the error pin (error group  $j$  ESM\_PIN\_EN\_SET<sub>j</sub> register), but may be done regardless as an extra CLEAR is not harmful.

#### **12.8.2.4.1.3 ESM High Priority Error Interrupt**

Events mapped to the high priority error interrupt are intended to be events that require immediate intervention from the system because a potentially dangerous error has occurred. An example would be an event indicating an uncorrected error. The system will want to diagnose the issue and intervene to ensure there are no violations.

Any error event can be mapped to the high priority error interrupt. A high priority error interrupt will be generated when an event is enabled to cause an interrupt (via the ESM\_INTR\_EN\_SET\_j) register and mapped to the high priority interrupt (via the ESM\_INT\_PRIO\_j) register and the raw status is set (via the ESM\_RAW\_j).

When a high priority error interrupt is received, the acting processor must perform the following steps:

1. Read the ESM\_HI\_PRI register

- a. If both [31-16] PLS and [15-0] LVL bit fields are equal to 0xFFFF, then interrupt is no longer asserted and the interrupt routine has ended.
- b. If either [31-16] PLS or [15-0] LVL bit fields are not equal to 0xFFFF, software has two options for determining what event to service:
  - i. First option: Record the value in [31-16] PLS and [15-0] LVL bit fields. Determine which is higher priority. This is based on the global event map number of the highest priority high priority error event.

---

**Note**

The global event map is neither defined by nor maintained in ESM. The global event map must be defined and maintained by software using software determined memory resources. It is conceivable that the global event map will be predefined and loaded during the execution of a secondary boot loader.

- ii. Second option:

1. Read the ESM\_HI register to determine which event group(s) have pending high priority error interrupts
2. Read the desired error group  $j$  ESM\_STS\_j register
3. Identify which high priority error interrupt to service

2. Determine, based on the global event map for the device, where the error event came from

3. Service the error event based on the IP's specification:

- a. The system may take several actions including (but not limited to):
  - i. Fixing the error
  - ii. Resetting the errored IP peripheral
  - iii. Resetting the device
  - iv. Communicating outside the device via the error pin for outside intervention

The rest of the steps assume that the error has been handled and the system wants to clear the error event. Clearing the error event depends on whether the event is a level (see [Section 12.8.2.4.1.3.1](#)) or pulse (see [Section 12.8.2.4.1.3.2](#)) event.

#### **12.8.2.4.1.3.1 ESM High Priority Error Level Event**

When a high priority error level event has to be cleared, the acting processor must perform the following steps:

1. Clear the error event at the source
2. Write 0x1 to the appropriate bit in the error group  $j$  of the ESM\_STS\_j register. This step will clear the raw status
  - a. If the error event is still asserted (or re-asserted) the raw status will be set back to 0x1
  - b. If there are no error events, the level will de-assert

---

**Note**

There is a possible software race condition if software manages to write to the Clear register before the de-asserted level from the source has been synchronized to the ESM clock. If this is an issue, software may perform a read-back at the source IP before writing the clear register to insure order.

3. Write the end of interrupt vector to the ESM\_EOI interrupt register

- a. If there are high priority error level events enabled and pending, then a new pulse will be generated
- b. If there are no additional high priority error level events enabled and pending, there will be no new pulse

4. Write a CLEAR (0x5) to the ESM\_PIN\_CTRL register. This step is optional if the event is not enabled to influence the error pin (error group  $j$ ESM\_PIN\_EN\_SET $_j$  register), but may be done regardless as an extra CLEAR is not harmful.

#### **12.8.2.4.1.3.2 ESM High Priority Error Pulse Event**

When a high priority error pulse event has to be cleared, the acting processor must perform the following steps:

1. Write 0x1 to the appropriate bit in the error group  $j$  of the ESM\_STS $_j$  register. This will clear the raw status and will de-assert the level interrupt.
2. Write the end of interrupt vector to the ESM\_EOI interrupt register
  - a. If there are high priority error pulse events enabled and pending, then a new pulse will be generated and the level interrupt will remain asserted
  - b. If there are no additional high priority error pulse events enabled and pending, there will be no new pulse
3. Clear the error event at the source. The source may generate a new pulse which will show up as a new error event at the ESM
4. Write a CLEAR (0x5) to the ESM\_PIN\_CTRL register. This step is optional if the event is not enabled to influence the error pin (error group  $j$ ESM\_PIN\_EN\_SET $_j$  register), but may be done regardless as an extra CLEAR is not harmful.

#### **12.8.2.4.2 ESM Error Event Inputs**

The ESM can have up to 1024 error event inputs, configurable by groups of 32. For the mapping of system interrupt error events to ESM interrupt inputs, see *Interrupt Sources*.

Level error events (active high) are synchronized to the ESM clock. This synchronized value is captured in to a flop.

Pulse error events use rising edge detection. Each pulse error event has 3 redundant inputs. Each input has its own edge detection logic. Multiple transmission protects against Single Event Upsets (SEUs, transient errors) causing a pulse to be lost during transmission and against failure of the edge detection logic. Once an edge has been detected on any of the three inputs, the ESM\_RAW $_j$  status is set. Subsequent pulses are likely to come concurrently or quickly enough that software will not have reacted yet. This logic is intentionally biased against false negatives and towards false positives. An SEU that causes an event where none actually occurred will cause software to be called in to action. Software must observe that there is no real error and clear the false status.

#### **12.8.2.4.3 ESM Error Pin Output**

The error pin output (ERR\_O) is used to signal an external agent that it needs to (or may need to) intervene because of an error. Each error event input can be programmed, via software, to influence the error pin output (via the ESM\_PIN\_EN\_SET $_j$  register). The error pin output is active low or PWM based on the ESM\_EN[7-4] PWM\_EN field. This bit field should only be modified when the ESM is disabled, based on the ESM\_EN register.

During Power-On Reset (POR), the error pin is active (asserted low) and the device drives this via a weak internal pull-down. The I/O is under the control of the device. When POR is removed from the ESM, it will be driving the error pin so the device can hand over control to the ESM. The user may also add an external pull-down that is only active when the device is in reset.

During a warm reset the state of the error pin is unchanged, that is the error pin logic is only reset by a POR. The device leaves the I/O active during a warm reset.

The ESM has also a software error forcing capability on the error pin. That is, a force error can be set via the ESM\_EN[3-0] KEY bit field.

**CAUTION**

The isolation value for the ERR\_O output of ESM is active (0). This is intended and supposed to protect against an accidental transition to a low power state. If the actual low power mode transition is intended, the PMIC should be made aware by software to ignore the ESM error signal. Otherwise device resets will be asserted from companion chip.

Figure 12-440 describes the behavior of the error pin. Not shown is that a reset (Power-On-Reset only) will immediately transition the error pin to the ESM\_RESET state and a Global Soft Reset will immediately transition the error pin to the ESM\_IDLE state. A pending error interrupt event is any error event with the raw state set and the error pin Influence enabled. There are two types of "clear" events associated with servicing the error pin. The first is to clear the status of the pending event (see [Section 12.8.2.4.1](#) for how to clear level and pulse pending events). The second is the CLEAR event meant to de-assert the error pin.



**Figure 12-440. ESM Error Pin State Flowchart**

If an error event happens that has been programmed to influence the error pin, the error pin will assert (active low) for a minimum time (as programmed by the ESM\_PIN\_CNTR\_PRE register). In order for the error pin to de-assert, the following 3 things must happen:

1. The minimum time interval must expire
2. The event that caused the error pin to assert must be cleared (see [Section 12.8.2.4.1](#))
3. A CLEAR (0x5) must be written to the ESM\_PIN\_CTRL register.

---

**Note**

Step 3 should happen after step 2, but either (or both) of these steps may happen before or after step 1.

Figure 12-441 shows a typical error pin assertion.



esm-008

**Figure 12-441. ESM Error Pin Assertion**

If, during the minimum time, CLEAR is written to the error key, then the error pin will de-assert after the minimum time interval, as shown in Figure 12-442.



esm-009

**Figure 12-442. ESM Error Pin Assertion with CLEAR during Minimum Interval**

If CLEAR is not written till after the minimum time interval, the error pin will de-assert when CLEAR is written. This is regardless of whether the error interrupt event itself is removed before or after the minimum time interval, as shown by the dotted line in Figure 12-443.



esm-010

**Figure 12-443. ESM Error Pin Asserting with CLEAR after Minimum Interval**

When in the ESM\_ERROR state and a CLEAR event happen, if there are still pending error events, the ESM stays in the ESM\_ERROR state with the error pin asserted. Multiple error events when in the ESM\_ERROR state do not reset the minimum time interval counter as shown in [Figure 12-444](#).



**Figure 12-444. ESM Error Pin Asserting with Interval Reset by Additional Error Event(s)**

A CLEAR event causes a re-evaluation of whether there are any pending error events. As such, a single CLEAR can be used to clear the error pin after multiple error events. Multiple CLEAR events can occur (such as the one with the dotted arrow shown in [Figure 12-445](#)), but are not necessary. No matter how many error events occur nor when (or how many) CLEAR events occur, the error pin will always be asserted for at least the minimum time interval



**Figure 12-445. ESM Error Pin Asserting with Single CLEAR for Multiple Events**

If all error events are cleared and the ESM is in the ESM\_WAIT state, waiting for the minimum time interval to expire, and a new error interrupt event occurs, the ESM will go back to the ESM\_ERROR state. The minimum time interval will not reset, but a new CLEAR event will be required as shown in [Figure 12-446](#).



**Figure 12-446. ESM Error Pin Asserting with New Error During Minimum Time Interval**

**Table 12-346** shows some common scenarios of how the error pin as well as the two associated registers (ESM\_PIN\_CTRL and ESM\_PIN\_STS) will be set.

**Table 12-346. ESM Error Pin Scenarios**

| Scenario                                                                      | Error Pin State Value | ESM_PIN_CTRL[3-0] KEY  | ESM_PIN_STS[0] VAL status value | Additional Notes                                                               |
|-------------------------------------------------------------------------------|-----------------------|------------------------|---------------------------------|--------------------------------------------------------------------------------|
| POR Asserted                                                                  | 0                     | N/A                    | N/A                             | Registers are inaccessible. Device disables the I/O and pulls down internally. |
| After de-assertion of POR                                                     | 1                     | 0x0 (Normal Mode)      | 0x0                             | -                                                                              |
| After de-assertion of Warm Reset (error was not asserted when reset asserted) | 1                     | 0x0 (Normal Mode)      | 0x0                             | -                                                                              |
| After de-assertion of Warm Reset (error was asserted when reset asserted)     | 0                     | 0x0 (Normal Mode)      | 0x1                             | -                                                                              |
| Force error pin                                                               | 0                     | 0xA (Force Error Mode) | 0x0                             | Forcing error on the pin via software.                                         |

#### 12.8.2.4.4 PWM Mode

If the error output pin is in PWM mode then when no error is detected it will toggle according to programmable MMR widths for high and low periods. When an error occurs, the error pin stops toggling and remains constant until the error is cleared. An external PMIC that is detecting the PWM toggles can identify the error if the pin stops toggling. The periods should be programmed such that they fit within the expectation of the external PMIC.

#### 12.8.2.4.5 ESM Minimum Time Interval

The minimum time interval is the minimum amount of time that the error pin will be asserted (active low) when an enabled error interrupt event happens. This value is system dependent, but should be enough time so that the external monitoring agent can always see the error pin asserted, but short enough so that if all of the error events are cleared, then the error pin can be de-asserted before the external agent decides to intervene. This is highly dependent on the application and the Fault Tolerant Time Interval.

The Minimum Time Interval counter is clock cycle based, therefore the time of the interval is a combination of the value in the ESM\_PIN\_CNTR\_PRE register and the clock frequency of the ESM. Software must calculate the value accordingly. The Minimum Time Interval should be set according to the needs of the application.

#### 12.8.2.4.6 ESM Protection for Registers

The configuration for each error group  $j$  of registers are backed up by 3 flops in order to protect against single or double-bit errors. When written, all 3 bits are set to the same value. When read (and for functioning of the internal state machines) the value is the OR of all 3 bits. Whenever any of the bits disagree, the Configuration Error interrupt is asserted (if enabled). The registers covered by this mechanism are:

- ESM\_ERR\_RAW
- ESM\_ERR\_STS
- ESM\_ERR\_EN\_SET
- ESM\_ERR\_EN\_CLR
- ESM\_RAW<sub>j</sub>
- ESM\_STS<sub>j</sub>
- ESM\_INTR\_EN\_SET<sub>j</sub>
- ESM\_INTR\_EN\_CLR<sub>j</sub>
- ESM\_INT\_PRIO<sub>j</sub>
- ESM\_PIN\_EN\_SET<sub>j</sub>
- ESM\_PIN\_EN\_CLR<sub>j</sub>

The error pin control register ESM\_PIN\_CTRL contains a multi-bit field KEY. The key value ensures normal operation on the error pin and that an error even will be generated if one occurs. Software should periodically

read check the KEY bit field value and make sure it is 0x0. If the value is not 0x0, software must re-write it to this key value (unless in test mode forcing an error on the pin) to ensure the normal operation. [Table 12-347](#) lists the KEY values and their respective meaning.

**Table 12-347. ESM Error Pin Control Values**

| ESM_PIN_CTRL[3-0] KEY | Description                                                                                                                                                                                                                                                                                            |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                   | Registers are inaccessible. Device disables the I/O and pulls down internally.                                                                                                                                                                                                                         |
| 0x0 (Normal)          | Normal operation mode - Error pin will activate when an enabled error event occurs.                                                                                                                                                                                                                    |
| 0xA (Force Error)     | Force error mode - Forces the error pin active. To clear the error pin (return to the ESM_IDLE state) write this field back to normal mode (writing a CLEAR event will also work). Force error mode must be set only while in IDLE. Attempting force error while in another state will have no effect. |
| 0x5 (CLEAR)           | CLEAR Event - generates a CLEAR event to the ESM state machine. KEY will return to normal mode (0x0) on the next cycle.                                                                                                                                                                                |
| Other Values          | All other values - Normal mode. Writing any of these values will have no effect. When reading any of these values indicates that one or more bits have experienced a single event upset, software should write the field back to 0x0. The ESM will continue to operate in normal mode.                 |

The error pin counter pre-load register ESM\_PIN\_CNTR\_PRE should also be read and checked periodically by software.

#### 12.8.2.4.7 ESM Clock Stop

The ESM can only be put in to clock stop if all of the internal state machines are idle and the [3-0] KEY bit field for the global enable command is cleared in the ESM\_EN register.

### 12.8.3 Memory Cyclic Redundancy Check (MCRC) Controller

This chapter describes the Memory Cyclic Redundancy Check (MCRC) controller in the device.

#### 12.8.3.1 MCRC Overview

VBUSM CRC controller is a module which is used to perform CRC (Cyclic Redundancy Check) to verify the integrity of a memory system. A signature representing the contents of the memory is obtained when the contents of the memory are read into MCRC Controller. The responsibility of MCRC controller is to calculate the signature for a set of data and then compare the calculated signature value against a pre-determined good signature value. MCRC controller provides four channels to perform CRC calculation on multiple memories in parallel and can be used on any memory system.

##### 12.8.3.1.1 MCRC Features

MCRC has the following features:

- Four channels to perform background signature verification on any memory subsystem
- Data compression on 8-, 16-, 32-, and 64-bit data size
- Maximum-length PSA (Parallel Signature Analysis) register constructed based on 64-bit primitive polynomial
- Each channel has a CRC Value Register which contains the pre-determined CRC value
- Use timed base event trigger from timer to initiate DMA data transfer
- Programmable 20-bit pattern counter per channel to count the number of data patterns for compression
- Three modes of operation:
  - Auto
  - Semi-CPU
  - Full-CPU
- For each channel, CRC can be performed either by MCRC Controller or by CPU
- Automatically performs signature verification without CPU intervention in AUTO mode
- Generates interrupt to CPU in Semi-CPU mode to allow CPU to perform signature verification itself
- Generates CRC fail interrupt in AUTO mode if signature verification fails
- Generates Timeout interrupt if CRC is not performed within the time limit
- Generates DMA request per channel to initiate CRC value transfer
- An 128-byte block burst address for the PSA register to DMA without constant mode bus attribute

##### 12.8.3.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

### 12.8.3.2 MCRC Functional Description

#### 12.8.3.2.1 MCRC Block Diagram

Figure 12-447 shows the MCRC internal blocks.



mcrc-003

**Figure 12-447. MCRC Block Diagram**

- **Command FIFO:** The Command FIFO pipelines the commands to the target register interface. The Command and Write FIFOs allow the data to be coincident for processing. If there is no space for writes in the Write Status FIFO or no space in the Read Data FIFO for reads, the command processing will be halted until there is space in the appropriate FIFO. This FIFO is 4 elements deep.
- **Write FIFO:** The Write FIFO pipelines the write data to the target register interface. The Command and Write FIFOs allow the data to be coincident for processing. If there is no space for writes in the Write Status FIFO or no space in the Read Data FIFO for reads, the command processing will be halted until there is space in the appropriate FIFO. This FIFO is 2 elements deep.
- **Write Status FIFO:** The Write Status FIFO pipelines the write status back to the VBUSM. A write status will be issued on the final data phase of a write command. This FIFO is 2 elements deep.
- **Read Data FIFO:** The Read Data FIFO pipelines the read data back to the VBUSM. This FIFO is 3 elements deep.
- **Target Register Interface:** The Target Register Interface directs the written data to the register file.
- **PSA Signature:** The PSA Signature creates the signature of the data written. This data will then be compared to the CRC Value or read by software to determine goodness.
- **Pattern State Machine:** The Pattern State Machine determines when a block of data has been serviced.
- **Timer State Machine:** The Timer State Machine determines when overrun and under-run events are detected.
- **Sector State Machine:** The Sector State Machine determines when a sector error should be captured so the software can determine the errant block of data.
- **Signature Compare:** The Signature Compare block compares the current signature to the CRC Value register and sends the result to the Interrupt Generation block.

#### **12.8.3.2.2 MCRC General Operation**

There are four channels in MCRC controller and for each channel there is a PSA (Parallel Signature Analysis) Signature Register (MCRC64\_0\_PSA\_SIGREGL1-4) and a CRC (Cyclic Redundancy Check) Value Register (MCRC64\_0\_CRC\_REGL1-4).

A memory can be organized into multiple sectors with each sector consisting of multiple data patterns. A data pattern can be a 8-, 16-, 32-, or 64-bit data. MCRC module performs the signature calculation and compares the signature to a pre-determined value. The PSA Signature Register compresses an incoming data pattern into a signature when it is written. When one sector of data patterns are written into PSA Signature Register, a final signature corresponding to the sector is obtained. CRC Value Register stores the pre-determined signature corresponding to one sector of data patterns. The calculated signature and the pre-determined signature are then compared to each other for signature verification. To minimize CPU's involvement, data patterns transfer can be carried out at the background of CPU using DMA controller. DMA is setup to transfer data from memory of which the contents to be verified to the memory mapped PSA Signature Register. When DMA transfers data to the memory mapped PSA Signature Register, a signature is generated.

A programmable 20-bit data pattern counter is used for each channel to define the number of data patterns to calculate for each sector. Signature verification can be performed automatically by MCRC controller in AUTO mode or by CPU itself in Semi-CPU or Full-CPU mode. In AUTO mode, a self-sustained CRC signature calculation can be achieved without any CPU intervention.

#### **12.8.3.2.3 MCRC Modes of Operation**

MCRC Controller can operate in AUTO, Semi-CPU, and Full-CPU modes.

##### **12.8.3.2.3.1 AUTO Mode**

In AUTO mode, MCRC Controller in conjunction with DMA controller can perform CRC without CPU intervention. A sustained transfer of data to both the PSA Signature Register (MCRC64\_0\_PSA\_SIGREGL1-4) and a CRC (Cyclic Redundancy Check) Value Register (MCRC64\_0\_CRC\_REGL1-4) are performed in the background of CPU. When a mismatch is detected, an interrupt is generated to the CPU. A 16-bit, current sector ID register (MCRC64\_0\_CRC\_CURSEC\_REG1-4) is provided to identify which sector causes a CRC failure.

##### **12.8.3.2.3.2 Semi-CPU Mode**

In Semi-CPU mode, DMA controller is also utilized to perform data patterns transfer to PSA Signature Register (MCRC64\_0\_PSA\_SIGREGL1-4). Instead of performing signature verification automatically, the CRC controller generates an compression complete interrupt to CPU after each sector is compressed. Upon responding to the interrupt the CPU performs the signature verification by reading the calculated signature stored at the PSA Sector Signature Register (MCRC64\_0\_PSA\_SECSIGREGL1-4) and compare it to a pre-determined CRC value.

##### **12.8.3.2.3.3 Full-CPU Mode**

In Full-CPU mode, the CPU does the data patterns transfer and signature verification all by itself. When CPU has enough throughput, it can perform data patterns transfer by reading data from the memory system to the PSA Signature Register (MCRC64\_0\_PSA\_SIGREGL1). After certain number of data patterns are compressed, the CPU can read from the PSA Signature Register and compare the calculated signature to the pre-determined CRC signature value. In Full-CPU mode, neither interrupt nor DMA request is generated. All counters are also disabled.

#### **12.8.3.2.4 PSA Signature Register**

The 64-bit PSA Signature Register (MCRC64\_0\_PSA\_SIGREGL1-4 and MCRC64\_0\_PSA\_SIGREGH1-4) is based on the primitive polynomial found in (EQ 1) to produce the maximum length LFSR (Linear Feedback Shift Register).

$$f(x) = x^{64} + x^4 + x^3 + x + 1 \quad (8)$$

- A. More details of the 64-bit primitive polynomial can be found at W. Stahnke, Primitive binary polynomials, Math. Comp. 27 (1973), 977-980.

There is one PSA Signature Register per CRC channel. PSA Signature Register can be both read and written. When it is written, it can either compress the data or just capture the data depending on the state of CHi\_MODE bits (where i = 1 to 4). If CHi\_MODE=0x0 (Data Capture), a seed value can be planted in the PSA Signature Register without compression. Other modes other than Data Capture will result with the data compressed by PSA Signature Register when it is written. Each channel can be planted with different seed value before compression starts. When PSA Signature Register is read, it gives the calculated signature.

MCRC Controller should be used in conjunction with the on-chip DMA controller to produce optimal system performance. The incoming data pattern to PSA Signature Register is typically initiated by the DMA controller. When DMA is properly setup, it would read data from the pre-determined memory system and write them to the memory mapped PSA Signature Register. Each time PSA Signature Register is written a signature is generated. CPU itself can also perform data transfer by reading from the memory system and perform write operation to PSA Signature Register if CPU has enough throughput to handle data patterns transfer.

After a system reset and when AUTO mode is enabled, MCRC Controller automatically generates a DMA request to request the pre-determined CRC value corresponding to the first sector of memory to be checked.

In AUTO mode, when one sector of data patterns is compressed, the signature stored at the PSA Signature Register is first copied to the PSA Sector Signature Register (MCRC64\_0\_PSA\_SECSIGREGL1-4) and PSA Signature Register is then cleared out to all zeros. An automatic signature verification is then performed by comparing the signature stored at the PSA Sector Signature Register to the CRC Value Register (MCRC64\_0\_CRC\_REGL1-4). After the comparison the MCRC Controller can generate a DMA request. Upon receiving the DMA request the DMA controller will update the CRC Value Register by transferring the next pre-determined signature value associated with the next sector of memory system. If the signature verification fails then MCRC Controller can generate a CRC fail interrupt.

In Full-CPU mode, no DMA request and interrupt are generated at all. The number of data patterns to be compressed is determined by CPU itself. Full-CPU mode is useful when DMA controller is not available to perform background data patterns transfer. Software can periodically generate a software interrupt to CPU and use CPU to accomplish data transfer and signature verification.

MCRC Controller supports double word, word, half word and byte access to the PSA Signature Register. During a non-doubleword write access, all unwritten byte lanes are padded with zeros before compression. Note that comparison between PSA Sector Signature Register and CRC Value Register is always in 64 bits because a compressed value is always expressed in 64 bits.

There is a software reset per channel for PSA Signature Register. When set, the PSA Signature Register is reset to all zeros.

PSA Signature Register is reset to zero under the following conditions:

- System reset
- PSA Software reset
- One sector of data patterns are compressed

#### **12.8.3.2.5 PSA Sector Signature Register**

After one sector of data is compressed, the final resulting signature calculated by PSA Signature Register is transferred to the 64-bit PSA Sector Signature Register (MCRC64\_0\_PSA\_SECSIGREGL1-4 and MCRC64\_0\_PSA\_SECSIGREGH1-4). PSA Signature Register is a read-only register. During Semi-CPU mode, the host CPU must read from the PSA Sector Signature Register instead of reading from PSA Signature Register for signature verification to avoid data coherency issue. The PSA Signature Register can be updated with new signature before the host CPU is able to retrieve it.

In Semi-CPU mode, no DMA request is generated. When one sector of data patterns is compressed, CRC controller first generates a compression complete interrupt. Responding to the interrupt, CPU will read the PSA Sector Signature Register and compare it to the known good signature or write the signature value to another memory location to build a signature file. In Semi-CPU mode, CPU must perform the signature verification in a manner to prevent any overrun condition. The overrun condition occurs when the compression complete

interrupt is generated after one sector of data patterns is compressed and CPU has not read from the PSA Sector Signature Register to perform necessary signature verification before PSA Sector Signature Register is overridden with a new value. An overrun interrupt can be enabled to generate when overrun condition occurs.

#### **12.8.3.2.6 CRC Value Register**

Associated with each channel there is a 64-bit CRC Value Register (MCRC64\_0\_CRC\_REGL1-4 and MCRC64\_0\_CRC\_REGH1-4).

The CRC Value Register stores the pre-determined CRC value. After one sector of data patterns is compressed by PSA Signature Register, MCRC Controller can automatically compare the resulting signature stored at the PSA Sector Signature Register with the pre-determined value stored at the CRC Value Register if AUTO mode is enabled. If the signature verification fails, MCRC Controller can be enabled to generate an CRC fail interrupt. When the channel is set up for Semi-CPU mode, CRC controller first generates a compression complete interrupt to CPU. Upon servicing the interrupt, CPU will then read the PSA Sector Signature Register and then read the corresponding CRC value stored at another location and compare them. CPU must not read from the CRC Value Register during Semi-CPU or Full-CPU mode because the CRC Value Register is not updated during these two modes.

In AUTO mode, for first sector's signature, DMA request is generated when mode is programmed to AUTO. For subsequent sectors, DMA request is generated after each sector is compressed. Responding to the DMA request, DMA controller reloads the CRC Value Register for the next sector of memory system to be checked. The user software needs to configure the DMA to ensure that the DMA first writes to the MCRC64\_0\_CRC\_REGL1 followed by the MCRC64\_0\_CRC\_REGH1 register in during the AUTO Mode.

When CRC Value Register is updated with a new CRC value, an internal flag is set to indicate that CRC Value Register contains the most current value. This flag is cleared when CRC comparison is performed. Each time at the end of the final data pattern compression of a sector, MCRC Controller first checks to see if the corresponding CRC Value Register has the most current CRC value stored in it by polling the flag. If the flag is set then the CRC comparison can be performed. If the flag is not set then it means the CRC Value Register contains stale information. A CRC underrun interrupt is generated. When an underrun condition is detected, signature verification is not performed.

MCRC Controller supports double word, word, half word and byte access to the CRC Value Register. As noted before comparison between PSA Sector Signature Register and CRC Value Register during AUTO mode is carried out in 64 bits.

#### **12.8.3.2.7 Raw Data Register**

The raw or un-compressed data written to the PSA Signature Register is also saved in the 64-bit Raw Data Register (MCRC64\_0\_RAW\_DATAREGL1-4 and MCRC64\_0\_RAW\_DATAREGH1-4). This register is read only.

#### **12.8.3.2.8 Example DMA Controller Setup**

DMA controller needs to be setup properly in either AUTO or Semi-CPU mode as DMA controller is used to transfer data patterns. Hardware or a combination of hardware and software DMA triggering are supported.

##### **12.8.3.2.8.1 AUTO Mode Using Hardware Timer Trigger**

There are two DMA channels associated with each CRC channel when in AUTO mode. One DMA channel is setup to transfer data patterns from the source memory to the PSA Signature Register (MCRC64\_0\_PSA\_SIGREGL1-4). The second DMA channel is setup to transfer the pre-determined signature to the CRC Value Register (MCRC64\_0\_CRC\_REGL1-4). The trigger source for the first DMA channel can be either by hardware or by software. As illustrated in [Figure 12-448](#), a timer can be used to trigger a DMA request to initiate transfer from the source memory system to PSA Signature Register. In AUTO mode, MCRC Controller also generates DMA request after one sector of data patterns is compressed to initiate transfer of the next CRC value corresponding to the next sector of memory. Thus a new CRC value is always updated in the CRC Value Register (MCRC64\_0\_CRC\_REGL1-4) by DMA synchronized to each sector of memory.

A block of system memory is usually divided into many sectors. All sectors are the same size. The sector size is programmed in the MCRC64\_0\_CRC\_PCOUNT\_REG1-4 and the number of sectors in one block is programmed in the MCRC64\_0\_CRC\_SCOUNT\_REG1-4 of the respective channel. MCRC64\_0\_CRC\_PCOUNT\_REG1-4 multiplies MCRC64\_0\_CRC\_SCOUNT\_REG1-4 and multiplies transfer size of each data pattern should give the total block size in number of bytes.

The total size of the memory system to be examined is also programmed in the respective transfer count register inside DMA module. The DMA transfer count register is divided into two parts. They are element count and frame count. Note that a hardware DMA request can be programmed to trigger either one frame or one entire block transfer. In [Figure 12-448](#), a hardware DMA request from a timer is used as a trigger source to initiate DMA transfer. If all four CRC channels are active in AUTO mode then a total of four DMA requests would be generated by MCRC Controller.



**Figure 12-448. AUTO Mode Using Hardware Timer Trigger**

#### 12.8.3.2.8.2 AUTO Mode Using Software Trigger

The data patterns transfer can also be initiated by software. CPU can generate a software DMA request to activate the DMA channel to transfer data patterns from source memory system to the PSA Signature Register. To generate a software DMA request CPU needs to set the corresponding DMA channel in the DMA software trigger register. Note that just one software DMA request from CPU is enough to complete the entire data patterns transfer for all sectors. Please see [Figure 12-449](#) for illustration.


mrcr-005

**Figure 12-449. AUTO Mode With Software CPU Trigger**

#### 12.8.3.2.8.3 Semi-CPU Mode Using Hardware Timer Trigger

During Semi-CPU mode, no DMA request is generated by CRC controller. Therefore, no DMA channel is allocated to update CRC Value Register. CPU should not read from CRC Value Register in semi-CPU mode as it contains stale value. Note that no signature verification is performed at all during this mode. Similar to AUTO mode, either by hardware or by software DMA request can be used as a trigger for data patterns transfer. [Figure 12-450](#) illustrates the DMA setup using semi-CPU mode with hardware timer trigger.


mrcr-006

**Figure 12-450. Semi-CPU Mode With Hardware Timer Trigger**

**Table 12-348. DMA Request and Counter Logic Operation According to CRC Mode**

| CRC Mode | DMA Request | Pattern Counter | Sector Counter | Timeout Counter |
|----------|-------------|-----------------|----------------|-----------------|
| AUTO     | Active      | Active          | Active         | Active          |
| Semi-CPU | Inactive    | Active          | Active         | Active          |
| Full CPU | Inactive    | Inactive        | Inactive       | Inactive        |

#### 12.8.3.2.9 Pattern Count Register

There is a 20-bit data pattern counter for every CRC channel. The data pattern counter is a down counter and can be pre-loaded with a programmable value stored in the Pattern Count Register (MCRC64\_0\_CRC\_PCOUNT\_REG1-4). When the data pattern counter reaches zero, a compression complete interrupt is generated in Semi-CPU mode and an automatic signature verification is performed in AUTO mode. In AUTO only, DMA request is generated to trigger the DMA controller to update the CRC Value Register.

---

##### Note

The data pattern count must be divisible by the total transfer count as programmed in DMA controller. The total transfer count is the product of element count and frame count.

#### 12.8.3.2.10 Sector Count Register/Current Sector Register

Each channel contains a 16-bit sector counter. The sector count register stores the number of sectors. Sector counter is a free running counter and is incremented by one each time when one sector of data patterns is compressed. When the signature verification fails, the current value stored in the sector counter is saved into current sector register (MCRC64\_0\_CRC\_CURSEC\_REG1-4). If signature verification fails, CPU can read from the current sector register to identify the sector which causes the CRC mismatch. To aid and facilitate the CPU in determining the cause of a CRC failure it is advisable to use the following equation during CRC and DMA setup.

$$\text{CRC Pattern Count} \times \text{CRC Sector Count} = \text{DMA Element Count} \times \text{DMA Frame Count} \quad (9)$$

The current sector register is frozen from being updated until both the current sector register is read and CRC fail (CHi\_CRC\_FAIL) status bit is cleared by CPU. If CPU does not respond to the CRC failure in a timely manner before another sector produces a signature verification failure, the current sector register is not updated with the new sector number. An overrun interrupt is generated instead. If current sector register is already frozen with an erroneous sector and emulation is entered with SUSPEND signal goes to high then the register still remains frozen even it is read.

In Semi-CPU mode, the current sector register is used to indicate the sector for which the compression complete has last happened.

Current sector register is reset when the PSA software reset is enabled.

---

##### Note

Both data pattern count and sector count registers must be greater than or equal to one for the counters to count. After reset, pattern count and sector count registers default to zero and the associated counters are inactive.

#### 12.8.3.2.11 Interrupts

CRC generate several types of interrupts per channel. Associated with each interrupt there is a interrupt enable bit (see MCRC64\_0\_CRC\_INTS). No interrupt is generated in Full-CPU mode.

- Compression complete interrupt
- CRC fail interrupt
- Overrun interrupt
- Underrun interrupt
- Timeout interrupt

**Table 12-349. Interrupt Conditions Per CRC Mode**

| CRC Mode | Compression Complete | CRC Fail | Overrun | Underrun | Timeout |
|----------|----------------------|----------|---------|----------|---------|
| AUTO     | No                   | Yes      | Yes     | Yes      | Yes     |
| Semi-CPU | Yes                  | No       | Yes     | No       | Yes     |

**Table 12-349. Interrupt Conditions Per CRC Mode (continued)**

| CRC Mode | Compression Complete | CRC Fail | Overrun | Underrun | Timeout |
|----------|----------------------|----------|---------|----------|---------|
| Full-CPU | No                   | No       | No      | No       | No      |

#### 12.8.3.2.11.1 Overrun Interrupt

Overrun Interrupt is generated in either AUTO or Semi-CPU mode. During AUTO mode, if a CRC fail is detected then the current sector number is recorded in the current sector register (MCRC64\_0\_CRC\_CURSEC\_REG1-4). If CRC fail status bit is not cleared and current sector register is not read by the host CPU before another CRC fail is detected for another sector then an overrun interrupt is generated. During Semi-CPU mode, when the data pattern counter finishes counting, it generates a compression complete interrupt. At the same time the signature is copied into the PSA Sector Signature Register (MCRC64\_0\_PSA\_SECSIGREGL1-4). If the host CPU does not read the signature from PSA Sector Signature Register before it is updated again with a new signature value then an overrun interrupt is generated.

#### 12.8.3.2.11.2 Timeout Interrupt

To ensure that the memory system is examined within a pre-defined time frame and no loss of incoming data there is a 24-bit timeout counter per CRC channel. The timeout counter can be pre-loaded with two different pre-load values, watchdog timeout pre-load value (MCRC64\_0\_CRC\_WDTOPLD1-4) and block complete timeout pre-load value (MCRC64\_0\_CRC\_BCTOPLD1-4). The timeout counter is clocked by a prescaler clock which is permanently running at division 64 of FICLK clock.

Watchdog timeout pre-load register (MCRC64\_0\_CRC\_WDTOPLD1-4) is used to check if DMA does supply a block of data responding to a request in a given time frame. Block complete timeout pre-load register (MCRC64\_0\_CRC\_BCTOPLD1-4) is used to check if one complete block of data patterns are compressed within a specific time frame. The timeout counter is first pre-loaded with MCRC64\_0\_CRC\_WDTOPLD1-4 after either AUTO or Semi-CPU mode is selected and starts to down count. If the timeout counter expires before DMA transfers any data pattern to PSA Signature Register then a timeout interrupt is generated. An incoming data pattern before the timeout counter expires will automatically pre-load the timeout counter with MCRC64\_0\_CRC\_BCTOPLD1-4 the block complete timeout pre-load value.

Block complete timeout pre-load value is used to check if one block of data patterns are compressed within a given time limit. If the timeout counter pre-loaded with MCRC64\_0\_CRC\_BCTOPLD1-4 value expires before one block of data patterns are compressed a timeout interrupt is generated. When one block (pattern count  $\times$  sector count) of data patterns are compressed before the counter has expired, the counter is pre-loaded with MCRC64\_0\_CRC\_WDTOPLD1-4 value again. If the timeout counter is pre-loaded with zero then the counter is disable and no timeout interrupt is generated.

#### 12.8.3.2.11.3 Underrun Interrupt

Underrun interrupt only occurs in AUTO mode. The interrupt is generated when the CRC Value Register is not updated with the corresponding signature when the data pattern counter finishes counting. During AUTO mode, MCRC Controller generates DMA request to update CRC Value Register in synchronization to the corresponding sector of the memory. Signature verification is also performed if underrun condition is detected. And CRC fail interrupt is generated at the same time as the underrun interrupt.

#### 12.8.3.2.11.4 Compression Complete Interrupt

Compression complete interrupt is generated in Semi-CPU mode only. When the data pattern counter reaches zero, the compression complete flag is set and the interrupt is generated

#### 12.8.3.2.11.5 Interrupt Offset Register

MCRC Controller only generates one interrupt request to interrupt manager. An interrupt offset register (MCRC64\_0\_CRC\_INT\_OFFSET\_REG) is provided to indicate the source of the pending interrupt with highest priority. [Table 12-350](#) shows the offset interrupt vector address of each interrupt in an ascending order of priority.

**Table 12-350. Interrupt Offset Mapping**

| Interrupt Condition      | Offset Value |
|--------------------------|--------------|
| Phantom                  | 0x0          |
| Ch1 CRC Fail             | 0x1          |
| Ch2 CRC Fail             | 0x2          |
| Ch3 CRC Fail             | 0x3          |
| Ch4 CRC Fail             | 0x4          |
| reserved                 | 0x5-0x8      |
| Ch1 Compression Complete | 0x9          |
| Ch2 Compression Complete | 0xA          |
| Ch3 Compression Complete | 0xB          |
| Ch4 Compression Complete | 0xC          |
| reserved                 | 0xD-0x10     |
| Ch1 Overrun              | 0x11         |
| Ch2 Overrun              | 0x12         |
| Ch3 Overrun              | 0x13         |
| Ch4 Overrun              | 0x14         |
| reserved                 | 0x15-0x18    |
| Ch1 Underrun             | 0x19         |
| Ch2 Underrun             | 0x1A         |
| Ch3 Underrun             | 0x1B         |
| Ch4 Underrun             | 0x1C         |
| reserved                 | 0x1D-0x20    |
| Ch1 Timeout              | 0x21         |
| Ch2 Timeout              | 0x22         |
| Ch3 Timeout              | 0x23         |
| Ch4 Timeout              | 0x24         |

#### 12.8.3.2.11.6 Error Handling

When an interrupt is generated, host CPU must take appropriate actions to identify the source of error and restart the respective channel in DMA and MCRC module. To restart a CRC channel user must perform the following steps in the ISR:

1. Write to software reset bit in MCRC64\_0\_CRC\_CTRL0 register to reset the respective PSA Signature Register
2. Reset the CHi\_MODE bits to 0 in MCRC64\_0\_CRC\_CTRL2 register as Data capture mode
3. Set the CHi\_MODE bits in MCRC64\_0\_CRC\_CTRL2 register to desired new mode again
4. Release software reset

The host CPU must use byte write to restart each individual channel.

#### 12.8.3.2.12 Power Down Mode

MCRC module can be put into power down mode when the power down control bit MCRC64\_0\_CRC\_CTRL1[0] PWDN is set. The module wakes up when the PWDN bit is cleared. When MCRC controller is in power down mode, no data tracing alone will happen.

#### 12.8.3.2.13 Emulation

A read access from a register in functional mode can sometimes trigger a certain internal event to follow. For example, reading interrupt offset register triggers an event to clear the corresponding interrupt status flag. During emulation when SUSPEND signal is high, a read access from any register should only return the register contents to the bus and should not trigger or mask any event as it would have in functional mode. This is

to prevent debugger from reading the interrupt offset register, that is, during refreshing screen and cause the corresponding interrupt status flag to get cleared. Timeout counters are stopped to generate timeout interrupts in emulation mode. No VBUSM bus error will be generated if reading from the unimplemented locations. .

CEMUDBG is the VBUSM suspend signal which need not explicitly indicate that whether CPU is in suspend mode or not. In data trace mode, a separate suspend signal CPU\_EMUSP, is used to indicate MCRC controller that the CPU is in suspend mode or not.

### 12.8.3.3 MCRC Programming Examples

#### 12.8.3.3.1 Example: Auto Mode Using Time Based Event Triggering

A large memory area with 2 Mbyte (256 k × 32-bit [doubleword]) is to be checked in the background of CPU. CRC is to be performed every 1 Kbyte (128 doubleword). Therefore there will be 2048 pre-recorded CRC values. For illustration purpose, we map MCRC64\_0\_CRC\_REGL1 register to DMA channel 1 and MCRC64\_0\_PSA\_SIGREGL1 register to DMA channel 2. Let's assume all DMA transfers are carried out in 64-bit transfer size.

##### 12.8.3.3.1.1 DMA Setup

- Setup DMA channel 1 with the starting address from which the pre-determined CRC values are stored. Setup the destination address to the MCRC64\_0\_CRC\_REGL1. Put the source address at post increment addressing mode and put the destination address at constant addressing mode. Use hardware DMA request for channel 1 to trigger a frame transfer.
- Setup DMA channel 2 with the source address from which the contents of memory to be verified. Setup the destination address to the MCRC64\_0\_PSA\_SIGREGL1. Program the element transfer count to 128 and the frame transfer count to 2048. Program the read and write element size to 64 bits. Put the source address at post increment addressing mode and put the destination address at constant address mode. Use hardware DMA request for channel 2 to trigger an entire block transfer.

##### 12.8.3.3.1.2 Timer Setup

The timer can be any general purpose timer which is capable of generating a time based DMA request.

- Setup Timer to generate DMA request associated with DMA channel 2. For example, software can setup the timer to generate a DMA request every 10 ms.

##### 12.8.3.3.1.3 CRC Setup

- Program the pattern count MCRC64\_0\_CRC\_PCOUNT\_REG1 to 128
- Program the sector count MCRC64\_0\_CRC\_SCOUNT\_REG1 to 2048
- For example, we want the entire 2 Mbytes to be compressed within 5 ms. We can program the block complete timeout pre-load (MCRC64\_0\_CRC\_BCTOPLD1-4) value to 15625 (5 ms / (1 FCLK period × 64)) if CRC is operating at 200 MHz.
- Enable AUTO mode and all interrupts.

After AUTO mode is selected MCRC Controller automatically generates a DMA request on channel 1. Around the same time the timer module also generates a DMA request on DMA channel 2. When the first incoming data pattern arrives at the MCRC64\_0\_PSA\_SIGREGL1/H1, the MCRC Controller will compress it. After some time, the DMA controller would update the MCRC64\_0\_CRC\_REGL1/H1 with a pre-determined value matching the calculated signature for the first sector of 128 64-bit data patterns. After one sector of data patterns are compressed, the MCRC Controller generates a CRC fail interrupt if signature stored at the MCRC64\_0\_PSA\_SECSIGREGL1/H1 does not match the MCRC64\_0\_CRC\_REGL1/H1 Register. MCRC Controller generates a DMA request on DMA channel 1 when one sector of data patterns are compressed. This routine will continue until the entire 2 Mbytes are consumed. If the timeout counter reached zero before the entire 2 Mbytes are compressed, a timeout interrupt is generated. After 2Mbytes are transferred, the DMA can generate an interrupt to CPU. The entire operation will continue again when DMA responds to the DMA request from both the timer and MCRC Controller. The CRC is performed totally without any CPU intervention.

#### 12.8.3.3.2 Example: Auto Mode Without Using Time Based Triggering

A small but highly secured memory area with 1 Kbytes is to be checked in the background of CPU. CRC is to be performed every 1 Kbytes. Therefore, there is only one pre-recorded CRC value. For illustration purpose, we map channel 1 MCRC64\_0\_CRC\_REGL1/H1 to DMA channel 1 and channel 1 MCRC64\_0\_PSA\_SIGREGL1/H1 to DMA channel 2. Assume all transfers carried out by DMA are in 64-bit transfer size.

#### **12.8.3.3.2.1 DMA Setup**

- Setup DMA channel 1 with the source address from which the pre-determined CRC value is stored. Setup the destination address to the MCRC64\_0\_CRC\_REGL1 Register. Put the source address at constant addressing mode and put the destination address at constant addressing mode. Use hardware DMA request for channel 1.
- Setup DMA channel 2 with the source address from which the memory area to be verified. Setup the destination address to the MCRC64\_0\_PSA\_SIGREGL1/H1. Program the element transfer count to 128 and the frame transfer count to 1. Put the source address at post increment addressing mode and put the destination address at constant address mode. Generate a software DMA request on channel 2 after CRC has completed its setup. Enable autoinitiation for DMA channel 2.

#### **12.8.3.3.2.2 CRC Setup**

- Program the MCRC64\_0\_CRC\_PCOUNT\_REG1 to 128
- Program the MCRC64\_0\_CRC\_SCOUNT\_REG1 to 1
- Leaving the timeout count MCRC64\_0\_CRC\_BCTOPLD1 register with the reset value of zero means no timeout interrupt is generated
- Enable AUTO mode and all interrupts

After AUTO mode is selected the MCRC Controller automatically generates a DMA request on channel 1. At the same time the CPU generates a software DMA request on DMA channel 2. When the first incoming data pattern arrives at the MCRC64\_0\_PSA\_SIGREGL1/H1, the MCRC Controller will compress it. After some time, the DMA controller would update the MCRC64\_0\_CRC\_REGL1/H1 with a pre-determined value matching the calculated signature for the first sector of 128 64-bit data patterns. After one sector of data patterns are compressed, the MCRC Controller generate a CRC fail interrupt if signature stored at the MCRC64\_0\_PSA\_SECSIGREGL1/H1 does not match the MCRC64\_0\_CRC\_REGL1/H1. MCRC Controller generate a DMA request on DMA channel 1 again after one sector is compressed. After 1 Kbytes are transferred, the DMA can generate an interrupt to CPU. Responding to the DMA interrupt CPU can restart the CRC routine by generating a software DMA request onto channel 2 again.

#### **12.8.3.3.3 Example: Semi-CPU Mode**

If DMA controller is available in a system the CRC module can also operate in semi-CPU mode. This means that CPU can still make use of the DMA to perform data patterns transfer to CRC controller in the background. The difference between semi-CPU mode and AUTO mode is that CRC controller does not automatically perform the signature verification. CRC controllers generates a compression complete interrupt to CPU when the one sector of data patterns are compressed. CPU needs to perform the signature verification itself.

A memory area with 2 Mbytes is to be verified with the help of the CPU. CRC operation is to be performed every 1 Kbyte. Since there are 2 Mbytes (256 K doublewords) of memory to be check and we want to perform a CRC every 1 Kbytes (128 doublewords) and therefore there must be 2048 pre-recorded CRC values. In Semi-CPU mode, the MCRC64\_0\_CRC\_REGL1/H1 is not updated and contains indeterminate data.

#### **12.8.3.3.3.1 DMA Setup**

- Setup DMA channel 1 with the source address from which the memory area to be verified are mapped. Setup the destination address to the MCRC64\_0\_PSA\_SIGREGL1/H1. Put the starting address at post increment addressing mode and put the destination address at constant address mode. Use hardware DMA request to trigger an entire block transfer for channel 1. Disable autoinitiation for DMA channel 1.

#### **12.8.3.3.3.2 Timer Setup**

The timer can be any general purpose timer which is capable of generating a time-based DMA request.

- Setup Timer to generate DMA request associated with DMA channel 1. For example, software can setup the timer to generate a DMA request every 10 ms.

#### **12.8.3.3.3.3 CRC Setup**

- Program the MCRC64\_0\_CRC\_PCOUNT\_REG1 to 128
- Program the MCRC64\_0\_CRC\_SCOUNT\_REG1 to 2048

- For example, we want the entire 2 Mbytes to be compressed within 5 ms. We can program the block complete timeout pre-load value MCRC64\_0\_CRC\_BCTOPLD1 to 15625 (5 ms / (1 FCLK period × 64)) if CRC is operating at 200 MHz
- Enable AUTO mode and all interrupts.

The timer module first generates a DMA request on DMA channel 1 when it is enabled. When the first incoming data pattern arrives at the MCRC64\_0\_PSA\_SIGREGL1/H1, the CRC controller will compress it. After one sector of data patterns are compressed, the CRC controller generate a compression complete interrupt. Upon responding to the interrupt the CPU would read from the MCRC64\_0\_PSA\_SECSIGREGL1/H1. It is up to the CPU on how to deal with the PSA value just read. It can compare it to a known signature value or it can write it to another memory location to build a signature file or even transfer the signature out of the device via SCI or SPI. This routine will continue until the entire 2 Mbytes are consumed. The latency of the interrupt response from CPU can cause overrun condition. If CPU does not read from MCRC64\_0\_PSA\_SECSIGREGL1 before the PSA value is overridden with the signature of the next sector of memory, an overrun interrupt will be generated by CRC controller.

#### **12.8.3.3.4 Example: Full-CPU Mode**

In a system without the availability of DMA controller, the CRC routine can be operated by CPU provided the CPU has enough throughput. CPU needs to read from the memory area from which CRC is to be performed.

A memory area with 2 Mbytes is to be checked with the help of the CPU. CRC operation is to be performed every 1 Kbyte. In CPU mode, the MCRC64\_0\_CRC\_REGL1/H1 is not updated and contains indeterminate data.

##### **12.8.3.3.4.1 CRC Setup**

- All control registers can be left in their reset state. Only enable Full-CPU mode.

CPU itself reads from the memory and write the data to the MCRC64\_0\_PSA\_SIGREGL1/H1 inside MCRC Controller. When the first incoming data pattern arrives at the MCRC64\_0\_PSA\_SIGREGL1/H1, the MCRC Controller will compress it. After n data patterns are compressed, CPU can read from the MCRC64\_0\_PSA\_SIGREGL1/H1. It is up to the CPU on how to deal with the PSA signature value just read. It can compare it to a known signature value stored at another memory location.

## 12.8.4 ECC Aggregator

This section describes the common ECC aggregator functionality.

### 12.8.4.1 ECC Aggregator Overview

To increase functional and system reliability the memories (for example, FIFOs, queues, SRAMs and others) in many device modules and subsystems are protected by error correcting code (ECC). This is accomplished through an ECC aggregator and ECC wrapper. The ECC aggregator is connected to these memories (hereinafter ECC RAMs) and involved in the ECC process. Each memory is surrounded by an ECC wrapper which performs the ECC detection and correction. The wrapper communicates via serial interface with the aggregator which has memory mapped configuration interface.

The ECC aggregator is also connected to interconnect ECC components that protect the command, address and data buses of the system interconnect. ECC is calculated for the data bus and parity and redundancy for the command and address buses. Each interconnect ECC component has the same serial interface for communication with the aggregator as the ECC wrapper. An ECC aggregator may be connected to both endpoints - the ECC wrapper and interconnect ECC component.

The ECC aggregator, ECC wrapper and interconnect ECC component are considered as single entity and are hereinafter referred to as ECC aggregator unless otherwise explicitly specified.

See *Module Integration* for device modules and subsystems which have ECC aggregator.

#### 12.8.4.1.1 ECC Aggregator Features

The ECC aggregator has the following features:

- Reduces memory software errors via single error correction (SEC) and double error detection (DED)
- Provides a mechanism to control and monitor the ECC protected memories in a module or subsystem
- SEC and DED over the system interconnect data bus and parity and redundancy for the system interconnect command and address buses
- Generates an interrupt for correctable error
- Generates an interrupt for non-correctable error
- Supports inject only mode for diagnostic purposes
- Supports software readable status for single and double-bit ECC errors and associated information such as row address where error has occurred and data bits that have been flipped
- Supports up to 256 ECC endpoints. An ECC endpoint can be either ECC RAM or interconnect ECC component.
- Detects single bit error via parity checking on:
  - Memory mapped configuration interface FIFO
  - Serial interface FIFO
  - Serial interface transaction
- Single bit error detection via parity checking results in a non-correctable error interrupt
- Supports timeout mechanism on transactions over the ECC serial interface. Timeout occurrence results in a non-correctable error interrupt.
- Certain control bits have redundancy and if a bit flips an interrupt is generated

#### 12.8.4.1.2 Unsupported Features

See the *Module Integration* section for information about unsupported features.

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### 12.8.4.2 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

### 12.8.4.3 ECC Aggregator Functional Description

This section describes the architecture and functional details of the ECC aggregator.

#### 12.8.4.3.1 ECC Aggregator Block Diagram

Figure 12-451 shows the ECC aggregator block diagram.



**Figure 12-451. ECC Aggregator Block Diagram**

The ECC aggregator is connected to one or more ECC endpoints each of which has assigned a unique ID used when the endpoint is accessed for status information or configuration. The ECC aggregator provides software access to all ECC related registers through its memory mapped target configuration interface while the serial interface is used to communicate with the ECC endpoints. Upon detection of single or double-bit error the corresponding interrupt line is asserted.

#### 12.8.4.3.2 ECC Aggregator Register Groups

The ECC aggregator has ECC control, status and interrupt registers for each ECC endpoint in a module or subsystem. These registers are memory mapped and occupy 1 KB address space although part of it may contain reserved locations. The registers are split in the following types:

- **Global registers.** They are common to all ECC endpoints associated with the ECC aggregator and include the ECC\_VECTOR and ECC\_REV registers. Each ECC endpoint has assigned a unique ID. When this ID is written to the ECC\_VECTOR[10-0] ECC\_VECTOR field the corresponding endpoint is selected either for control or for status reading.
- **ECC control and status registers.** These registers are specific to each ECC endpoint and reside in the range from address offset 0x10 to 0x28, if the endpoint is ECC RAM or from 0x10 to 0x24, if the endpoint is interconnect ECC component. They are memory mapped but are accessed through the ECC serial interface. They are also selected by the ECC endpoint ID written to the ECC\_VECTOR[10-0] ECC\_VECTOR field. Because of latency on the serial interface the ECC control and status registers are read by performing special sequence as described in [Section 12.8.4.3.3](#). These registers have also different functionality for both types of endpoints - ECC RAM and interconnect ECC component.
- **Interrupt registers.** They include interrupt status, interrupt enable, interrupt disable, and EOI registers. For more information, see *Interrupts*.

---

#### Note

For description of each register, see *ECC\_AGG Registers*.

---

#### 12.8.4.3.3 Read Access to the ECC Control and Status Registers

Read accesses to the ECC control and status registers for each ECC endpoint represent read operations over the ECC serial interface and are triggered by performing the following sequence:

1. Software writes the following in the ECC\_VECTOR register:
  - The ECC endpoint ID in the ECC\_VECTOR[10-0] ECC\_VECTOR field to select particular ECC endpoint.
  - The register read address in the ECC\_VECTOR[23-16] RD\_SVBU ADDRESS field to select which register has to be read through the ECC serial interface.
  - A value of 0x1 in the ECC\_VECTOR[15] RD\_SVBU bit to trigger read operation through the ECC serial interface.
2. Software polls the ECC\_VECTOR[24] RD\_SVBU\_DONE bit to check if it is 0x1. This indicates that the read operation on the ECC serial interface has completed.
3. Software reads the data from the register previously selected by the ECC\_VECTOR[23-16] RD\_SVBU ADDRESS field.

The following is an example for serial read operation:

1. Write 0x00~~10~~ 8005 to the ECC\_VECTOR register. This sends read request to the ECC\_WRAP\_REV or ECC\_CBASS\_REV register (address = 0x10) associated with ECC endpoint with ID = 5.
2. Poll the ECC\_VECTOR[24] RD\_SVBU\_DONE bit until value of 0x1 is read.
3. Read the ECC\_WRAP\_REV or ECC\_CBASS\_REV register to get its value.

#### 12.8.4.3.4 Serial Write Operation

Write operations over the ECC serial interface are performed as follows:

1. Software specifies the ECC endpoint ID in the ECC\_VECTOR[10-0] ECC\_VECTOR field. The ECC\_VECTOR[23-16] RD\_SVBU ADDRESS field is a don't care but the ECC\_VECTOR[15] RD\_SVBU bit must be set to 0x0.
2. Software performs regular write operation to the desired address. If the ECC endpoint ID has already been specified, step 1 can be skipped. Unlike serial read operations it is not necessary to always specify the endpoint ID before performing serial write operation.

The following is an example for serial write operation:

1. Write 0x0000 0008 to the ECC\_VECTOR register.
2. Write 0x0000 000F to the ECC\_CTRL register. This sends write request with data 0x0000 000F to the ECC\_CTRL register associated with ECC RAM with ID = 8.

#### 12.8.4.3.5 Interrupts

The ECC aggregator generates the following interrupts:

- Correctable interrupt (ECC\_SEC\_INT) where hardware can correct the error but notifies the system in case of SEC.
- Non-correctable interrupt (ECCDED\_INT) where hardware cannot correct the error in cases of DED, parity check, redundancy check or timeout occurrence.

The following is the sequence for servicing interrupts:

- Software enables the interrupts for an ECC endpoint by writing 0x1 to the corresponding bit of the following interrupt enable registers:
  - ECC\_SEC\_ENABLE\_SET\_REG0 through ECC\_SEC\_ENABLE\_SET\_REG7 for the correctable interrupt
  - ECCDED\_ENABLE\_SET\_REG0 through ECCDED\_ENABLE\_SET\_REG7 for the non-correctable interrupt
- On receiving an interrupt, software checks which ECC endpoint has caused the error by reading the following interrupt status registers:

- ECC\_SEC\_STATUS\_REG0 through ECC\_SEC\_STATUS\_REG7 for the correctable interrupt
- ECCDED\_STATUS\_REG0 through ECCDED\_STATUS\_REG7 for the non-correctable interrupt
- Software performs serial read operations as described in [Section 12.8.4.3.3](#) to read the following status registers that contain details about the error:
  - If the endpoint is ECC RAM:
    - ECC\_ERR\_STAT1
    - ECC\_ERR\_STAT2
    - ECC\_ERR\_STAT3
  - If the endpoint is interconnect ECC component:
    - ECC\_CBASS\_ERR\_STAT1
    - ECC\_CBASS\_ERR\_STAT2
- After the interrupt has been serviced, depending on the error type, software should clear the corresponding status bits in the ECC\_ERR\_STAT1 and ECC\_ERR\_STAT3 registers or in the ECC\_CBASS\_ERR\_STAT1 register. Software has to poll these registers to guarantee that status bits are cleared as there is no other indication for write completion over the ECC serial interface. The value of the \*\_PEND\_CLR fields in the ECC\_CBASS\_ERR\_STAT1 register must be read and then written back to decrement the count of each field back to 0x0. A further error capture into the ECC\_CBASS\_ERR\_STAT1 register does not occur unless all its fields are 0x0. The decrement value should not be larger than the read value. If a field in the ECC\_CBASS\_ERR\_STAT1 register should not be modified, write a value of 0x0 to that field.
- Software writes 0x1 to the corresponding end of interrupt register to clear the interrupt:
  - ECC\_SEC\_EOI\_REG for the correctable interrupt
  - ECCDED\_EOI\_REG for the non-correctable interrupt

#### 12.8.4.3.6 Inject Only Mode

There are modules that already perform the ECC generation and checking as part of their data path. In this case, the ECC wrapper may be configured in inject only mode, if needed. In this mode the ECC wrapper does not perform ECC detection and correction. The inject only mode allows users to inject single or double-bit errors so that the module logic can be tested for diagnostic purposes.

---

#### Note

There is no software control to enable inject only mode. It is configured via tie-off value. Inject only and ECC modes are mutually exclusive.

The interconnect ECC component also supports error injection mode. There is error injection logic for testing of the error checking logic (checkers). The injection logic can be configured to inject either single or double bit error and what data pattern to be used for injection (ECC\_CBASS\_CTRL[11-8] ECC\_PATTERN). The ECC\_CBASS\_ERR\_CTRL1 and ECC\_CBASS\_ERR\_CTRL2 registers should be written first to setup the injection. Then, either the ECC\_CBASS\_CTRL[3] FORCE\_SE or the ECC\_CBASS\_CTRL[4] FORCE\_DE bit must be set to 0x1 to start the injection. Both bits must not be set at the same time. If the injection should continue in incrementing mode, then the ECC\_CBASS\_CTRL[5] FORCE\_N\_BIT bit should be set to 0x1. Once the FORCE\_N\_BIT is set, then each successive injection can simply write the ECC\_CBASS\_CTRL register to set the FORCE\_SE or FORCE\_DE again. Reading 0x0 from either the FORCE\_SE or the FORCE\_DE bit indicates that the injection has completed, as these bits automatically clear when the checker indicates that it has performed the injection. The time for an injection to complete is not guaranteed, so some delay is needed between successive injections.

#### 12.8.4.4 ECC Aggregator Configurations

**Table 12-351. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S_VBUS | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |

**Table 12-351. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)**

| RAM ID Name                                         | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|-----------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_SV<br>BUS  | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S<br>VBUS  | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU0_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_SV<br>BUS  | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU0_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SV<br>BUS       | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU0_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SV<br>BUS       | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SV<br>BUS     | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SV<br>BUS     | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SV<br>BUS     | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SV<br>BUS     | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SV<br>BUS     | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SV<br>BUS     | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SV<br>BUS     | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DDATA_SPRAM_BANK7_ECC_SV<br>BUS     | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SVBU<br>S      | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SVBU<br>S      | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SVBU<br>S      | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SVBU<br>S      | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU0_A53_DUAL_U_DDIRTY_SPRAM_ECC_SV<br>BUS          | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SV<br>BUS       | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SV<br>BUS       | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SV<br>BUS       | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SV<br>BUS       | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC<br>_SVBUS | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC<br>_SVBUS | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC<br>_SVBUS | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU0_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC<br>_SVBUS | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S<br>VBUS  | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_SV<br>BUS  | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S<br>VBUS  | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |

**Table 12-351. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)**

| RAM ID Name                                         | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|-----------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU1_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_SV<br>BUS  | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU1_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SV<br>BUS       | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU1_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SV<br>BUS       | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SV<br>US      | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SV<br>US      | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SV<br>US      | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SV<br>US      | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SV<br>US      | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SV<br>US      | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SV<br>US      | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DDATA_SPRAM_BANK7_ECC_SV<br>US      | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SVBU<br>S      | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SVBU<br>S      | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SVBU<br>S      | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SVBU<br>S      | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU1_A53_DUAL_U_DDIRTY_SPRAM_ECC_SV<br>BUS          | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SV<br>BUS       | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SV<br>BUS       | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SV<br>BUS       | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SV<br>BUS       | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC<br>_SVBUS | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC<br>_SVBUS | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC<br>_SVBUS | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU1_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC<br>_SVBUS | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S<br>VBUS  | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_SV<br>BUS  | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S<br>VBUS  | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU2_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_SV<br>BUS  | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU2_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SV<br>BUS       | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU2_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SV<br>BUS       | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |

**Table 12-351. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SVB_US    | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SVB_US    | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SVB_US    | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SVB_US    | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SVB_US    | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SVB_US    | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SVB_US    | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DDATA_SPRAM_BANK7_ECC_SVB_US    | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SVBU_S     | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SVBU_S     | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SVBU_S     | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SVBU_S     | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU2_A53_DUAL_U_DDIRTY_SPRAM_ECC_SVBU           | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SVBU        | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SVBU        | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SVBU        | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SVBU        | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC_SVBU  | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC_SVBU  | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC_SVBU  | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU2_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC_SVBU  | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK0_LO_ECC_S_VBUS | 0      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK0_HI_ECC_S_VBUS | 1      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK1_LO_ECC_S_VBUS | 2      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_IDATA_SPRAM_BANK1_HI_ECC_S_VBUS | 3      | ECC Wrapper | Inject only | Yes             | 42        | 10 KB    |
| CPU3_A53_DUAL_U_ITAG_SPRAM_RAM0_ECC_SVBU        | 4      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU3_A53_DUAL_U_ITAG_SPRAM_RAM1_ECC_SVBU        | 5      | ECC Wrapper | Inject only | Yes             | 32        | 1 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK0_ECC_SVB_US    | 6      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK1_ECC_SVB_US    | 7      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |

**Table 12-351. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)**

| RAM ID Name                                        | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|----------------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK2_ECC_SVB<br>US    | 8      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK3_ECC_SVB<br>US    | 9      | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK4_ECC_SVB<br>US    | 10     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK5_ECC_SVB<br>US    | 11     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK6_ECC_SVB<br>US    | 12     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DDATA_SPRAM_BANK7_ECC_SVB<br>US    | 13     | ECC Wrapper | Inject only | Yes             | 39        | 5 KB     |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK0_ECC_SVBU<br>S     | 14     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK1_ECC_SVBU<br>S     | 15     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK2_ECC_SVBU<br>S     | 16     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DTAG_SPRAM_BANK3_ECC_SVBU<br>S     | 17     | ECC Wrapper | Inject only | Yes             | 31        | 496 B    |
| CPU3_A53_DUAL_U_DDIRTY_SPRAM_ECC_SVBU              | 18     | ECC Wrapper | Inject only | Yes             | 12        | 384 B    |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK0_ECC_SVBU           | 19     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK1_ECC_SVBU           | 20     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK2_ECC_SVBU           | 21     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_TLB_SPRAM_BANK3_ECC_SVBU           | 22     | ECC Wrapper | Inject only | Yes             | 117       | 3 KB     |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY0_ECC<br>_SVBU | 23     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY1_ECC<br>_SVBU | 24     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY2_ECC<br>_SVBU | 25     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| CPU3_A53_DUAL_U_L1D_TAGRAM_SPRAM_WAY3_ECC<br>_SVBU | 26     | ECC Wrapper | Inject only | Yes             | 38        | 608 B    |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY0_ECC_SVBU           | 0      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY1_ECC_SVBU           | 1      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY2_ECC_SVBU           | 2      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY3_ECC_SVBU           | 3      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY4_ECC_SVBU           | 4      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY5_ECC_SVBU           | 5      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY6_ECC_SVBU           | 6      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY7_ECC_SVBU           | 7      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY8_ECC_SVBU           | 8      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY9_ECC_SVBU           | 9      | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY10_ECC_SVBU<br>S     | 10     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY11_ECC_SVBU<br>S     | 11     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY12_ECC_SVBU<br>S     | 12     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |

**Table 12-351. Properties of ECC Aggregator Instance COMPUTE\_CLUSTER0 (continued)**

| RAM ID Name                                 | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|---------------------------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY13_ECC_SVBU_S | 13     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY14_ECC_SVBU_S | 14     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_TAGRAM_SPRAM_WAY15_ECC_SVBU_S | 15     | ECC Wrapper | Inject only | Yes             | 38        | 2 KB     |
| A53_DUAL_U_L2_DATARAM_SPRAM_0_ECC_SVBU_S    | 16     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_1_ECC_SVBU_S    | 17     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_2_ECC_SVBU_S    | 18     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_3_ECC_SVBU_S    | 19     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_4_ECC_SVBU_S    | 20     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_5_ECC_SVBU_S    | 21     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_6_ECC_SVBU_S    | 22     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |
| A53_DUAL_U_L2_DATARAM_SPRAM_7_ECC_SVBU_S    | 23     | ECC Wrapper | Inject only | Yes             | 72        | 72 KB    |

**Table 12-352. Properties of ECC Aggregator Instance CSI\_RX\_IF0**

| RAM ID Name                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_RX_IF_RX_SHIM_DMA_PSIL_FIFO | 1      | ECC Wrapper | Inject with error capture | Yes             | 143       | 36 KB    |
| CSI_RX_IF_RAM_WRAPPER0_FIFO     | 2      | ECC Wrapper | Inject only               | Yes             | 45        | 11 KB    |
| CSI_RX_IF_RAM_WRAPPER1_FIFO     | 3      | ECC Wrapper | Inject only               | Yes             | 45        | 6 KB     |
| CSI_RX_IF_RAM_WRAPPER2_FIFO     | 4      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_RAM_WRAPPER3_FIFO     | 5      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_VP0_VP_FIFO           | 6      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |
| CSI_RX_IF_VP1_VP_FIFO           | 7      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |

**Table 12-353. Properties of ECC Aggregator Instance CSI\_RX\_IF0**

| RAM ID Name          | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------------|--------|------------------|---------------------------|-----------------|------------------------|
| CSI_RX_IF_EDC_CTRL_0 | 0      | EDC Interconnect | Inject with error capture | Yes             | 2                      |

**Table 12-354. EDC checkers information for ECC Aggregator Instance CSI\_RX\_IF0**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CSI_RX_IF_EDC_CTRL_0   | 0        | 32    | Parity       |
| CSI_RX_IF_EDC_CTRL_0   | 1        | 32    | Parity       |

**Table 12-355. Properties of ECC Aggregator Instance CSI\_RX\_IF1**

| RAM ID Name                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_RX_IF_RX_SHIM_DMA_PSIL_FIFO | 1      | ECC Wrapper | Inject with error capture | Yes             | 143       | 36 KB    |
| CSI_RX_IF_RAM_WRAPPER0_FIFO     | 2      | ECC Wrapper | Inject only               | Yes             | 45        | 11 KB    |
| CSI_RX_IF_RAM_WRAPPER1_FIFO     | 3      | ECC Wrapper | Inject only               | Yes             | 45        | 6 KB     |

**Table 12-355. Properties of ECC Aggregator Instance CSI\_RX\_IF1 (continued)**

| RAM ID Name                 | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-----------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_RX_IF_RAM_WRAPPER2_FIFO | 4      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_RAM_WRAPPER3_FIFO | 5      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_VP0_VP_FIFO       | 6      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |
| CSI_RX_IF_VP1_VP_FIFO       | 7      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |

**Table 12-356. Properties of ECC Aggregator Instance CSI\_RX\_IF1**

| RAM ID Name          | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------------|--------|------------------|---------------------------|-----------------|------------------------|
| CSI_RX_IF_EDC_CTRL_0 | 0      | EDC Interconnect | Inject with error capture | Yes             | 2                      |

**Table 12-357. EDC checkers information for ECC Aggregator Instance CSI\_RX\_IF1**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CSI_RX_IF_EDC_CTRL_0   | 0        | 32    | Parity       |
| CSI_RX_IF_EDC_CTRL_0   | 1        | 32    | Parity       |

**Table 12-358. Properties of ECC Aggregator Instance CSI\_RX\_IF2**

| RAM ID Name                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_RX_IF_RX_SHIM_DMA_PSIL_FIFO | 1      | ECC Wrapper | Inject with error capture | Yes             | 143       | 36 KB    |
| CSI_RX_IF_RAM_WRAPPER0_FIFO     | 2      | ECC Wrapper | Inject only               | Yes             | 45        | 11 KB    |
| CSI_RX_IF_RAM_WRAPPER1_FIFO     | 3      | ECC Wrapper | Inject only               | Yes             | 45        | 6 KB     |
| CSI_RX_IF_RAM_WRAPPER2_FIFO     | 4      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_RAM_WRAPPER3_FIFO     | 5      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_VP0_VP_FIFO           | 6      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |
| CSI_RX_IF_VP1_VP_FIFO           | 7      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |

**Table 12-359. Properties of ECC Aggregator Instance CSI\_RX\_IF2**

| RAM ID Name          | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------------|--------|------------------|---------------------------|-----------------|------------------------|
| CSI_RX_IF_EDC_CTRL_0 | 0      | EDC Interconnect | Inject with error capture | Yes             | 2                      |

**Table 12-360. EDC checkers information for ECC Aggregator Instance CSI\_RX\_IF2**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CSI_RX_IF_EDC_CTRL_0   | 0        | 32    | Parity       |
| CSI_RX_IF_EDC_CTRL_0   | 1        | 32    | Parity       |

**Table 12-361. Properties of ECC Aggregator Instance CSI\_RX\_IF3**

| RAM ID Name                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_RX_IF_RX_SHIM_DMA_PSIL_FIFO | 1      | ECC Wrapper | Inject with error capture | Yes             | 143       | 36 KB    |
| CSI_RX_IF_RAM_WRAPPER0_FIFO     | 2      | ECC Wrapper | Inject only               | Yes             | 45        | 11 KB    |
| CSI_RX_IF_RAM_WRAPPER1_FIFO     | 3      | ECC Wrapper | Inject only               | Yes             | 45        | 6 KB     |
| CSI_RX_IF_RAM_WRAPPER2_FIFO     | 4      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_RAM_WRAPPER3_FIFO     | 5      | ECC Wrapper | Inject only               | Yes             | 44        | 352 B    |
| CSI_RX_IF_VP0_VP_FIFO           | 6      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |
| CSI_RX_IF_VP1_VP_FIFO           | 7      | ECC Wrapper | Inject with error capture | Yes             | 36        | 9 KB     |

**Table 12-362. Properties of ECC Aggregator Instance CSI\_RX\_IF3**

| RAM ID Name          | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------------|--------|------------------|---------------------------|-----------------|------------------------|
| CSI_RX_IF_EDC_CTRL_0 | 0      | EDC Interconnect | Inject with error capture | Yes             | 2                      |

**Table 12-363. EDC checkers information for ECC Aggregator Instance CSI\_RX\_IF3**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CSI_RX_IF_EDC_CTRL_0   | 0        | 32    | Parity       |
| CSI_RX_IF_EDC_CTRL_0   | 1        | 32    | Parity       |

**Table 12-364. Properties of ECC Aggregator Instance CSI\_TX\_IF0**

| RAM ID Name                                                           | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-----------------------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CSI_TX_IF_V2_TX_SHIM_DMA_PSIL_FIFO                                    | 1      | ECC Wrapper | Inject with error capture | Yes             | 143       | 36 KB    |
| CSI_TX_IF_V2_TX_SHIM_KSDMA_PSIL_ENDPT_IPCFIFO_F0_TPRAM_256X167_SBW_SR | 2      | ECC Wrapper | Inject with error capture | Yes             | 167       | 5 KB     |
| CSI_TX_IF_V2_RAM_WRAPPER0_FIFO                                        | 0      | ECC Wrapper | Inject only               | Yes             | 44        | 22 KB    |
| CSI_TX_IF_V2_RAM_WRAPPER1_FIFO                                        | 1      | ECC Wrapper | Inject only               | Yes             | 44        | 6 KB     |

**Table 12-365. Properties of ECC Aggregator Instance CSI\_TX\_IF0**

| RAM ID Name             | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|-------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| CSI_TX_IF_V2_EDC_CTRL_0 | 0      | EDC Interconnect | Inject with error capture | Yes             | 4                      |

**Table 12-366. EDC checkers information for ECC Aggregator Instance CSI\_TX\_IF0**

| Protected Interconnect  | Group ID | Width | Checker Type |
|-------------------------|----------|-------|--------------|
| CSI_TX_IF_V2_EDC_CTRL_0 | 0        | 32    | Parity       |
| CSI_TX_IF_V2_EDC_CTRL_0 | 1        | 32    | Parity       |
| CSI_TX_IF_V2_EDC_CTRL_0 | 2        | 32    | Parity       |
| CSI_TX_IF_V2_EDC_CTRL_0 | 3        | 32    | Parity       |

**Table 12-367. Properties of ECC Aggregator Instance DSS\_DSI0**

| RAM ID Name                                | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|--------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| K3_DSS_DSI_TOP_DSI_EDC_CTRL_SYS_EDC_CTRL_0 | 0      | EDC Interconnect | Inject with error capture | Yes             | 2                      |

**Table 12-368. EDC checkers information for ECC Aggregator Instance DSS\_DSI0**

| Protected Interconnect                         | Group ID | Width | Checker Type |
|------------------------------------------------|----------|-------|--------------|
| K3_DSS_DSI_DSI_TOP_DSI_EDC_CTRL_SYS_EDC_CTRL_0 | 0        | 32    | Parity       |
| K3_DSS_DSI_DSI_TOP_DSI_EDC_CTRL_SYS_EDC_CTRL_0 | 1        | 32    | Parity       |

**Table 12-369. Properties of ECC Aggregator Instance FSS0**

| RAM ID Name         | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| OSPI_OSPI_WRAP_SRAM | 0      | ECC Wrapper | Inject with error capture | Yes             | 32        | 1 KB     |

**Table 12-370. Properties of ECC Aggregator Instance GICSS0**

| RAM ID Name | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|-------------|--------|-------------|-------------|-----------------|-----------|----------|
| ICB_RAMECC  | 0      | ECC Wrapper | Inject only | No              | 16        | 640 B    |
| ITE_RAMECC  | 1      | ECC Wrapper | Inject only | No              | 58        | 464 B    |
| LPI_RAMECC  | 2      | ECC Wrapper | Inject only | No              | 26        | 208 B    |

**Table 12-371. Properties of ECC Aggregator Instance MCAN0**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MCANSS_MSGMEM_WRAP_MSGMEM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 17 KB    |

**Table 12-372. Properties of ECC Aggregator Instance MCAN0**

| RAM ID Name    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------|--------|------------------|---------------------------|-----------------|------------------------|
| CTRL_EDC_VBUSS | 1      | EDC Interconnect | Inject with error capture | Yes             | 1                      |

**Table 12-373. EDC checkers information for ECC Aggregator Instance MCAN0**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CTRL_EDC_VBUSS         | 0        | 32    | Parity       |

**Table 12-374. Properties of ECC Aggregator Instance MCAN1**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MCANSS_MSGMEM_WRAP_MSGMEM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 17 KB    |

**Table 12-375. Properties of ECC Aggregator Instance MCAN1**

| RAM ID Name    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------|--------|------------------|---------------------------|-----------------|------------------------|
| CTRL_EDC_VBUSS | 1      | EDC Interconnect | Inject with error capture | Yes             | 1                      |

**Table 12-376. EDC checkers information for ECC Aggregator Instance MCAN1**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CTRL_EDC_VBUSS         | 0        | 32    | Parity       |

**Table 12-377. Properties of ECC Aggregator Instance MCU\_ECC\_AGGR1**

| RAM ID Name                                                  | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|--------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC      | 0      | EDC Interconnect | Inject with error capture | Yes             | 69                     |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC       | 1      | EDC Interconnect | Inject with error capture | Yes             | 65                     |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC      | 2      | EDC Interconnect | Inject with error capture | Yes             | 69                     |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_CFG_G_SLV_DST_BUSECC | 3      | EDC Interconnect | Inject with error capture | Yes             | 4                      |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC      | 4      | EDC Interconnect | Inject with error capture | Yes             | 15                     |
| ISAM62A_MCU_PULSAR_UL_BR_IECC_AGGR_CFG_DST_BUSECC            | 5      | EDC Interconnect | Inject with error capture | Yes             | 4                      |
| SAM62A_MCU_PULSAR_UL_ECC_AGGR_EDC_CTRL                       | 6      | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 12-378. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR1**

| Protected Interconnect                                  | Group ID | Width | Checker Type |
|---------------------------------------------------------|----------|-------|--------------|
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 0        | 24    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 1        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 2        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 3        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 4        | 36    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 5        | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 6        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 7        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 8        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 9        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 10       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 11       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 12       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 13       | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 14       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 15       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 16       | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 17       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 18       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 19       | 1     | Parity       |

**Table 12-378. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR1 (continued)**

| Protected Interconnect                                  | Group ID | Width | Checker Type |
|---------------------------------------------------------|----------|-------|--------------|
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 20       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 21       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 22       | 10    | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 23       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 24       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 25       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 26       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 27       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 28       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 29       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 30       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 31       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 32       | 4     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 33       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 34       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 35       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 36       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 37       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 38       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 39       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 40       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 41       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 42       | 8     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 43       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 44       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 45       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 46       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 47       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 48       | 5     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 49       | 4     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 50       | 2     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 51       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 52       | 4     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 53       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 54       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 55       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 56       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 57       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 58       | 7     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 59       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 60       | 4     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 61       | 4     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 62       | 1     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 63       | 3     | Parity       |
| ISAM62A MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 64       | 1     | Parity       |

**Table 12-378. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR1 (continued)**

| Protected Interconnect                                  | Group ID | Width | Checker Type |
|---------------------------------------------------------|----------|-------|--------------|
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 65       | 5     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 66       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 67       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_RMST_SRC_BUSECC | 68       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 0        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 1        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 2        | 9     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 3        | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 4        | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 5        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 6        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 7        | 23    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 8        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 9        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 10       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 11       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 12       | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 13       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 14       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 15       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 16       | 9     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 17       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 18       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 19       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 20       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 21       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 22       | 9     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 23       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 24       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 25       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 26       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 27       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 28       | 2     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 29       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 30       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 31       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 32       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 33       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 34       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 35       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 36       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 37       | 5     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 38       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 39       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 40       | 4     | Parity       |

**Table 12-378. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR1 (continued)**

| Protected Interconnect                                  | Group ID | Width | Checker Type |
|---------------------------------------------------------|----------|-------|--------------|
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 41       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 42       | 2     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 43       | 2     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 44       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 45       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 46       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 47       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 48       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 49       | 2     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 50       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 51       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 52       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 53       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 54       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 55       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 56       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 57       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 58       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 59       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 60       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 61       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 62       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 63       | 5     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_SLV_DST_BUSECC  | 64       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 0        | 24    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 1        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 2        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 3        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 4        | 36    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 5        | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 6        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 7        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 8        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 9        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 10       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 11       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 12       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 13       | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 14       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 15       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 16       | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 17       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 18       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 19       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 20       | 1     | Parity       |

**Table 12-378. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR1 (continued)**

| Protected Interconnect                                  | Group ID | Width | Checker Type |
|---------------------------------------------------------|----------|-------|--------------|
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 21       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 22       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 23       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 24       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 25       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 26       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 27       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 28       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 29       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 30       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 31       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 32       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 33       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 34       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 35       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 36       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 37       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 38       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 39       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 40       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 41       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 42       | 8     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 43       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 44       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 45       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 46       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 47       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 48       | 5     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 49       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 50       | 2     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 51       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 52       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 53       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 54       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 55       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 56       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 57       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 58       | 7     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 59       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 60       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 61       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 62       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 63       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 64       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC | 65       | 5     | Parity       |

**Table 12-378. EDC checkers information for ECC Aggregator Instance MCU\_ECC\_AGGR1 (continued)**

| Protected Interconnect                                     | Group ID | Width | Checker Type |
|------------------------------------------------------------|----------|-------|--------------|
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC    | 66       | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC    | 67       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_M2M_CPU0_WMST_SRC_BUSECC    | 68       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_CFG_SLV_DST_BUSECC | 0        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_CFG_SLV_DST_BUSECC | 1        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_CFG_SLV_DST_BUSECC | 2        | 11    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_CFG_SLV_DST_BUSECC | 3        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 0        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 1        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 2        | 36    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 3        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 4        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 5        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 6        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 7        | 2     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 8        | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 9        | 1     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 10       | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 11       | 5     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 12       | 3     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 13       | 4     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_ICPU0_P2P_CPU0_PMST_SRC_BUSECC    | 14       | 2     | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_IECC_AGGR_CFG_DST_BUSECC          | 0        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_IECC_AGGR_CFG_DST_BUSECC          | 1        | 1     | Redundant    |
| ISAM62A_MCU_PULSAR_UL_BR_IECC_AGGR_CFG_DST_BUSECC          | 2        | 10    | Parity       |
| ISAM62A_MCU_PULSAR_UL_BR_IECC_AGGR_CFG_DST_BUSECC          | 3        | 3     | Parity       |
| SAM62A_MCU_PULSAR_UL_ECC_AGGR_EDC_CTRL                     | 0        | 1     | Redundant    |
| SAM62A_MCU_PULSAR_UL_ECC_AGGR_EDC_CTRL                     | 1        | 32    | EDC          |
| SAM62A_MCU_PULSAR_UL_ECC_AGGR_EDC_CTRL                     | 2        | 1     | Parity       |
| SAM62A_MCU_PULSAR_UL_ECC_AGGR_EDC_CTRL                     | 3        | 10    | Parity       |
| SAM62A_MCU_PULSAR_UL_ECC_AGGR_EDC_CTRL                     | 4        | 4     | Parity       |
| SAM62A_MCU_PULSAR_UL_ECC_AGGR_EDC_CTRL                     | 5        | 3     | Parity       |

**Table 12-379. Properties of ECC Aggregator Instance MCU\_MCAN0**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MCANSS_MSGMEM_WRAP_MSGMEM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 17 KB    |

**Table 12-380. Properties of ECC Aggregator Instance MCU\_MCAN0**

| RAM ID Name    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------|--------|------------------|---------------------------|-----------------|------------------------|
| CTRL_EDC_VBUSS | 1      | EDC Interconnect | Inject with error capture | Yes             | 1                      |

**Table 12-381. EDC checkers information for ECC Aggregator Instance MCU\_MCAN0**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CTRL_EDC_VBUSS         | 0        | 32    | Parity       |

**Table 12-382. Properties of ECC Aggregator Instance MCU\_MCAN1**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MCANSS_MSGMEM_WRAP_MSGMEM_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 17 KB    |

**Table 12-383. Properties of ECC Aggregator Instance MCU\_MCAN1**

| RAM ID Name    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------|--------|------------------|---------------------------|-----------------|------------------------|
| CTRL_EDC_VBUSS | 1      | EDC Interconnect | Inject with error capture | Yes             | 1                      |

**Table 12-384. EDC checkers information for ECC Aggregator Instance MCU\_MCAN1**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CTRL_EDC_VBUSS         | 0        | 32    | Parity       |

**Table 12-385. Properties of ECC Aggregator Instance MCU\_MSRAM\_256K0**

| RAM ID Name              | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|--------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MSRAM32KX64E_MSRAM0_ECC0 | 0      | ECC Wrapper | Inject with error capture | No              | 64        | 256 KB   |

**Table 12-386. Properties of ECC Aggregator Instance MCU\_MSRAM\_256K0**

| RAM ID Name                    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|--------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 1      | EDC Interconnect | Inject with error capture | Yes             | 65                     |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 2      | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 12-387. EDC checkers information for ECC Aggregator Instance MCU\_MSRAM\_256K0**

| Protected Interconnect         | Group ID | Width | Checker Type |
|--------------------------------|----------|-------|--------------|
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 0        | 1     | Redundant    |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 1        | 12    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 2        | 1     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 3        | 10    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 4        | 18    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 5        | 2     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 6        | 3     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 7        | 12    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 8        | 4     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 9        | 3     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 10       | 1     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 11       | 1     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 12       | 1     | Parity       |

**Table 12-387. EDC checkers information for ECC Aggregator Instance MCU\_MSRAm\_256K0 (continued)**

| Protected Interconnect         | Group ID | Width | Checker Type |
|--------------------------------|----------|-------|--------------|
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 13       | 1     | Redundant    |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 14       | 10    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 15       | 1     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 16       | 1     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 17       | 4     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 18       | 8     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 19       | 1     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 20       | 32    | EDC          |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 21       | 32    | EDC          |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 22       | 1     | Redundant    |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 23       | 1     | Redundant    |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 24       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 25       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 26       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 27       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 28       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 29       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 30       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 31       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 32       | 58    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 33       | 58    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 34       | 20    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 35       | 58    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 36       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 37       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 38       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 39       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 40       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 41       | 8     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 42       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 43       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 44       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 45       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 46       | 56    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 47       | 22    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 48       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 49       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 50       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 51       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 52       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 53       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 54       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 55       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 56       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 57       | 64    | Parity       |

**Table 12-387. EDC checkers information for ECC Aggregator Instance MCU\_MSRAM\_256K0 (continued)**

| Protected Interconnect         | Group ID | Width | Checker Type |
|--------------------------------|----------|-------|--------------|
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 58       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 59       | 30    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 60       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 61       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 62       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 63       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 64       | 36    | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 0        | 1     | Redundant    |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 1        | 32    | EDC          |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 2        | 1     | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 3        | 10    | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 4        | 4     | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 5        | 3     | Parity       |

**Table 12-388. Properties of ECC Aggregator Instance MCU\_MSRAM\_256K1**

| RAM ID Name              | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|--------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| MSRAM32KX64E_MSRAM0_ECC0 | 0      | ECC Wrapper | Inject with error capture | No              | 64        | 256 KB   |

**Table 12-389. Properties of ECC Aggregator Instance MCU\_MSRAM\_256K1**

| RAM ID Name                    | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|--------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 1      | EDC Interconnect | Inject with error capture | Yes             | 65                     |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 2      | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 12-390. EDC checkers information for ECC Aggregator Instance MCU\_MSRAM\_256K1**

| Protected Interconnect         | Group ID | Width | Checker Type |
|--------------------------------|----------|-------|--------------|
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 0        | 1     | Redundant    |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 1        | 12    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 2        | 1     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 3        | 10    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 4        | 18    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 5        | 2     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 6        | 3     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 7        | 12    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 8        | 4     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 9        | 3     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 10       | 1     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 11       | 1     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 12       | 1     | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 13       | 1     | Redundant    |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 14       | 10    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 15       | 1     | Parity       |

**Table 12-390. EDC checkers information for ECC Aggregator Instance MCU\_MSRAm\_256K1 (continued)**

| Protected Interconnect         | Group ID | Width | Checker Type |
|--------------------------------|----------|-------|--------------|
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 16       | 1     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 17       | 4     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 18       | 8     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 19       | 1     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 20       | 32    | EDC          |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 21       | 32    | EDC          |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 22       | 1     | Redundant    |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 23       | 1     | Redundant    |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 24       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 25       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 26       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 27       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 28       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 29       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 30       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 31       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 32       | 58    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 33       | 58    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 34       | 20    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 35       | 58    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 36       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 37       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 38       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 39       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 40       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 41       | 8     | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 42       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 43       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 44       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 45       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 46       | 56    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 47       | 22    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 48       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 49       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 50       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 51       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 52       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 53       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 54       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 55       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 56       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 57       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 58       | 64    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 59       | 30    | Parity       |
| MSRAM32KX64E_MSRAm0_EDC_CTRL_0 | 60       | 64    | Parity       |

**Table 12-390. EDC checkers information for ECC Aggregator Instance MCU\_MSRAM\_256K1 (continued)**

| Protected Interconnect         | Group ID | Width | Checker Type |
|--------------------------------|----------|-------|--------------|
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 61       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 62       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 63       | 64    | Parity       |
| MSRAM32KX64E_MSRAM0_EDC_CTRL_0 | 64       | 36    | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 0        | 1     | Redundant    |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 1        | 32    | EDC          |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 2        | 1     | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 3        | 10    | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 4        | 4     | Parity       |
| MSRAM32KX64E_ECC_AGGR_EDC_CTRL | 5        | 3     | Parity       |

**Table 12-391. Properties of ECC Aggregator Instance MCU\_R5FSS0**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CPU0_ITAG_RAM0                | 0      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM1                | 1      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM2                | 2      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM3                | 3      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_IDATA_BANK0              | 4      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK1              | 5      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK2              | 6      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK3              | 7      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_DTAG_RAM0                | 8      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM1                | 9      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM2                | 10     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM3                | 11     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DDIRTY_RAM               | 12     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DDATA_RAM0               | 13     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM1               | 14     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM2               | 15     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM3               | 16     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM4               | 17     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM5               | 18     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM6               | 19     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM7               | 20     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| PULSAR_ULS_ATCM0_BANK0        | 21     | ECC Wrapper | Inject only               | No              | 39        | 20 KB    |
| PULSAR_ULS_ATCM0_BANK1        | 22     | ECC Wrapper | Inject only               | No              | 39        | 20 KB    |
| PULSAR_ULS_B0TCM0_BANK0       | 23     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_ULS_B0TCM0_BANK1       | 24     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_ULS_B1TCM0_BANK0       | 25     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_ULS_B1TCM0_BANK1       | 26     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| CPU0_KS_VIM_RAMECC            | 27     | ECC Wrapper | Inject with error capture | Yes             | 30        | 960 B    |
| CPU0_AXI2VBUSM_MEM_MST_RAMECC | 29     | ECC Wrapper | Inject with error capture | Yes             | 66        | 528 B    |

**Table 12-392. Properties of ECC Aggregator Instance MCU\_R5FSS0**

| RAM ID Name                                                                           | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|---------------------------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| CPU0_VBUSHM2AXI_EDC                                                                   | 28     | EDC Interconnect | Inject with error capture | Yes             | 36                     |
| PULSAR_ULS_MEM_MST0_EDC_CTRL_0                                                        | 30     | EDC Interconnect | Inject with error capture | Yes             | 37                     |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                           | 31     | EDC Interconnect | Inject with error capture | Yes             | 15                     |
| SCRP_EDC                                                                              | 32     | EDC Interconnect | Inject with error capture | Yes             | 26                     |
| PULSAR_ULS_CPU0_CFG_SCP_P_SCP1_SCP_PULSAR_ULS_CPU0_CFG_SCP_P_SCP1_SCP_EDC_CTRL_B_USEC | 33     | EDC Interconnect | Inject with error capture | Yes             | 77                     |
| PULSAR_ULS_CPU0_ECC_AGGR_EDC_CTRL                                                     | 34     | EDC Interconnect | Inject with error capture | Yes             | 6                      |

**Table 12-393. EDC checkers information for ECC Aggregator Instance MCU\_R5FSS0**

| Protected Interconnect | Group ID | Width | Checker Type |
|------------------------|----------|-------|--------------|
| CPU0_VBUSHM2AXI_EDC    | 0        | 1     | Redundant    |
| CPU0_VBUSHM2AXI_EDC    | 1        | 12    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 2        | 4     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 3        | 12    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 4        | 23    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 5        | 1     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 6        | 10    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 7        | 2     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 8        | 3     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 9        | 1     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 10       | 2     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 11       | 2     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 12       | 1     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 13       | 1     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 14       | 1     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 15       | 3     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 16       | 4     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 17       | 2     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 18       | 2     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 19       | 2     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 20       | 1     | Redundant    |
| CPU0_VBUSHM2AXI_EDC    | 21       | 32    | EDC          |
| CPU0_VBUSHM2AXI_EDC    | 22       | 32    | EDC          |
| CPU0_VBUSHM2AXI_EDC    | 23       | 8     | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 24       | 1     | Redundant    |
| CPU0_VBUSHM2AXI_EDC    | 25       | 1     | Redundant    |
| CPU0_VBUSHM2AXI_EDC    | 26       | 10    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 27       | 64    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 28       | 63    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 29       | 17    | Parity       |
| CPU0_VBUSHM2AXI_EDC    | 30       | 10    | Parity       |

**Table 12-393. EDC checkers information for ECC Aggregator Instance MCU\_R5FSS0 (continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| CPU0_VBUSH2AXI_EDC                           | 31       | 7     | Parity       |
| CPU0_VBUSH2AXI_EDC                           | 32       | 8     | Parity       |
| CPU0_VBUSH2AXI_EDC                           | 33       | 8     | Parity       |
| CPU0_VBUSH2AXI_EDC                           | 34       | 64    | Parity       |
| CPU0_VBUSH2AXI_EDC                           | 35       | 56    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 0        | 1     | Redundant    |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 1        | 12    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 2        | 1     | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 3        | 3     | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 4        | 10    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 5        | 4     | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 6        | 32    | EDC          |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 7        | 32    | EDC          |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 8        | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 9        | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 10       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 11       | 48    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 12       | 32    | EDC          |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 13       | 32    | EDC          |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 14       | 32    | EDC          |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 15       | 32    | EDC          |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 16       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 17       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 18       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 19       | 56    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 20       | 2     | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 21       | 2     | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 22       | 1     | Redundant    |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 23       | 1     | Redundant    |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 24       | 3     | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 25       | 10    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 26       | 12    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 27       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 28       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 29       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 30       | 38    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 31       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 32       | 17    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 33       | 8     | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 34       | 12    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 35       | 64    | Parity       |
| PULSAR_ULTS_MEM_MST0_EDC_CTRL_0              | 36       | 20    | Parity       |
| PULSAR_ULTS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0 | 0        | 1     | Redundant    |
| PULSAR_ULTS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0 | 1        | 1     | Redundant    |
| PULSAR_ULTS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0 | 2        | 3     | Parity       |

**Table 12-393. EDC checkers information for ECC Aggregator Instance MCU\_R5FSS0 (continued)**

| Protected Interconnect                                                                   | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------------------|----------|-------|--------------|
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 3        | 32    | EDC          |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 4        | 32    | EDC          |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 5        | 4     | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 6        | 1     | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 7        | 1     | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 8        | 1     | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 9        | 2     | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 10       | 14    | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 11       | 1     | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 12       | 36    | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 13       | 10    | Parity       |
| PULSAR_ULS_PULSAR_AHB2VBUSP_CPU0_EDC_CTRL_0                                              | 14       | 4     | Parity       |
| SCRP_EDC                                                                                 | 0        | 11    | Parity       |
| SCRP_EDC                                                                                 | 1        | 1     | Redundant    |
| SCRP_EDC                                                                                 | 2        | 32    | EDC          |
| SCRP_EDC                                                                                 | 3        | 1     | Redundant    |
| SCRP_EDC                                                                                 | 4        | 8     | Parity       |
| SCRP_EDC                                                                                 | 5        | 4     | Redundant    |
| SCRP_EDC                                                                                 | 6        | 3     | Parity       |
| SCRP_EDC                                                                                 | 7        | 12    | Parity       |
| SCRP_EDC                                                                                 | 8        | 4     | Redundant    |
| SCRP_EDC                                                                                 | 9        | 12    | EDC          |
| SCRP_EDC                                                                                 | 10       | 2     | Parity       |
| SCRP_EDC                                                                                 | 11       | 32    | Parity       |
| SCRP_EDC                                                                                 | 12       | 4     | Parity       |
| SCRP_EDC                                                                                 | 13       | 3     | Parity       |
| SCRP_EDC                                                                                 | 14       | 12    | Parity       |
| SCRP_EDC                                                                                 | 15       | 4     | Parity       |
| SCRP_EDC                                                                                 | 16       | 1     | Redundant    |
| SCRP_EDC                                                                                 | 17       | 1     | Redundant    |
| SCRP_EDC                                                                                 | 18       | 32    | EDC          |
| SCRP_EDC                                                                                 | 19       | 1     | Parity       |
| SCRP_EDC                                                                                 | 20       | 32    | Parity       |
| SCRP_EDC                                                                                 | 21       | 4     | Parity       |
| SCRP_EDC                                                                                 | 22       | 3     | Parity       |
| SCRP_EDC                                                                                 | 23       | 12    | Parity       |
| SCRP_EDC                                                                                 | 24       | 4     | Parity       |
| SCRP_EDC                                                                                 | 25       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 0        | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 1        | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 2        | 1     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 3        | 4     | Parity       |

**Table 12-393. EDC checkers information for ECC Aggregator Instance MCU\_R5FSS0 (continued)**

| Protected Interconnect                                                                      | Group ID | Width | Checker Type |
|---------------------------------------------------------------------------------------------|----------|-------|--------------|
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 4        | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 5        | 1     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 6        | 4     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 7        | 4     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 8        | 2     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 9        | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 10       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 11       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 12       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 13       | 10    | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 14       | 12    | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 15       | 4     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 16       | 4     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 17       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 18       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 19       | 12    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 20       | 4     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 21       | 12    | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 22       | 4     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 23       | 10    | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 24       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 25       | 12    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 26       | 4     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 27       | 12    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 28       | 4     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR<br>P_P_SCR1_SCR_EDC_CTRL_BUSECC | 29       | 1     | Redundant    |

**Table 12-393. EDC checkers information for ECC Aggregator Instance MCU\_R5FSS0 (continued)**

| Protected Interconnect                                                                   | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------------------|----------|-------|--------------|
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 30       | 4     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 31       | 4     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 32       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 33       | 5     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 34       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 35       | 5     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 36       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 37       | 1     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 38       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 39       | 4     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 40       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 41       | 5     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 42       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 43       | 5     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 44       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 45       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 46       | 8     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 47       | 7     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 48       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 49       | 4     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 50       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 51       | 26    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 52       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 53       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 54       | 26    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 55       | 3     | Parity       |

Table 12-393. EDC checkers information for ECC Aggregator Instance MCU\_R5FSS0 (continued)

| Protected Interconnect                                                                   | Group ID | Width | Checker Type |
|------------------------------------------------------------------------------------------|----------|-------|--------------|
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 56       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 57       | 26    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 58       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 59       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 60       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 61       | 26    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 62       | 32    | EDC          |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 63       | 3     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 64       | 1     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 65       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 66       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 67       | 3     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 68       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 69       | 1     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 70       | 1     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 71       | 32    | EDC          |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 72       | 1     | Redundant    |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 73       | 1     | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 74       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 75       | 10    | Parity       |
| PULSAR_ULS_CPU0_CFG_SCRP_P_SCR1_SCR_PULSAR_ULS_CPU0_CFG_SCR_P_P_SCR1_SCR_EDC_CTRL_BUSECC | 76       | 1     | Parity       |
| PULSAR_ULS_CPU0_ECC_AGGR_EDC_CTRL                                                        | 0        | 1     | Redundant    |
| PULSAR_ULS_CPU0_ECC_AGGR_EDC_CTRL                                                        | 1        | 32    | EDC          |
| PULSAR_ULS_CPU0_ECC_AGGR_EDC_CTRL                                                        | 2        | 1     | Parity       |
| PULSAR_ULS_CPU0_ECC_AGGR_EDC_CTRL                                                        | 3        | 10    | Parity       |
| PULSAR_ULS_CPU0_ECC_AGGR_EDC_CTRL                                                        | 4        | 4     | Parity       |
| PULSAR_ULS_CPU0_ECC_AGGR_EDC_CTRL                                                        | 5        | 3     | Parity       |

**Table 12-394. Properties of ECC Aggregator Instance MMCSD0**

| RAM ID Name                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| EMMC8SS_16FFC_SDHC_WRAP_TXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| EMMC8SS_16FFC_SDHC_WRAP_RXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |

**Table 12-395. Properties of ECC Aggregator Instance MMCSD1**

| RAM ID Name              | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|--------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| EMMCS4SS_SDHC_WRAP_RXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| EMMCS4SS_SDHC_WRAP_TXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |

**Table 12-396. Properties of ECC Aggregator Instance MMCSD2**

| RAM ID Name              | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|--------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| EMMCS4SS_SDHC_WRAP_RXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| EMMCS4SS_SDHC_WRAP_TXMEM | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |

**Table 12-397. Properties of ECC Aggregator Instance PCIE0**

| RAM ID Name                                                   | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|---------------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| PCIE_G2X1_64_CORE_DBN_WRAP_RAMS_AXIMIFO                       | 0      | ECC Wrapper | Inject only               | Yes             | 81        | 324 B    |
| PCIE_G2X1_64_CORE_DBN_WRAP_RAMS_AXISIFO                       | 1      | ECC Wrapper | Inject only               | Yes             | 97        | 388 B    |
| PCIE_G2X1_64_CORE_DBN_WRAP_RAMS_DIBRAM                        | 2      | ECC Wrapper | Inject only               | Yes             | 81        | 1 KB     |
| PCIE_G2X1_64_CORE_AXI2VBUSM_MST_KSBUS_AXI2V_BUSM_RDATA_BUFFER | 3      | ECC Wrapper | Inject with error capture | Yes             | 66        | 8 KB     |
| PCIE_G2X1_64_CORE_DBN_WRAP_RAMS_PNP FIFO                      | 0      | ECC Wrapper | Inject only               | Yes             | 45        | 13 KB    |
| PCIE_G2X1_64_CORE_DBN_WRAP_RAMS_RXCPL FIFO                    | 1      | ECC Wrapper | Inject only               | Yes             | 45        | 2 KB     |
| PCIE_G2X1_64_CORE_DBN_WRAP_RAMS_RPLYBUF                       | 2      | ECC Wrapper | Inject only               | Yes             | 45        | 2 KB     |
| PCIE_G2X1_64_CORE_DBN_WRAP_RAMS_AXISRODR                      | 3      | ECC Wrapper | Inject only               | Yes             | 44        | 1 KB     |

**Table 12-398. Properties of ECC Aggregator Instance PDMA1**

| RAM ID Name                                           | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| SAM62_PDMA_UART_PDMA_CORE_TF0_F0_TPRAM_28_X128_SBW_SR | 0      | ECC Wrapper | Inject with error capture | Yes             | 128       | 448 B    |
| SAM62_PDMA_UART_PDMA_CORE_TF0_F1_TPRAM_28_X128_SBW_SR | 1      | ECC Wrapper | Inject with error capture | Yes             | 128       | 448 B    |
| SAM62_PDMA_UART_PDMA_CORE_RF0_F0_TPRAM_28_X144_SBW_SR | 2      | ECC Wrapper | Inject with error capture | Yes             | 144       | 504 B    |
| SAM62_PDMA_UART_PDMA_CORE_RF0_F1_TPRAM_28_X144_SBW_SR | 3      | ECC Wrapper | Inject with error capture | Yes             | 144       | 504 B    |

**Table 12-399. Properties of ECC Aggregator Instance PSRAMECC0**

| RAM ID Name             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| PSRAM256X32E_PSRAM0_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 1 KB     |

**Table 12-400. Properties of ECC Aggregator Instance PSRAMECC1**

| RAM ID Name             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| PSRAM256X32E_PSRAM0_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 1 KB     |

**Table 12-401. Properties of ECC Aggregator Instance R5FSS0**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| CPU0_ITAG_RAM0                                  | 0      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM1                                  | 1      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM2                                  | 2      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM3                                  | 3      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_IDATA_BANK0                                | 4      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK1                                | 5      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK2                                | 6      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK3                                | 7      | ECC Wrapper | Inject only               | No              | 72        | 9 KB     |
| CPU0_DTAG_RAM0                                  | 8      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM1                                  | 9      | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM2                                  | 10     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM3                                  | 11     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DDIRTY_RAM                                 | 12     | ECC Wrapper | Inject only               | Yes             | 28        | 896 B    |
| CPU0_DDATA_RAM0                                 | 13     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM1                                 | 14     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM2                                 | 15     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM3                                 | 16     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM4                                 | 17     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM5                                 | 18     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM6                                 | 19     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM7                                 | 20     | ECC Wrapper | Inject only               | No              | 39        | 5 KB     |
| PULSAR_UL_ATCM0_BANK0                           | 21     | ECC Wrapper | Inject only               | No              | 39        | 20 KB    |
| PULSAR_UL_ATCM0_BANK1                           | 22     | ECC Wrapper | Inject only               | No              | 39        | 20 KB    |
| PULSAR_UL_B0TCM0_BANK0                          | 23     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_B0TCM0_BANK1                          | 24     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_B1TCM0_BANK0                          | 25     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_B1TCM0_BANK1                          | 26     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_PULSAR_KS_VIM_COMMON_CORE0_RAM        | 27     | ECC Wrapper | Inject with error capture | Yes             | 30        | 960 B    |
| PULSAR_UL_MEM_MST0_KSBUS_AXI2VBUSM_RDATA_BUFFER | 28     | ECC Wrapper | Inject with error capture | Yes             | 66        | 528 B    |

**Table 12-402. Properties of ECC Aggregator Instance SA3\_SS0**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| DMSS_HSM_PKTDMA_CFG_CONFIG                      | 1      | ECC Wrapper | Inject with error capture | Yes             | 108       | 432 B    |
| DMSS_HSM_PKTDMA_CFG_STATE                       | 2      | ECC Wrapper | Inject with error capture | Yes             | 256       | 192 B    |
| DMSS_HSM_PKTDMA_TPCFIFO_F0                      | 3      | ECC Wrapper | Inject with error capture | Yes             | 141       | 212 B    |
| DMSS_HSM_PKTDMA_TPCFIFO_F1                      | 4      | ECC Wrapper | Inject with error capture | Yes             | 141       | 212 B    |
| DMSS_HSM_PKTDMA_RPCFIFO_F0                      | 5      | ECC Wrapper | Inject with error capture | Yes             | 128       | 384 B    |
| DMSS_HSM_PKTDMA_RPCFIFO_F1                      | 6      | ECC Wrapper | Inject with error capture | Yes             | 128       | 384 B    |
| DMSS_HSM_PKTDMA_RPCFIFO_WC                      | 7      | ECC Wrapper | Inject with error capture | Yes             | 22        | 132 B    |
| DMSS_HSM_PKTDMA_STATS_STST0                     | 8      | ECC Wrapper | Inject with error capture | Yes             | 96        | 24 B     |
| DMSS_HSM_PKTDMA_STATS_STSR0                     | 9      | ECC Wrapper | Inject with error capture | Yes             | 128       | 64 B     |
| DMSS_HSM_PKTDMA_RINGOCC_CNTR                    | 10     | ECC Wrapper | Inject with error capture | Yes             | 18        | 144 B    |
| DMSS_HSM_INTAGGR_STATREG_SR_SPRAM_8X128_S_WW_SR | 13     | ECC Wrapper | Inject with error capture | Yes             | 128       | 128 B    |
| DMSS_HSM_INTAGGR_COMMON_IM_TPRAM_158X34_S_WW_SR | 14     | ECC Wrapper | Inject with error capture | Yes             | 34        | 672 B    |
| DMSS_HSM_IPCSS_RINGACC_STRAM                    | 17     | ECC Wrapper | Inject with error capture | Yes             | 216       | 162 B    |
| DMSS_HSM_IPCSS_SEC_PROXY_BUF_STRAM              | 18     | ECC Wrapper | Inject with error capture | Yes             | 91        | 182 B    |
| DMSS_HSM_IPCSS_SEC_PROXY_BUFRAM                 | 19     | ECC Wrapper | Inject with error capture | Yes             | 64        | 64 B     |
| DMSS_HSM_IPCSS_MSRAM_ECC0                       | 24     | ECC Wrapper | Inject with error capture | Yes             | 64        | 4 KB     |
| SA3_UL_CM_PKTRAM0_ECC                           | 0      | ECC Wrapper | Inject with error capture | Yes             | 64        | 512 B    |
| SA3_UL_CM_PKTRAM1_ECC                           | 1      | ECC Wrapper | Inject with error capture | Yes             | 64        | 512 B    |
| SA3_UL_CM_PKA_PROG_RAM_ECC                      | 2      | ECC Wrapper | Inject with error capture | Yes             | 24        | 15 KB    |
| SA3_UL_CM_ENCR_CTXRAM_BANK01_ECC                | 3      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_CM_ENCR_CTXRAM_BANK23_ECC                | 4      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_CM_ENCR_CTXRAM_BANK4_ECC                 | 5      | ECC Wrapper | Inject with error capture | Yes             | 256       | 128 B    |
| SA3_UL_CM_AUTH_CTXRAM_BANK01_ECC                | 6      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_CM_AUTH_CTXRAM_BANK23_ECC                | 7      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_CM_AUTH_CTXRAM_BANK45_ECC                | 8      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_CM_AUTH_CTXRAM_BANK67_ECC                | 9      | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |

**Table 12-402. Properties of ECC Aggregator Instance SA3\_SS0 (continued)**

| RAM ID Name                      | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|----------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| SA3_UL_CM_AUTH_CTXRAM_BANK89_ECC | 10     | ECC Wrapper | Inject with error capture | Yes             | 256       | 256 B    |
| SA3_UL_CM_AUTH_CTXRAM_BANK10_ECC | 11     | ECC Wrapper | Inject with error capture | Yes             | 256       | 128 B    |

**Table 12-403. Properties of ECC Aggregator Instance SA3\_SS0**

| RAM ID Name                                                      | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|------------------------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| DMSS_HSM_ECCAGGR_EDC_CTRL                                        | 0      | EDC Interconnect | Inject with error capture | Yes             | 6                      |
| DMSS_HSM_PKTDMA_EDC_CTRL_0                                       | 11     | EDC Interconnect | Inject with error capture | Yes             | 72                     |
| DMSS_HSM_INTAGGR_EDC_CTRL_0                                      | 12     | EDC Interconnect | Inject with error capture | Yes             | 18                     |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0                                | 15     | EDC Interconnect | Inject with error capture | Yes             | 256                    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1                                | 16     | EDC Interconnect | Inject with error capture | Yes             | 57                     |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0                              | 20     | EDC Interconnect | Inject with error capture | Yes             | 67                     |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRI<br>DGE_SRC_EDC_CTRL_0 | 21     | EDC Interconnect | Inject with error capture | Yes             | 72                     |
| DMSS_HSM_IPCSS_CBASS_SCR_EDC_CTRL_0                              | 22     | EDC Interconnect | Inject with error capture | Yes             | 132                    |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0                          | 23     | EDC Interconnect | Inject with error capture | Yes             | 3                      |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0                                  | 25     | EDC Interconnect | Inject with error capture | Yes             | 63                     |
| DMSS_HSM_PSISS_SAUL0_PSIL_SAFEGR_EDC_CTRL_0                      | 26     | EDC Interconnect | Inject with error capture | Yes             | 33                     |
| DMSS_HSM_PSISS_PKTDMA_STRM_SAFEGR_EDC_CTR<br>L_0                 | 27     | EDC Interconnect | Inject with error capture | Yes             | 33                     |
| DMSS_HSM_PSISS_PKTDMA_CFGSTRM_SAFEGR_EDC_<br>CTRL_0              | 28     | EDC Interconnect | Inject with error capture | Yes             | 30                     |
| DMSS_HSM_PSISS_PSIICFG_CFGSTRM_SAFEGR_EDC_<br>CTRL_0             | 29     | EDC Interconnect | Inject with error capture | Yes             | 30                     |
| DMSS_HSM_PSISS_PKTDMA_CFGSTRM_BRIDGE_EDC_<br>CTRL_0              | 30     | EDC Interconnect | Inject with error capture | Yes             | 101                    |
| DMSS_HSM_PSISS_PSIICFG_CFGSTRM_BRIDGE_EDC_<br>CTRL_0             | 31     | EDC Interconnect | Inject with error capture | Yes             | 101                    |
| DMSS_HSM_PSISS_L2P_SAUL0_PSIL_EDC_CTRL_0                         | 32     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSISS_L2P_PKTDMA_STRM_EDC_CTRL_0                        | 33     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSISS_L2P_PKTDMA_CFGSTRM_EDC_CT<br>RL_0                 | 34     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSISS_L2P_INTAGGR_EVT_EDC_CTRL_0                        | 35     | EDC Interconnect | Inject with error capture | Yes             | 2                      |
| DMSS_HSM_PSISS_L2P_INTAGGR_CEVTE_EDC_CTRL_0                      | 36     | EDC Interconnect | Inject with error capture | Yes             | 2                      |
| DMSS_HSM_PSISS_L2P_INTAGGR_MEVT_IN_EDC_CT<br>RL_0                | 37     | EDC Interconnect | Inject with error capture | Yes             | 2                      |

**Table 12-403. Properties of ECC Aggregator Instance SA3\_SS0 (continued)**

| RAM ID Name                                       | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|---------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| DMSS_HSM_PSISS_L2P_PSIICFG_CFGSTRM_EDC_CTRL_0     | 38     | EDC Interconnect | Inject with error capture | Yes             | 35                     |
| DMSS_HSM_PSISS_CFG_EDC_CTRL_0                     | 39     | EDC Interconnect | Inject with error capture | Yes             | 3                      |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0     | 40     | EDC Interconnect | Inject with error capture | Yes             | 106                    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0     | 41     | EDC Interconnect | Inject with error capture | Yes             | 103                    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 42     | EDC Interconnect | Inject with error capture | Yes             | 131                    |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 43     | EDC Interconnect | Inject with error capture | Yes             | 10                     |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 44     | EDC Interconnect | Inject with error capture | Yes             | 7                      |
| DMSS_HSM_CFG_CBASS_SCR_EDC_CTRL_0                 | 45     | EDC Interconnect | Inject with error capture | Yes             | 91                     |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0             | 46     | EDC Interconnect | Inject with error capture | Yes             | 62                     |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0**

| Protected Interconnect     | Group ID | Width | Checker Type |
|----------------------------|----------|-------|--------------|
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 0        | 1     | Redundant    |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 1        | 32    | EDC          |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 2        | 1     | Parity       |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 3        | 10    | Parity       |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 4        | 4     | Parity       |
| DMSS_HSM_ECCAGGR_EDC_CTRL  | 5        | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 0        | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 1        | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 2        | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 3        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 4        | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 5        | 6     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 6        | 6     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 7        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 8        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 9        | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 10       | 18    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 11       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 12       | 16    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 13       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 14       | 16    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 15       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 16       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 17       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 18       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 19       | 8     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect     | Group ID | Width | Checker Type |
|----------------------------|----------|-------|--------------|
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 20       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 21       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 22       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 23       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 24       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 25       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 26       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 27       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 28       | 10    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 29       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 31       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 32       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 33       | 5     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 34       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 35       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 36       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 37       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 38       | 12    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 39       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 40       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 41       | 14    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 42       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 43       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 44       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 45       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 46       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 47       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 48       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 49       | 4     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 50       | 32    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 51       | 10    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 52       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 53       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 54       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 55       | 4     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 56       | 2     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 57       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 58       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 59       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 60       | 8     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 61       | 32    | EDC          |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 62       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 63       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0 | 64       | 10    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 65       | 10    | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 66       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 67       | 1     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 68       | 3     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 69       | 4     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 70       | 2     | Parity       |
| DMSS_HSM_PKTDMA_EDC_CTRL_0        | 71       | 3     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 0        | 3     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 1        | 2     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 2        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 3        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 4        | 64    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 5        | 50    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 6        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 7        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 8        | 56    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 9        | 58    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 10       | 64    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 11       | 50    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 12       | 64    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 13       | 12    | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 14       | 2     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 15       | 2     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 16       | 8     | Parity       |
| DMSS_HSM_INTAGGR_EDC_CTRL_0       | 17       | 28    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 1        | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 3        | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 4        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 6        | 48    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 8        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 10       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 11       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 12       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 13       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 16       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 17       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 18       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 19       | 8     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 20       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 21       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 23       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 25       | 3     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 27       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 28       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 29       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 30       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 31       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 32       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 34       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 35       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 36       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 37       | 32    | EDC          |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 38       | 32    | EDC          |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 40       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 41       | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 42       | 22    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 44       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 45       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 46       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 47       | 1     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 48       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 49       | 3     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 50       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 51       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 52       | 32    | EDC          |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 53       | 32    | EDC          |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 54       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 55       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 56       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 57       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 58       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 59       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 60       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 61       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 62       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 63       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 64       | 12    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 65       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 66       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 67       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 68       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 69       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 70       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 71       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 72       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 73       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 74       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 75       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 76       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 77       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 78       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 79       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 80       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 81       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 82       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 83       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 84       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 85       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 86       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 87       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 88       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 89       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 90       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 91       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 92       | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 93       | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 94       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 95       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 96       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 97       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 98       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 99       | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 100      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 101      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 102      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 103      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 104      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 105      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 106      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 107      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 108      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 109      | 2     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 110      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 111      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 112      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 113      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 114      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 115      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 116      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 117      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 118      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 119      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 120      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 121      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 122      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 123      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 124      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 125      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 126      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 127      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 128      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 129      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 130      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 131      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 132      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 133      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 134      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 135      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 136      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 137      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 138      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 139      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 140      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 141      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 142      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 143      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 144      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 145      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 146      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 147      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 148      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 149      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 150      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 151      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 152      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 153      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 154      | 10    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 155      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 156      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 157      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 158      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 159      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 160      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 161      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 162      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 163      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 164      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 165      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 166      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 167      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 168      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 169      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 170      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 171      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 172      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 173      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 174      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 175      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 176      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 177      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 178      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 179      | 9     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 180      | 32    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 181      | 2     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 182      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 183      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 184      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 185      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 186      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 187      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 188      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 189      | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 190      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 191      | 8     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 192      | 1     | Redundant    |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 193      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 194      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 195      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 196      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 197      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 198      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 199      | 10    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 200      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 201      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 202      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 203      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 204      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 205      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 206      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 207      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 208      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 209      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 210      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 211      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 212      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 213      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 214      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 215      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 216      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 217      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 218      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 219      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 220      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 221      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 222      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 223      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 224      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 225      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 226      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 227      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 228      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 229      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 230      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 231      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 232      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 233      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 234      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 235      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 236      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 237      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 238      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 239      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 240      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 241      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 242      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 243      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 244      | 12    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect            | Group ID | Width | Checker Type |
|-----------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 245      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 246      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 247      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 248      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 249      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 250      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 251      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 252      | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 253      | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 254      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_0 | 255      | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 0        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 1        | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 2        | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 3        | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 4        | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 5        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 6        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 7        | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 8        | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 9        | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 10       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 11       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 12       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 13       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 14       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 15       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 16       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 17       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 18       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 19       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 20       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 21       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 22       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 23       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 24       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 25       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 26       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 27       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 28       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 29       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 30       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 31       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 32       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1 | 33       | 10    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 34       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 35       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 36       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 37       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 38       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 39       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 40       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 41       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 42       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 43       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 44       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 45       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 46       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 47       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 48       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 49       | 10    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 50       | 4     | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 51       | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 52       | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 53       | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 54       | 16    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 55       | 12    | Parity       |
| DMSS_HSM_IPCSS_RINGACC_EDC_CTRL_1   | 56       | 8     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 2        | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 3        | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 4        | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 6        | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 7        | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 8        | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 9        | 2     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 14       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 15       | 14    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 16       | 14    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 17       | 8     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 18       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 19       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 20       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 21       | 4     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect              | Group ID | Width | Checker Type |
|-------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 22       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 23       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 25       | 4     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 26       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 27       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 28       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 29       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 31       | 12    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 32       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 34       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 35       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 36       | 8     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 37       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 38       | 3     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 39       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 40       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 41       | 48    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 42       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 43       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 45       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 46       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 47       | 4     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 48       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 49       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 50       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 51       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 52       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 53       | 4     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 54       | 3     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 55       | 32    | EDC          |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 56       | 32    | EDC          |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 57       | 1     | Redundant    |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 58       | 10    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 59       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 60       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 61       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 62       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 63       | 1     | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 64       | 16    | Parity       |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 65       | 32    | EDC          |
| DMSS_HSM_IPCSS_SEC_PROXY_EDC_CTRL_0 | 66       | 32    | EDC          |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                                       | Group ID | Width | Checker Type |
|--------------------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 0        | 24    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 1        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 3        | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 4        | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 5        | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 6        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 7        | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 8        | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 10       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 11       | 9     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 12       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 13       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 14       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 15       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 16       | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 17       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 18       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 19       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 20       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 21       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 22       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 23       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 25       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 28       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 29       | 9     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 31       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 32       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 34       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 35       | 9     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 36       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 37       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 38       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 39       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 40       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 41       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 43       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 44       | 10    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                                       | Group ID | Width | Checker Type |
|--------------------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 45       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 46       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 47       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 48       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 49       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 50       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 51       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 52       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 53       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 54       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 55       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 56       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 57       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 58       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 59       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 60       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 61       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 62       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 63       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 64       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 65       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 66       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 67       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 68       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 69       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_IPCSS_VBM_DST_M2M_BRIDGE_SRC_EDC_CTRL_0 | 71       | 8     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 1        | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 3        | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 4        | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 5        | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 6        | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 7        | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 8        | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 9        | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 10       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 11       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 12       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 13       | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 14       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 15       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 16       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0                      | 17       | 4     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                  | Group ID | Width | Checker Type |
|-----------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 18       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 20       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 21       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 23       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 24       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 25       | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 27       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 28       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 29       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 30       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 31       | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 33       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 34       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 35       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 36       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 37       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 38       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 40       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 41       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 42       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 43       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 44       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 46       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 47       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 48       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 49       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 50       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 51       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 52       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 53       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 54       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 55       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 56       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 57       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 58       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 59       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 60       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 61       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 62       | 10    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                  | Group ID | Width | Checker Type |
|-----------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 63       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 66       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 67       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 68       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 69       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 70       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 71       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 72       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 73       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 74       | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 75       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 76       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 77       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 78       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 79       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 80       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 81       | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 82       | 12    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 83       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 84       | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 85       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 86       | 7     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 87       | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 88       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 89       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 90       | 7     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 91       | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 92       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 93       | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 94       | 7     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 95       | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 96       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 97       | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 98       | 19    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 99       | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 100      | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 101      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 102      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 103      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 104      | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 105      | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 106      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 107      | 3     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                  | Group ID | Width | Checker Type |
|-----------------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 108      | 19    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 109      | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 110      | 5     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 111      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 112      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 113      | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 114      | 26    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 115      | 6     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 116      | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 117      | 4     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 118      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 119      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 120      | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 121      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 122      | 1     | Redundant    |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 123      | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 124      | 32    | EDC          |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 125      | 32    | EDC          |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 126      | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 127      | 1     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 128      | 23    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 129      | 10    | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 130      | 2     | Parity       |
| DMSS_HSM_IPCSS_CBASS_SCR_SCR_EDC_CTRL_0 | 131      | 3     | Parity       |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0 | 0        | 48    | Parity       |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0 | 1        | 48    | Parity       |
| DMSS_HSM_IPCSS_CBASS_VD2GCLK_EDC_CTRL_0 | 2        | 48    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 0        | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 1        | 12    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 2        | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 3        | 10    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 4        | 12    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 5        | 2     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 6        | 3     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 7        | 12    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 8        | 4     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 9        | 3     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 10       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 11       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 12       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 13       | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 14       | 10    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 15       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 16       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0         | 17       | 4     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect          | Group ID | Width | Checker Type |
|---------------------------------|----------|-------|--------------|
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 18       | 8     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 19       | 1     | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 20       | 32    | EDC          |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 21       | 32    | EDC          |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 23       | 1     | Redundant    |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 24       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 25       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 26       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 27       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 28       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 29       | 38    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 30       | 54    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 31       | 46    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 32       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 33       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 34       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 35       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 36       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 37       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 38       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 39       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 40       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 41       | 34    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 42       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 43       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 44       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 45       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 46       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 47       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 48       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 49       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 50       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 51       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 52       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 53       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 54       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 55       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 56       | 34    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 57       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 58       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 59       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 60       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 61       | 64    | Parity       |
| DMSS_HSM_IPCSS_MSRAM_EDC_CTRL_0 | 62       | 36    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 1        | 16    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 3        | 8     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 4        | 5     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 7        | 4     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 8        | 32    | EDC          |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 9        | 32    | EDC          |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 10       | 32    | EDC          |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 11       | 32    | EDC          |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 16       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 17       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 18       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 19       | 4     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 20       | 3     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 22       | 8     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 23       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 24       | 12    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 25       | 1     | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 27       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 28       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 29       | 1     | Redundant    |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 30       | 16    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 31       | 16    | Parity       |
| DMSS_HSM_PSILSS_SAUL0_PSIL_SAFEG_EDC_CTRL_0  | 32       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 3        | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 4        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 8        | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 9        | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 10       | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0 | 11       | 32    | EDC          |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                          | Group ID | Width | Checker Type |
|-------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 16       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 17       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 18       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 19       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 20       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 22       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 23       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 24       | 12    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 25       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 27       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 28       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 29       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 30       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 31       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_STRM_SAFEG_EDC_CTRL_0    | 32       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 3        | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 4        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 6        | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 8        | 32    | EDC          |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 10       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 16       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 17       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 19       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 20       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 21       | 12    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 22       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEG_EDC_CTRL_0 | 23       | 1     | Redundant    |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 24       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 25       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 27       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 28       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_SAFEGR_EDC_CTRL_0  | 29       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 1        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 3        | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 4        | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 6        | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 8        | 32    | EDC          |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 10       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 16       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 17       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 19       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 20       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 21       | 12    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 22       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 23       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 24       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 25       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 26       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 27       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 28       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_SAFEGR_EDC_CTRL_0 | 29       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 1        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 3        | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 8        | 2     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                           | Group ID | Width | Checker Type |
|--------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 9        | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 12       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 13       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 14       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 15       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 16       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 17       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 20       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 21       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 22       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 23       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 25       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 27       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 28       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 29       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 31       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 32       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 33       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 34       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 35       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 36       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 37       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 38       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 40       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 41       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 44       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 45       | 16    | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 46       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 47       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 48       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 49       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 50       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 51       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 52       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 53       | 1     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                           | Group ID | Width | Checker Type |
|--------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 54       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 55       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 56       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 57       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 58       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 59       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 60       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 61       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 62       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 63       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 64       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 65       | 7     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 66       | 5     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 67       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 68       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 69       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 71       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 72       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 73       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 74       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 75       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 76       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 77       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 78       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 79       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 80       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 81       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 82       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 83       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 84       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 85       | 4     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 86       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 87       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 88       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 89       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 90       | 8     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 91       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 92       | 2     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 93       | 1     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 94       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 95       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 96       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 97       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0 | 98       | 3     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 99       | 3     | Parity       |
| DMSS_HSM_PSILSS_PKTDMA_CFGSTRM_BRIDGE_EDC_CTRL_0  | 100      | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 1        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 3        | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 8        | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 9        | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 12       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 13       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 14       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 15       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 16       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 17       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 18       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 20       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 21       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 22       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 23       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 25       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 26       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 27       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 28       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 29       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 31       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 32       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 33       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 34       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 35       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 36       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 37       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 38       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 39       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 40       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 41       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 42       | 1     | Redundant    |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 44       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 45       | 16    | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 46       | 1     | Redundant    |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 47       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 48       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 49       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 50       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 51       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 52       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 53       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 54       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 55       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 56       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 57       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 58       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 59       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 60       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 61       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 62       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 63       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 64       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 65       | 7     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 66       | 5     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 67       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 68       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 69       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 71       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 72       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 73       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 74       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 75       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 76       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 77       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 78       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 79       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 80       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 81       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 82       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 83       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 84       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 85       | 4     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 86       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 87       | 3     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 88       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 89       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 90       | 8     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 91       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 92       | 2     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 93       | 1     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 94       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 95       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 96       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 97       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 98       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 99       | 3     | Parity       |
| DMSS_HSM_PSILSS_PSILCFG_CFGSTRM_BRIDGE_EDC_CTRL_0 | 100      | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 10       | 10    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 25       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 29       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_SAULO_PSIL_EDC_CTRL_0         | 31       | 3     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0     | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0     | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_SAUL0_PSIL_EDC_CTRL_0     | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 10       | 10    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 25       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 29       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 31       | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_STRM_EDC_CTRL_0    | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0 | 6        | 5     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                           | Group ID | Width | Checker Type |
|--------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 10       | 10    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 25       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 29       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 31       | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PKTDMA_CFGSTRM_EDC_CTRL_0    | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_EVT_EDC_CTRL_0       | 0        | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_EVT_EDC_CTRL_0       | 1        | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_INTAGGR_CEVTEVENT_EDC_CTRL_0 | 0        | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_CEVTEVENT_EDC_CTRL_0 | 1        | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_INTAGGR_MEVT_IN_EDC_CTRL_0   | 0        | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_INTAGGR_MEVT_IN_EDC_CTRL_0   | 1        | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 0        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 1        | 8     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 2        | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 3        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 4        | 1     | Redundant    |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 5        | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 6        | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 7        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 8        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 9        | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0   | 10       | 10    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                         | Group ID | Width | Checker Type |
|------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 11       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 12       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 13       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 14       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 15       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 16       | 32    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 17       | 32    | EDC          |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 18       | 48    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 20       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 21       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 22       | 2     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 23       | 5     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 24       | 4     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 25       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 26       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 28       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 29       | 12    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 30       | 1     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 31       | 3     | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 32       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 33       | 16    | Parity       |
| DMSS_HSM_PSILSS_L2P_PSILCFG_CFGSTRM_EDC_CTRL_0 | 34       | 8     | Parity       |
| DMSS_HSM_PSILSS_CFG_EDC_CTRL_0                 | 0        | 12    | Parity       |
| DMSS_HSM_PSILSS_CFG_EDC_CTRL_0                 | 1        | 12    | Parity       |
| DMSS_HSM_PSILSS_CFG_EDC_CTRL_0                 | 2        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 1        | 48    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 3        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 4        | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 6        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 8        | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 9        | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 12       | 48    | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 14       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 15       | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 16       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 17       | 4     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 18       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 20       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 21       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 23       | 48    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 25       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 26       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 28       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 29       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 31       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 33       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 34       | 48    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 35       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 38       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 39       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 41       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 46       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 47       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 48       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 49       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 50       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 51       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 52       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 53       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 54       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 55       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 56       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 57       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 58       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 59       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 60       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 61       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 62       | 12    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 63       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 66       | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 67       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 68       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 69       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 71       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 72       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 73       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 74       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 75       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 76       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 77       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 78       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 79       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 80       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 81       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 82       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 83       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 84       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 85       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 86       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 87       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 88       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 89       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 90       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 91       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 92       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 93       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 94       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 95       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 96       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 97       | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 98       | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 99       | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 100      | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 101      | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 102      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 103      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 104      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_DATA_SCR1_SCR_EDC_CTRL_0 | 105      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 0        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 1        | 32    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 2        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 3        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 4        | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 5        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 6        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 8        | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 9        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 10       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 11       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 12       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 13       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 14       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 15       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 16       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 17       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 18       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 19       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 20       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 21       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 23       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 25       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 26       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 27       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 28       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 29       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 30       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 31       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 33       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 34       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 35       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 38       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 39       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 41       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 46       | 1     | Redundant    |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 47       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 48       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 49       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 50       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 51       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 52       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 53       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 54       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 55       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 56       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 57       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 58       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 59       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 60       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 61       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 62       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 63       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 66       | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 67       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 68       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 69       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 70       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 71       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 72       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 73       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 74       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 75       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 76       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 77       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 78       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 79       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 80       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 81       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 82       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 83       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 84       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 85       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 86       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 87       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 88       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 89       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 90       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 91       | 5     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 92       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 93       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 94       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 95       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 96       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 97       | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 98       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 99       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 100      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 101      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_RESP_SCR2_SCR_EDC_CTRL_0 | 102      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 0        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 1        | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 2        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 3        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 4        | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 5        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 6        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 7        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 8        | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 9        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 10       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 11       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 12       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 13       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 14       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 15       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 16       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 17       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 18       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 19       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 20       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 21       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 22       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 23       | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 24       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 25       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 26       | 3     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 27       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 28       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 29       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 30       | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 31       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 32       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0  | 33       | 1     | Redundant    |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 34       | 32    | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 35       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 38       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 39       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 41       | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 45       | 32    | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 46       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 47       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 48       | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 49       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 50       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 51       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 52       | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 53       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 54       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 55       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 56       | 32    | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 57       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 58       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 59       | 3     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 60       | 1     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 61       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 62       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 63       | 2     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 64       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 65       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 66       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 67       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 68       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 69       | 12    | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 70       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 71       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 72       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 73       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 74       | 12    | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 75       | 4     | Parity       |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 76       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 77       | 1     | Redundant    |
| DMSS_HSM_PSILSS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 78       | 1     | Redundant    |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                       | Group ID | Width | Checker Type |
|----------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 79       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 80       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 81       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 82       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 83       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 84       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 85       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 86       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 87       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 88       | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 89       | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 90       | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 91       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 92       | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 93       | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 94       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 95       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 96       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 97       | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 98       | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 99       | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 100      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 101      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 102      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 103      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 104      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 105      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 106      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 107      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 108      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 109      | 9     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 110      | 5     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 111      | 6     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 112      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 113      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 114      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 115      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 116      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 117      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 118      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 119      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 120      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 121      | 7     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 122      | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0 | 123      | 1     | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                            | Group ID | Width | Checker Type |
|---------------------------------------------------|----------|-------|--------------|
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 124      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 125      | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 126      | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 127      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 128      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 129      | 10    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_SCR3_SCR_EDC_CTRL_0      | 130      | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 0        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 1        | 1     | Redundant    |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 2        | 32    | EDC          |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 3        | 1     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 4        | 32    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 5        | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 6        | 2     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 7        | 12    | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 8        | 4     | Parity       |
| DMSS_HSM_PSISS_CBASS_ETL_VD2GCLK_EDC_CTRL_0       | 9        | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 0        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 1        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 2        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 3        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 4        | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 5        | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_DMSS_CFG_P2P_BRIDGE_EDC_CTRL_0 | 6        | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 0        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 1        | 23    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 2        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 3        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 4        | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 5        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 6        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 7        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 8        | 2     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 9        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 10       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 11       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 12       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 13       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 14       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 15       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 16       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 17       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 18       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 19       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0             | 20       | 12    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                | Group ID | Width | Checker Type |
|---------------------------------------|----------|-------|--------------|
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 21       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 22       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 23       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 24       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 25       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 26       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 27       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 28       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 29       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 30       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 31       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 33       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 34       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 35       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 37       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 38       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 39       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 40       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 41       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 42       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 44       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 45       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 46       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 47       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 48       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 49       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 50       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 51       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 52       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 53       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 54       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 55       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 56       | 8     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 57       | 9     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 58       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 59       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 60       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 61       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 62       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 63       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 64       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 65       | 26    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                | Group ID | Width | Checker Type |
|---------------------------------------|----------|-------|--------------|
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 66       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 67       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 68       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 69       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 70       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 71       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 72       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 73       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 74       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 75       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 76       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 77       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 78       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 79       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 80       | 26    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 81       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 82       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 83       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 84       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 85       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 86       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 87       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 88       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 89       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_SCR_SCR_EDC_CTRL_0 | 90       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 0        | 48    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 1        | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 2        | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 3        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 4        | 17    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 5        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 6        | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 7        | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 8        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 9        | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 10       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 11       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 12       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 13       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 14       | 2     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 15       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 16       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 17       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 18       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 19       | 22    | Parity       |

**Table 12-404. EDC checkers information for ECC Aggregator Instance SA3\_SS0 (continued)**

| Protected Interconnect                | Group ID | Width | Checker Type |
|---------------------------------------|----------|-------|--------------|
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 20       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 21       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 22       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 23       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 24       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 25       | 10    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 26       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 27       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 28       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 29       | 2     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 30       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 31       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 32       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 33       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 34       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 35       | 17    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 36       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 37       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 38       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 39       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 40       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 41       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 42       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 43       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 44       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 45       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 46       | 9     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 47       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 48       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 49       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 50       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 51       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 52       | 1     | Redundant    |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 53       | 32    | EDC          |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 54       | 1     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 55       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 56       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 57       | 3     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 58       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 59       | 4     | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 60       | 12    | Parity       |
| DMSS_HSM_CFG_CBASS_VD2GCLK_EDC_CTRL_0 | 61       | 1     | Parity       |

**Table 12-405. Properties of ECC Aggregator Instance USB0**

| RAM ID Name                                                             | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| USB2SS_16FFC_USB2SS_CORE_AXI2VBUSM_MST_KSB<br>US_AXI2VBUSM_RDATA_BUFFER | 0      | ECC Wrapper | Inject with error capture | Yes             | 66        | 4 KB     |
| USB2SS_16FFC_USB2SS_CORE_RAMs_MEM_CTRL_RA<br>M0                         | 1      | ECC Wrapper | Inject with error capture | Yes             | 64        | 56 KB    |

**Table 12-406. Properties of ECC Aggregator Instance USB1**

| RAM ID Name                                                                              | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|------------------------------------------------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| USB3P0SS64_16FFC_USB3P0SS64_CORE_USB3P0_KSB<br>US_AXI2VBUSM_KSBUS_AXI2VBUSM_RDATA_BUFFER | 0      | ECC Wrapper | Inject with error capture | Yes             | 66        | 2 KB     |

**Table 12-407. Properties of ECC Aggregator Instance WKUP\_PSRAECC\_8K0**

| RAM ID Name            | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| PSRAM8KX32E_PSRAM0_ECC | 0      | ECC Wrapper | Inject with error capture | No              | 32        | 32 KB    |

**Table 12-408. Properties of ECC Aggregator Instance WKUP\_R5FSS0**

| RAM ID Name            | RAM ID | ECC Type    | Inject Type | Accessible Flag | Row Width | RAM Size |
|------------------------|--------|-------------|-------------|-----------------|-----------|----------|
| CPU0_ITAG_RAM0         | 0      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM1         | 1      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM2         | 2      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_ITAG_RAM3         | 3      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_IDATA_BANK0       | 4      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK1       | 5      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK2       | 6      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_IDATA_BANK3       | 7      | ECC Wrapper | Inject only | No              | 72        | 9 KB     |
| CPU0_DTAG_RAM0         | 8      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM1         | 9      | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM2         | 10     | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_DTAG_RAM3         | 11     | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_DDIRTY_RAM        | 12     | ECC Wrapper | Inject only | Yes             | 28        | 896 B    |
| CPU0_DDATA_RAM0        | 13     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM1        | 14     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM2        | 15     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM3        | 16     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM4        | 17     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM5        | 18     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM6        | 19     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| CPU0_DDATA_RAM7        | 20     | ECC Wrapper | Inject only | No              | 39        | 5 KB     |
| PULSAR_UL_ATCM0_BANK0  | 21     | ECC Wrapper | Inject only | No              | 39        | 20 KB    |
| PULSAR_UL_ATCM0_BANK1  | 22     | ECC Wrapper | Inject only | No              | 39        | 20 KB    |
| PULSAR_UL_B0TCM0_BANK0 | 23     | ECC Wrapper | Inject only | No              | 39        | 10 KB    |
| PULSAR_UL_B0TCM0_BANK1 | 24     | ECC Wrapper | Inject only | No              | 39        | 10 KB    |

**Table 12-408. Properties of ECC Aggregator Instance WKUP\_R5FSS0 (continued)**

| RAM ID Name                                     | RAM ID | ECC Type    | Inject Type               | Accessible Flag | Row Width | RAM Size |
|-------------------------------------------------|--------|-------------|---------------------------|-----------------|-----------|----------|
| PULSAR_UL_B1TCM0_BANK0                          | 25     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_B1TCM0_BANK1                          | 26     | ECC Wrapper | Inject only               | No              | 39        | 10 KB    |
| PULSAR_UL_PULSAR_KS_VIM_COMMON_CORE0_RAM        | 27     | ECC Wrapper | Inject with error capture | Yes             | 30        | 960 B    |
| PULSAR_UL_MEM_MST0_KSBUS_AXI2VBUSM_RDATA_BUFFER | 28     | ECC Wrapper | Inject with error capture | Yes             | 66        | 528 B    |

**Table 12-409. Properties of ECC Aggregator Instance WKUP\_VTM0**

| RAM ID Name                                        | RAM ID | ECC Type         | Inject Type               | Accessible Flag | Max Number of Checkers |
|----------------------------------------------------|--------|------------------|---------------------------|-----------------|------------------------|
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL                      | 0      | EDC Interconnect | Inject with error capture | Yes             | 6                      |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 1      | EDC Interconnect | Inject with error capture | Yes             | 171                    |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 2      | EDC Interconnect | Inject with error capture | Yes             | 3                      |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 3      | EDC Interconnect | Inject with error capture | Yes             | 50                     |

**Table 12-410. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0**

| Protected Interconnect        | Group ID | Width | Checker Type |
|-------------------------------|----------|-------|--------------|
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 0        | 1     | Redundant    |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 1        | 32    | EDC          |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 2        | 1     | Parity       |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 3        | 10    | Parity       |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 4        | 4     | Parity       |
| K3VTM_N16FFC_ECCAGGR_EDC_CTRL | 5        | 3     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 0        | 1     | Redundant    |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 1        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 2        | 4     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 3        | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 4        | 4     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 5        | 32    | EDC          |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 6        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 7        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 8        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 9        | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 10       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 11       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 12       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 13       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 14       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 15       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 16       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 17       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0   | 18       | 8     | Parity       |

**Table 12-410. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 19       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 20       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 21       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 22       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 23       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 24       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 25       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 26       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 27       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 28       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 29       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 30       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 31       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 32       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 33       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 34       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 35       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 36       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 37       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 38       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 39       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 40       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 41       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 42       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 43       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 44       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 45       | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 46       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 47       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 48       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 49       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 50       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 51       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 52       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 53       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 54       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 55       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 56       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 57       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 58       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 59       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 60       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 61       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 62       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 63       | 1     | Parity       |

**Table 12-410. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 64       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 65       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 66       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 67       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 68       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 69       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 70       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 71       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 72       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 73       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 74       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 75       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 76       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 77       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 78       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 79       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 80       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 81       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 82       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 83       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 84       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 85       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 86       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 87       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 88       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 89       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 90       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 91       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 92       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 93       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 94       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 95       | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 96       | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 97       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 98       | 10    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 99       | 16    | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 100      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 101      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 102      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 103      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 104      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 105      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 106      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 107      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 108      | 1     | Parity       |

**Table 12-410. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect      | Group ID | Width | Checker Type |
|-----------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 109      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 110      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 111      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 112      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 113      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 114      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 115      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 116      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 117      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 118      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 119      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 120      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 121      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 122      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 123      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 124      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 125      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 126      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 127      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 128      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 129      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 130      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 131      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 132      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 133      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 134      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 135      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 136      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 137      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 138      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 139      | 5     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 140      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 141      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 142      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 143      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 144      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 145      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 146      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 147      | 6     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 148      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 149      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 150      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 151      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 152      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0 | 153      | 1     | Parity       |

**Table 12-410. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect                             | Group ID | Width | Checker Type |
|----------------------------------------------------|----------|-------|--------------|
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 154      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 155      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 156      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 157      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 158      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 159      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 160      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 161      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 162      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 163      | 1     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 164      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 165      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 166      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 167      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 168      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 169      | 8     | Parity       |
| K3VTM_N16FFC_MMR_EDC_CTRL_0                        | 170      | 8     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 0        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 1        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_VBUSB_P2P_BRIDGE_EDC_CTRL_0 | 2        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 0        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 1        | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 2        | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 3        | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 4        | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 5        | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 6        | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 7        | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 8        | 2     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 9        | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 10       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 11       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 12       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 13       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 14       | 12    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 15       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 16       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 17       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 18       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 19       | 12    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 20       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 21       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 22       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 23       | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_EDC_CTRL_0          | 24       | 1     | Redundant    |

**Table 12-410. EDC checkers information for ECC Aggregator Instance WKUP\_VTM0 (continued)**

| Protected Interconnect                        | Group ID | Width | Checker Type |
|-----------------------------------------------|----------|-------|--------------|
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 25       | 12    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 26       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 27       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 28       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 29       | 7     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 30       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 31       | 4     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 32       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 33       | 26    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 34       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 35       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 36       | 26    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 37       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 38       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 39       | 26    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 40       | 3     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 41       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 42       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 43       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 44       | 32    | EDC          |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 45       | 1     | Redundant    |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 46       | 1     | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 47       | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 48       | 10    | Parity       |
| K3VTM_N16FFC_CFG_CBASS_CFG_SCR_SCR_EDC_CTRL_0 | 49       | 1     | Parity       |

## 12.9 Display Subsystem (DSS) and Peripherals

This section describes the Display Subsystem (DSS) in the device, integrated together with display peripherals.

### 12.9.1 Display Subsystem (DSS)

This section describes the Display Subsystem (DSS) in the device.

#### 12.9.1.1 DSS Overview

The Display Subsystem (DSS) is a flexible, multi-pipeline subsystem that supports high-resolution display outputs. DSS includes input pipelines providing multi-layer blending with transparency to enable on-the-fly composition. Various pixel processing capabilities are supported, such as color space conversion and scaling, among others. DSS includes a DMA engine, which allows direct access to the frame buffer (device system memory). Display outputs can connect seamlessly to an Open LVDS Display Interface transmitter (OLDITX), or can directly drive device pads as a Display Parallel Interface (DPI).

Figure 12-452 is a high-level overview of the display subsystem.



Figure 12-452. DSS Overview

#### 12.9.1.1.1 DSS Features

The Display Subsystem module includes the following features:

- Two display outputs
  - Up to 24-bit per pixel parallel or embedded sync output
  - Up to 200MHz pixel clock
  - Supports
    - 1920x1080@60fps
    - 1x 2048x1080 + 1x 1280x720 (constrained by DDR bandwidth)
  - Support for RGB/YUV422 modes
  - Support for progressive/interlaced modes
  - Two display pipelines support 2x OpenLDI 4-data/1clk link (either shared to provide a 4K display or mirroring the same display - independent displays on each ODLI are not supported)
- Two input display processing pipelines
  - One video pipeline supporting full RGB and 8/10-bit YUV data formats with 3/5-tap 16-phase scaler capable of 0.25x to 16x resizing.
  - One video\_lite pipeline supporting full RGB and 8/10 YUV data formats (no resizing support)
- Two Overlay Managers with multi layer alpha blending
- One DMA controller capable of supporting up to 2K input source width.

- 48-bit addressing (256 TB reach)
- On-the-fly X/Y-axis flip of the source (Flip/Mirror mode support)
- Safety check (freeze frame detection and data correctness check)

---

**Note**

Some features may not be available. See *Module Integration* for more information.

---

#### **12.9.1.1.2 Unsupported Features**

See the *Module Integration* section for information about unsupported features.

### 12.9.1.2 DSS Environment

This section describes the interfaces handled by the display subsystem.

DSS supports two types of display interfaces:

- Display parallel interface via DISPC Video Port 2 (VP2) output. For more information, see [Section 12.9.1.2.1](#).
- Two low-voltage differential signaling (LVDS) interfaces, each with four data lanes and one clock lane, via Open LDI Transmitters (OLDITX0 and OLDITX1) connected to DISPC Video Port 1 (VP1) output. For more information, see [Section 12.9.1.2.2](#).

For more information on video ports configuration, see [Section 12.9.1.4.1.10, DISPC Video Port Outputs](#).

[Figure 12-453](#) is a diagram of the DSS external connections.



Figure 12-453. DSS Environment

---

#### Note

For more information about device level signals (pull-up/down resistors, buffer type, multiplexing and others), see tables *Pin Attributes* and *Pin Multiplexing* in the device-specific Datasheet.

##### 12.9.1.2.1 DSS Parallel Interface

The DISPC Video Port 2 (VP2) outputs the required data and control signals to device pads to support the following display interface modes:

- Parallel MIPI DPI 2.0 (Digital Pixel Interface): RGB 16/18/24-bit output with separate sync signals.
- BT.656/BT.1120 interface: YUV422 output (8/10-bit modes) with embedded syncs.

Table 12-411 describes the DISPC VP2 output signals.

**Table 12-411. DSS Signals for MIPI DPI 2.0 or BT.656/BT.1120**

| Module Pin          | Device Level Signal | Type <sup>(1)</sup> | Description                                                                                                                                                                                                                       | Module Pin Reset Value |
|---------------------|---------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| DSS_DPI2_DATA[23:0] | VOUT1_DATA[23:0]    | O                   | Pixel data output. RGB data for MIPI DPI 2.0 interface. YUV data for BT.656/BT.1120 interfaces.                                                                                                                                   | 0                      |
| DSS_DPI2_PCLK       | VOUT1_PCLK          | O                   | Pixel clock output. The maximum interface frequency is 165MHz.                                                                                                                                                                    | 0                      |
| DSS_DPI2_VSYNC      | VOUT1_VSYNC         | O                   | Vertical synchronization. The frame synchronization pulse (vsync) toggles after all the lines in a frame are transmitted and a programmable number of line clock cycles has elapsed at the beginning and the end of each frame.   | 0                      |
| DSS_DPI2_HSYNC      | VOUT1_HSYNC         | O                   | Horizontal synchronization. The line synchronization pulse (hsync) toggles after all pixels in a line are transmitted and a programmable number of pixel clock wait-states has elapsed at the beginning and the end of each line. | 0                      |
| DSS_DPI2_DE         | VOUT1_DE            | O                   | Pixel data output-enable signal to indicate when data must be latched using the pixel clock.                                                                                                                                      | 0                      |

(1) I = Input, O = Output, I/O = Input/Output

---

#### Note

The effective output pixel clock rate for interleaved data formats (that is, BT.656 output mode or TDM (Time Division Multiplexed) output mode) will be either 1/2 or 1/3 of the maximum pixel clock rate, respectively, depending on the interleaving ratio.

##### 12.9.1.2.1.1 Pixel Data Formats

This section describes the pixel data bus for RGB formats and shows timing diagrams of transactions and synchronizations.

For the active matrix display type, one pixel per pixel clock is displayed. The diagrams represent the configuration of assertion of the data on the rising edge of the pixel clock. It is possible to program the interface timing to output the data on the falling edge of the pixel clock.

Figure 12-454 through Figure 12-457 show the interface to 12-, 16-, 18-, and 24-bit RGB active matrix displays. Each vertical line represents one output pixel. The width of the data bus can be configured through DSS0\_CONTROL[10-8] DATALINES register bitfield.



**Figure 12-454. DISPC Video Port Pixel Data - 12-bit RGB Active Matrix**



**Figure 12-455. DISPC Video Port Pixel Data - 16-bit RGB Active Matrix**



**Figure 12-456. DISPC Video Port Pixel Data - 18-bit RGB Active Matrix**



**Figure 12-457. DISPC Video Port Pixel Data - 24-bit RGB Active Matrix**

#### 12.9.1.2.1.2 Display Timing Diagrams

Figure 12-458 through Figure 12-461 show examples with timing diagrams of synchronization signals and pixel clocks for active matrix panels. The DISPC video ports directly drive these signals, which are related to the programmable fields listed in Table 12-412. For more information, see also Section 12.9.1.4.1.10.7, *DISPC VP Timing Generator and Display Panel Settings*.

**Table 12-412. DISPC Video Port Register Fields for Active Matrix Display**

| Name  | Register                | Description   |
|-------|-------------------------|---------------|
| PPL   | DSS0_SIZE_SCREEN[11-0]  | PPL value + 1 |
| LPP   | DSS0_SIZE_SCREEN[27-16] | LPP value + 1 |
| HBP   | DSS0_TIMING_HI[31-20]   | HBP value + 1 |
| HFP   | DSS0_TIMING_H[19-8]     | HFP value + 1 |
| HSW   | DSS0_TIMING_H[7-0]      | HSW value + 1 |
| VBP   | DSS0_TIMING_V[31-20]    | VBP value     |
| VFP   | DSS0_TIMING_V[19-8]     | VFP value     |
| VSW   | DSS0_TIMING_V[7-0]      | VSW value + 1 |
| ALIGN | DSS0_POL_FREQ[18]       | ALIGN         |
| ONOFF | DSS0_POL_FREQ[17]       | ONOFF         |
| RF    | DSS0_POL_FREQ[16]       | RF            |
| IEO   | DSS0_POL_FREQ[15]       | IEO           |
| IPC   | DSS0_POL_FREQ[14]       | IPC           |
| IHS   | DSS0_POL_FREQ[13]       | IHS           |
| IVS   | DSS0_POL_FREQ[12]       | IVS           |

- Active matrix timing configuration 1:
  - DSS0\_POL\_FREQ[17] ONOFF = 0
  - DSS0\_POL\_FREQ[16] RF = 0
  - The HSYNC and VSYNC signals are driven on the opposite edge of PCLK from the pixel data.
  - DSS0\_POL\_FREQ[15] IEO = 0

The DE signal is active high.

- DSS0\_POL\_FREQ[14] IPC = 0

The pixel data are driven on the rising edge of PCLK.

- DSS0\_POL\_FREQ[13] IHS = 0

The HSYNC signal is active high.

- DSS0\_POL\_FREQ[12] IVS = 0

The VSYNC signal is active high.

- DSS0\_POL\_FREQ[18] ALIGN = 0

The VSYNC and HSYNC assertion is not aligned.



**Figure 12-458. DISPC Display Timing Diagram of Configuration 1 (Start of Frame)**



**Figure 12-459. DISPC Display Timing Diagram of Configuration 1 (Between Lines)**



**Figure 12-460. DISPC Display Timing Diagram of Configuration 1 (Between Frames)**



**Figure 12-461. DISPC Display Timing Diagram of Configuration 1 (End of Frame)**

- Active matrix timing configuration 2:

- DSS0\_POL\_FREQ[17] ONOFF = 1
- DSS0\_POL\_FREQ[16] RF = 1
  - The HSYNC and VSYNC signals are driven on the rising edge of PCLK.
- DSS0\_POL\_FREQ[15] IEO = 1
  - The DE signal is active low.
- DSS0\_POL\_FREQ[14] IPC = 1
  - The pixel data is driven on the falling edge of PCLK.
- DSS0\_POL\_FREQ[13] IHS = 1
  - The HSYNC signal is active low.
- DSS0\_POL\_FREQ[12] IVS = 1
  - The VSYNC signal is active low.
- DSS0\_POL\_FREQ[18] ALIGN = 0
  - The VSYNC and HSYNC assertion is not aligned.



**Figure 12-462. DISPC Display Timing Diagram of Configuration 2 (Start of Frame)**



**Figure 12-463. DISPC Display Timing Diagram of Configuration 2 (Between Lines)**



**Figure 12-464. DISPC Display Timing Diagram of Configuration 2 (Between Frames)**



**Figure 12-465. DISPC Display Timing Diagram of Configuration 2 (End of Frame)**

- Active matrix timing configuration 3:

- DSS0\_POL\_FREQ[17] ONOFF = 1
- DSS0\_POL\_FREQ[16] RF = 1

The HSYNC and VSYNC signals are driven on the rising edge of PCLK.

- DSS0\_POL\_FREQ[15] IEO = 0

The DE signal is active high.

- DSS0\_POL\_FREQ[14] IPC = 0

The pixel data are driven on the rising edge of PCLK.

- DSS0\_POL\_FREQ[13] IHS = 0

The HSYNC signal is active high.

- DSS0\_POL\_FREQ[12] IVS = 0

The VSYNC signal is active high.

- DSS0\_POL\_FREQ[18] ALIGN = 0

The VSYNC and HSYNC assertion is not aligned.



**Figure 12-466. DISPC Display Timing Diagram of Configuration 3 (Start of Frame)**



**Figure 12-467. DISPC Display Timing Diagram of Configuration 3 (Between Lines)**



Figure 12-468. DISPC Display Timing Diagram of Configuration 3 (Between Frames)



Figure 12-469. DISPC Display Timing Diagram of Configuration 3 (End of Frame)

#### 12.9.1.2.2 DSS LVDS Interface

The LVDS display interface is provided via two single-link OLDITX modules, which receives parallel RGB pixel data and synchronization signals from DSS DISPC Video Port 1 (VP1). The VP1 pixel data format and timings are the same as described for VP2 in [Section 12.9.1.2.1.1](#) and [Section 12.9.1.2.1.2](#), respectively. OLDITX works only with 18-bit or 24-bit RGB input source data.

The OLDITX translates 21-bit or 28-bit wide video and sync data into 3-bit or 4-bit wide serial data, 7-bits deep. The 24-bit serialized RGB pixel data is transmitted on four LVDS data lanes, clocked by one clock lane. OLDITX can also be configured to transmit only 18-bit RGB data (6-bits/pixel color component) on three LVDS lanes, when connected to a low-resolution display panel. In 18-bit configuration, only three LVDS data lanes and one clock lane are active. The fourth data lane is disabled.

[Table 12-413](#) describes the OLDITX output LVDS signals.

Table 12-413. DSS OLDITX Signals for LVDS Interface

| Module Pin  | Device Level Signal | Type <sup>(1)</sup> | Description                          | Module Pin Reset Value |
|-------------|---------------------|---------------------|--------------------------------------|------------------------|
| OLDI_DATA0X | OLDI_A0P            | O                   | OLDI differential data lane A0 (+)   | -                      |
| OLDI_DATA0Y | OLDI_A0N            | O                   | OLDI differential data lane A0 (-)   | -                      |
| OLDI_DATA1X | OLDI_A1P            | O                   | OLDI differential data lane A1 (+)   | -                      |
| OLDI_DATA1Y | OLDI_A1N            | O                   | OLDI differential data lane A1 (-)   | -                      |
| OLDI_DATA2X | OLDI_A2P            | O                   | OLDI differential data lane A2 (+)   | -                      |
| OLDI_DATA2Y | OLDI_A2N            | O                   | OLDI differential data lane A2 (-)   | -                      |
| OLDI_DATA3X | OLDI_A3P            | O                   | OLDI differential data lane A3 (+)   | -                      |
| OLDI_DATA3Y | OLDI_A3N            | O                   | OLDI differential data lane A3 (-)   | -                      |
| OLDI_CLOCKX | OLDI_CLKP           | O                   | OLDI differential clock lane CLK (+) | -                      |

**Table 12-413. DSS OLDITX Signals for LVDS Interface (continued)**

| Module Pin  | Device Level Signal | Type <sup>(1)</sup> | Description                          | Module Pin Reset Value |
|-------------|---------------------|---------------------|--------------------------------------|------------------------|
| OLDI_CLOCKY | OLDI_CLKN           | O                   | OLDI differential clock lane CLK (-) | -                      |

(1) I = Input, O = Output, I/O = Input/Output

**Table 12-414** shows the supported LVDS pixel components mapping for 18-bit and 24-bit output data modes. The OLDI mapping type is defined in DSS0\_DSS\_OLDI\_CFG[3-1] MAP register field as follows:

- Type A = Single-link 18-bit. MAP = '000'.
- Type B = Single-link 24-bit JEIDA. MAP = '001'.
- Type C = Single-link 24-bit. MAP = '010'.
- Type D = Dual-link 18-bit. MAP = '100'.
- Type E = Dual-link 24-bit JEIDA. MAP = '101'.
- Type F = Dual-link 24-bit. MAP = '110'.

**Table 12-414. DSS OLDITX LVDS Data Format**

| Mode                        | Single-link        | Single-link   | Single-link   | Dual-link          | Dual-link     | Dual-link     |
|-----------------------------|--------------------|---------------|---------------|--------------------|---------------|---------------|
|                             | 18-bit             | 24-bit JEIDA  | 24-bit        | 18-bit             | 24-bit JEIDA  | 24-bit        |
| OLDI mapping type           | A                  | B             | C             | D                  | E             | F             |
| Pixels per LVDS clock cycle | 1pixel/1clock      | 1pixel/1clock | 1pixel/1clock | 2pixel/1clock      | 2pixel/1clock | 2pixel/1clock |
| Number of clock pairs       | 1                  | 1             | 1             | 1or2               | 1or2          | 1or2          |
| Number of LVDS data pairs   | 3                  | 4             | 4             | 6                  | 8             | 8             |
| Color depth                 | 6                  | 8             | 8             | 6                  | 8             | 8             |
| A00                         | R0                 | R2            | R0            | OR0                | OR2           | OR0           |
| A01                         | R1                 | R3            | R1            | OR1                | OR3           | OR1           |
| A02                         | R2                 | R4            | R2            | OR2                | OR4           | OR2           |
| A03                         | R3                 | R5            | R3            | OR3                | OR5           | OR3           |
| A04                         | R4                 | R6            | R4            | OR4                | OR6           | OR4           |
| A05                         | R5                 | R7            | R5            | OR5                | OR7           | OR5           |
| A06                         | G0                 | G2            | G0            | OG0                | OG2           | OG0           |
| A10                         | G1                 | G3            | G1            | OG1                | OG3           | OG1           |
| A11                         | G2                 | G4            | G2            | OG2                | OG4           | OG2           |
| A12                         | G3                 | G5            | G3            | OG3                | OG5           | OG3           |
| A13                         | G4                 | G6            | G4            | OG4                | OG6           | OG4           |
| A14                         | G5                 | G7            | G5            | OG5                | OG7           | OG5           |
| A15                         | B0                 | B2            | B0            | OB0                | OB2           | OB0           |
| A16                         | B1                 | B3            | B1            | OB1                | OB3           | OB1           |
| A20                         | B2                 | B4            | B2            | OB2                | OB4           | OB2           |
| A21                         | B3                 | B5            | B3            | OB3                | OB5           | OB3           |
| A22                         | B4                 | B6            | B4            | OB4                | OB6           | OB4           |
| A23                         | B5                 | B7            | B5            | OB5                | OB7           | OB5           |
| A24                         | H SYNC             | H SYNC        | H SYNC        | H SYNC             | H SYNC        | H SYNC        |
| A25                         | V SYNC             | V SYNC        | V SYNC        | V SYNC             | V SYNC        | V SYNC        |
| A26                         | DEN                | DEN           | DEN           | DEN                | DEN           | DEN           |
| A30                         | See <sup>(1)</sup> | R0            | R6            | See <sup>(1)</sup> | OR0           | OR6           |
| A31                         | ---                | R1            | R7            | ---                | OR1           | OR7           |
| A32                         | ---                | G0            | G6            | ---                | OG0           | OG6           |
| A33                         | ---                | G1            | G7            | ---                | OG1           | OG7           |

Table 12-414. DSS OLDITX LVDS Data Format (continued)

| Mode | Single-link | Single-link | Single-link | Dual-link | Dual-link | Dual-link |
|------|-------------|-------------|-------------|-----------|-----------|-----------|
| A34  | ---         | B0          | B6          | ---       | OB0       | OB6       |
| A35  | ---         | B1          | B7          | ---       | OB1       | OB7       |
| A36  | ---         | NA          | NA          | ---       | NA        | NA        |
| A40  | See (2)     | See (2)     | See (2)     | ER0       | ER2       | ER0       |
| A41  | ---         | ---         | ---         | ER1       | ER3       | ER1       |
| A42  | ---         | ---         | ---         | ER2       | ER4       | ER2       |
| A43  | ---         | ---         | ---         | ER3       | ER5       | ER3       |
| A44  | ---         | ---         | ---         | ER4       | ER6       | ER4       |
| A45  | ---         | ---         | ---         | ER5       | ER7       | ER5       |
| A46  | ---         | ---         | ---         | EG0       | EG2       | EG0       |
| A50  | ---         | ---         | ---         | EG1       | EG3       | EG1       |
| A51  | ---         | ---         | ---         | EG2       | EG4       | EG2       |
| A52  | ---         | ---         | ---         | EG3       | EG5       | EG3       |
| A53  | ---         | ---         | ---         | EG4       | EG6       | EG4       |
| A54  | ---         | ---         | ---         | EG5       | EG7       | EG5       |
| A55  | ---         | ---         | ---         | EB0       | EB2       | EB0       |
| A56  | ---         | ---         | ---         | EB1       | EB3       | EB1       |
| A60  | ---         | ---         | ---         | EB2       | EB4       | EB2       |
| A61  | ---         | ---         | ---         | EB3       | EB5       | EB3       |
| A62  | ---         | ---         | ---         | EB4       | EB6       | EB4       |
| A63  | ---         | ---         | ---         | EB5       | EB7       | EB5       |
| A64  | ---         | ---         | ---         | NA        | NA        | NA        |
| A65  | ---         | ---         | ---         | NA        | NA        | NA        |
| A66  | ---         | ---         | ---         | DEN       | DEN       | DEN       |
| A70  | See (1)     | ---         | ---         | See (1)   | ER0       | ER6       |
| A71  | ---         | ---         | ---         | ---       | ER1       | ER7       |
| A72  | ---         | ---         | ---         | ---       | EG0       | EG6       |
| A73  | ---         | ---         | ---         | ---       | EG1       | EG7       |
| A74  | ---         | ---         | ---         | ---       | EB0       | EB6       |
| A75  | ---         | ---         | ---         | ---       | EB1       | EB7       |
| A76  | ---         | ---         | ---         | ---       | NA        | NA        |

(1) Not used - output disabled.

(2) Reserved for other video channel (Single-Link Mode)

Figure 12-470 and Figure 12-471 show the LVDS data output bit format (that is, the pixel bit numbers onto LVDS interface bit numbers). The rising edge of the LVDS clock occurs two LVDS sub-symbols before the current cycle of data. The clock is composed of a 4 LVDS sub-symbol high time and a 3 LVDS sub-symbol low time.



Figure 12-470. DSS OLDITX Pixel Bit Numbers on LVDS Output (Single-Link)



**Figure 12-471. DSS OLDITX Pixel Bit Numbers on LVDS Output (Dual-Link)**

Figure 12-472 and Figure 12-473 show the OLDITX input data mapped to LVDS output and the serial bit positions.



**Figure 12-472. DSS OLDITX Inputs Mapped to LVDS Outputs**



**Figure 12-473. DSS OLDITX LVDS Serial Bit Positions**

The OLDITX LVDS signal lines support a minimum bit time of 0.866 ns. This corresponds to a maximum pixel clock rate of 165 MHz (for a single link operation). A bit time period (known as TUI or Time Unit Interval) consists of several timing parameters:

- TCCS (Transmitter Channel-to-Channel Skew) - refers to the max skew across the differential data pairs within a link (in a single-link mode).
- SW - setup and hold time (internal data sample window) in the receiver.
- RSKM (Receiver Input Skew Margin) - the total time margin that remains after subtracting the sampling window (SW) size and the transmitter channel-to-channel skew (TCCS) from the time unit interval (TUI).

For more information on the OLDITX LVDS timing parameters, refer to device-specific Datasheet.

#### 12.9.1.3 Integration

See the *Module Integration* section for information about clocks, resets and hardware requests.

#### 12.9.1.4 DSS Functional Description

##### 12.9.1.4.1 DISPC Functional Description

###### 12.9.1.4.1.1 DISPC Overview

Figure 12-474 is a simplified block diagram of DISPC.



dss-068

**Figure 12-474. DISPC Architecture Overview**

The DISPC integrated within DSS is capable of fetching pixel data from the device system memory through its single initiator port, performing various pixel processing, and then providing the processed pixels to an external display panel. The internal DMA engine tightly coupled to the DISPC is used for the pixel data transfer from system memory (frame buffer). The DISPC DMA engine is in charge of scheduling the memory requests. Several processes are configurable in order to manage the video pipeline features (color space conversion, up-sampling, down-sampling) and overlay features. The internal timing generator logic generates the video port output signals based on VESA DMT and CEA-861 standards. The DISPC video port output can be connected to display panels either directly (for MIPI DPI 2.0 or BT.656/BT.1120 support), or through Open LDI transmitter.

#### Note

DISPC does not support any tiled frame buffer, nor any compressed frame buffer. DISPC has no internal capability to support rotation of the frame buffer.

#### Note

The display resolution is programmable and can be any width in the range [1:4096] pixels. The following limitations apply, related to the type of display or the processing done:

- Active Matrix screen + dithering forces a width multiple of 2 pixels
- Active Matrix + TDM may force a width multiple of 2 pixels

The display buffers in the system memory must consist of contiguous pixels.

##### 12.9.1.4.1.2 DISPC Clocks

DISPC has one clock domain for its internal logic and separate domains for each video port output.

The DISPC functional clock (DSS\_FUNC\_CLK) serves as the internal logic clock and also acts as the interface clock for the DISPC initiator and responder ports to system interconnect. There is no internal divisor on this clock.

The DISPC pixel clocks (DPI\_x\_IN\_CLK) serve as the clocks for the DISPC video port outputs to OLDITX0 and OLDITX1 modules (VP1 pixel clock DPI\_0\_IN\_CLK) or for the parallel display interface (VP2 pixel clock DPI\_1\_IN\_CLK). There are no internal divisors on the pixel clocks.

The frequency of DSS\_FUNC\_CLK clock must be greater or equal to the DPI\_x\_IN\_CLK clocks, in order to get the DISPC internal logic to function properly. The frequency of the DPI\_x\_IN\_CLK clocks depend on the output display resolution and required frame rate. For the maximum supported frequency ratings, refer to device-specific Datasheet.

All input clocks are asynchronous to each other. They can be generated by different sources.

The DSS0\_COMMON\_DSS\_SYSCONFIG[0] AUTOCLKGATING register bit is set by default to allow the auto-gating of the interface and functional clocks. The AUTOCLKGATING bit can be reset to disable the auto-gating of the clocks, if required.

DISPC provides also a clock-gating control on sub-module level, via configuration of the DSS0\_COMMON\_DISPC\_CLKGATING\_DISABLE register fields.

#### 12.9.1.4.1.3 DISPC Resets

DISPC receives a single hardware reset signal. For more information, see *DSS Integration*.

To perform a software reset on the DISPC, set the DSS0\_COMMON\_DSS\_SYSCONFIG[1] SOFTRESET bit to 0x1. The DSS0\_COMMON\_DSS\_SYSSTATUS[0] DISPC\_FUNC\_RESETDONE bit indicates that the software reset is complete (for the DISPC internal logic) when its value is 0x1. When the software reset completes, the DSS0\_COMMON\_DSS\_SYSCONFIG[1] SOFTRESET bit is automatically reset. Software must ensure that the software reset completes before performing DISPC operations.

The completion of the software reset for the video ports logic is indicated in the DSS0\_COMMON\_DSS\_SYSSTATUS[3-1] DISPC\_VP\_RESETDONE register bit-field.

#### 12.9.1.4.1.4 DISPC Power Management

DISPC supports a power management protocol with the device Power Sleep Controller (PSC).

The (software) sequence, while performing a *clkstop\_req* to DISPC, is as follows:

1. Disable DISPC by programing the [0] ENABLE bit of DSS0\_VP\_CONTROL register to 0.
2. DISPC hardware completes the output of the current frame. Then hardware sets the DSS0\_COMMON\_DSS\_SYSSTATUS[9] DISPC\_IDLE\_STATUS register bit to 1.
3. Poll the DSS\_IDLE\_STATUS bit to ensure that DISPC is in idle mode.
4. PSC initiates *clkstop\_req* to DISPC.
5. DISPC hardware acknowledges with *clkstop\_ack* immediately.

### 12.9.1.4.1.5 DISPC Interrupt Requests

DISPC supports two active-high level sensitive interrupt output lines: DSS\_INTERRUPT0 and DSS\_INTERRUPT1. All DISPC sub-module interrupt events are fully mapped to both of these interrupts, as shown in Figure 12-475. There are two sets of IRQ aggregating registers, one set for each interrupt line, which enable fully independent monitoring and control of the interrupt events by two processor hosts at device level.



**Figure 12-475. DISPC Interrupts Generation**

Each of the interrupt signals indicates that one or more interrupt events are detected by the hardware. Each event is independently maskable for each interrupt output.

There are two levels of interrupt events. The first level is used to indicate common events and is also source for the second level of interrupts. The second level of interrupt events consists of status and enable interrupt registers for each video pipeline and each video port.

Table 12-415 describes the first level of interrupt events with associated mask and status register fields. Each interrupt event is captured in an interrupt status register. Equivalent IRQSTATUS\_RAW registers exist, which are updated even if interrupts are not enabled. This allows software to get access to updated status for all interrupt events.

**Table 12-415. DISPC Interrupts - First Level**

| Interrupt Name | DSS_INTERRUPT_MASK_DSS0_COMMON_DISPC_IRQENABLE_SET | DSS_INTERRUPT_STATUS_DSS0_COMMON_DISPC_IRQSTATUS | DSS_INTERRUPT_MASK_DSS0_COMMON1_DISPC_IRQENABLE_SET | DSS_INTERRUPT_STATUS_DSS0_COMMON1_DISPC_IRQSTATUS | Description                                                                                                                |
|----------------|----------------------------------------------------|--------------------------------------------------|-----------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| VID_IRQ        | [4] SET_VID_IRQ                                    | [4] VID_IRQ                                      | [4] SET_VID_IRQ                                     | [4] VID_IRQ                                       | At least one event of the VID pipeline interrupt events has occurred. See <a href="#">Table 12-416</a> for more details.   |
| VIDL_IRQ       | [5] SET_VID_IRQ                                    | [5] VID_IRQ                                      | [5] SET_VID_IRQ                                     | [5] VID_IRQ                                       | At least one event of the VIDL1 pipeline interrupt events has occurred. See <a href="#">Table 12-417</a> for more details. |
| VP1_IRQ        | [0] SET_VP_IRQ                                     | [0] VP_IRQ                                       | [0] SET_VP_IRQ                                      | [0] VP_IRQ                                        | At least one event of the VP1 interrupt events has occurred. See <a href="#">Table 12-418</a> for more details.            |
| VP2_IRQ        | [1] SET_VP_IRQ                                     | [1] VP_IRQ                                       | [1] SET_VP_IRQ                                      | [1] VP_IRQ                                        | At least one event of the VP2 interrupt events has occurred. See <a href="#">Table 12-419</a> for more details.            |

[Table 12-416](#) describes the second level of interrupts for VID pipeline with associated mask and status register bits.

**Table 12-416. DISPC Interrupts - Second Level - VID Pipeline**

| Interrupt Name   | DSS_INTERRUPT_MASK_DSS0_COMMON_VID_IRQENABLE_0 | DSS_INTERRUPT_STATUS_DSS0_COMMON_VID_IRQSTATUS_0 | DSS_INTERRUPT_MASK_DSS0_COMMON1_VID_IRQENABLE_0 | DSS_INTERRUPT_STATUS_DSS0_COMMON1_VID_IRQSTATUS_0 | Description                                                                                            |
|------------------|------------------------------------------------|--------------------------------------------------|-------------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| VIDENDWINDOW_IRQ | [1] VIDENDWINDOW_EN                            | [1] VIDENDWINDOW_IRQ                             | [1] VIDENDWINDOW_EN                             | [1] VIDENDWINDOW_IRQ                              | End of the video window:<br>The DMA engine has fetched all the data from memory for the current frame. |

**Table 12-416. DISPC Interrupts - Second Level - VID Pipeline (continued)**

| Interrupt Name         | DSS_INTERRUPT_MASK<br>DSS0_COMMON_VID_IRQEN<br>ABLE_0 | DSS_INTERRUPT_Status<br>DSS0_COMMON_VID_IRQST<br>ATUS_0 | DSS_INTERRUPT_Mask<br>DSS0_COMMON_VID_IRQE<br>NABLE_0 | DSS_INTERRUPT_Status<br>DSS0_COMMON_VID_IRQS<br>ATUS_0 | Description                                                                                                                                                                                               |
|------------------------|-------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VIDBUFFERUNDERFLOW_IRQ | [0] VIDBUFFERUNDERFLOW_EN_Q                           | [0] VIDBUFFERUNDERFLOW_IR_Q                             | [0] VIDBUFFERUNDERFLOW_EN_Q                           | [0] VIDBUFFERUNDERFLOW_IR_Q                            | Video DMA buffer underflow.<br>The input video DMA buffer goes underflow. This does not necessary means that the buffer is empty (out of order refill), but simply that the required pixel is not in yet. |
| VIDSAFETYREGION_IRQ    | [2] SAFETYREGION_EN                                   | [2] SAFETYREGION_IRQ                                    | [2] SAFETYREGION_EN                                   | [2] SAFETYREGION_IRQ                                   | Video output MISR signature mismatch OR Video output freeze frame detect.<br>The MISR signature generated does not match the expected signature OR The Video output frame freeze detection has triggered. |

Table 12-417 describes the second level of interrupts for VIDL pipeline with associated mask and status register bits.

**Table 12-417. DISPC Interrupts - Second Level - VIDL Pipeline**

| Interrupt Name   | DSS_INTERRUPT_MASK<br>DSS0_COMMON_VID_IRQEN<br>ABLE_1 | DSS_INTERRUPT_Status<br>DSS0_COMMON_VID_IRQST<br>ATUS_1 | DSS_INTERRUPT_Mask<br>DSS0_COMMON_VID_IRQE<br>NABLE_1 | DSS_INTERRUPT_Status<br>DSS0_COMMON_VID_IRQS<br>ATUS_1 | Description                                                                                                          |
|------------------|-------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| VIDENDWINDOW_IRQ | [1] VIDENDWINDOW_EN                                   | [1] VIDENDWINDOW_IRQ                                    | [1] VIDENDWINDOW_EN                                   | [1] VIDENDWINDOW_IRQ                                   | End of the video window.<br>The DMA engine has fetched all the data from memory for the video for the current frame. |

**Table 12-417. DISPC Interrupts - Second Level - VIDL Pipeline (continued)**

| Interrupt Name         | DSS_INTERRUPT_MASK_DSS0_COMMON_VID_IRQENABLE_1 | DSS_INTERRUPT_STATUS_DSS0_COMMON_VID_IRQSTATUS_1 | DSS_INTERRUPT_MASK_DSS0_COMMON1_VID_IRQENABLE_1 | DSS_INTERRUPT_STATUS_DSS0_COMMON1_VID_IRQSTATUS_1 | Description                                                                                                                                                                                                 |
|------------------------|------------------------------------------------|--------------------------------------------------|-------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VIDBUFFERUNDERFLOW_IRQ | [0] VIDBUFFERUNDERFLOW_EN_Q                    | [0] VIDBUFFERUNDERFLOW_IRQ                       | [0] VIDBUFFERUNDERFLOW_EN_Q                     | [0] VIDBUFFERUNDERFLOW_IRQ                        | Video DMA buffer underflow.<br>The input video DMA buffer goes underflow. This does not necessary means that the buffer is empty (out of order refill), but simply that the required pixel is not in yet.   |
| VIDSAFETYREGION_IRQ    | [2] SAFETYREGION_EN                            | [2] SAFETYREGION_IRQ                             | [2] SAFETYREGION_EN                             | [2] SAFETYREGION_IRQ                              | Video output MISR signature mismatch, or video output freeze frame detect.<br>The MISR signature generated does not match the expected signature, or the video output frame freeze detection has triggered. |

Table 12-418 describes the second level of interrupts for VP1 output with associated mask and status register bits.

**Table 12-418. DISPC Interrupts - Second Level - VP1 Output**

| Interrupt Name        | DSS_INTERRUPT_MASK_DSS0_COMMON_VP_IRQENABLE_0 | DSS_INTERRUPT_STATUS_DSS0_COMMON_VP_IRQSTATUS_0 | DSS_INTERRUPT_MASK_DSS0_COMMON1_VP_IRQENABLE_0 | DSS_INTERRUPT_STATUS_DSS0_COMMON1_VP_IRQSTATUS_0 | Description                                                                                                                                |
|-----------------------|-----------------------------------------------|-------------------------------------------------|------------------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| VPSYNC_IRQ            | [1] VPSYNC_EN                                 | [1] VPSYNC_IRQ                                  | [1] VPSYNC_EN                                  | [1] VPSYNC_IRQ                                   | Sync for VP1 output. Shadow to work copy of registers associated with VP1 has occurred. DSS_VP1_CONTROL[5] GO register bit is cleared.     |
| SECURITYVIOLATION_IRQ | [10] SECURITYVIOLATION_EN                     | [10] SECURITYVIOLATION_IRQ                      | [10] SECURITYVIOLATION_EN                      | [10] SECURITYVIOLATION_IRQ                       | Security violation for VP1 output. A security violation (for example, a secure video pipeline connected to non-secure VP/VR) has occurred. |

**Table 12-418. DISPC Interrupts - Second Level - VP1 Output (continued)**

| Interrupt Name       | DSS_INTERRUPT Mask<br>DSS0_COMMON_VP IRQEN<br>ABLE_0 | DSS_INTERRUPT Status<br>DSS0_COMMON_VP IRQST<br>ATUS_0 | DSS_INTERRUPT Mask<br>DSS0_COMMON_VP IRQE<br>NABLE_0 | DSS_INTERRUPT Status<br>DSS0_COMMON_VP IRQS<br>TATUS_0 | Description                                                                                                                                                                                           |
|----------------------|------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FRAMEDONE_IRQ        | [0] VPFRAMEDONE_EN                                   | [0] VPFRAMEDONE IRQ                                    | [0] VPFRAMEDONE_EN                                   | [0] VPFRAMEDONE IRQ                                    | Frame done for VP1 output.<br>After disabling the VP1 output of the DISPC, the interrupt is set when the active frame related to the VP1 has completed.                                               |
| VSYNC_IRQ            | [1] VPVSYNC_EN                                       | [1] VPVSYNC IRQ                                        | [1] VPVSYNC_EN                                       | [1] VPVSYNC IRQ                                        | VSYNC for VP1 output:<br>VSYNC interrupt for the VP1 has occurred at the end of the frame.                                                                                                            |
| VSYNC_ODD_IRQ        | [2] VPVSYNC_ODD_EN                                   | [2] VPVSYNC_ODD IRQ                                    | [2] VPVSYNC_ODD_EN                                   | [2] VPVSYNC_ODD IRQ                                    | VSYNC for odd field.<br>VSYNC_ODD interrupt has occurred at the end of the frame (EVSYNC received and the field polarity is odd).                                                                     |
| PROGRAMMEDLINENUM_RQ | [3] VPPROGRAMMEDLINENUM<br>BER_EN                    | [3] VPPROGRAMMEDLINENUM<br>BER IRQ                     | [3] VPPROGRAMMEDLINENUM<br>BER_EN                    | [3] VPPROGRAMMEDLINENUM<br>BER IRQ                     | Programmed line number.<br>The VP1 has reached the user-programmed line number.                                                                                                                       |
| SYNCLOST_IRQ         | [4] VPVSYNCLOST_EN                                   | [4] VPVSYNCLOST IRQ                                    | [4] VPVSYNCLOST_EN                                   | [4] VPVSYNCLOST IRQ                                    | Synchronization lost on VP1 output:<br>Occurs when VSYNC width/front or back porches are not wide enough to load the pipeline with data (VP1 output).                                                 |
| VPSAFETYREGION_IRQ   | [9-6] SAFETYREGION_EN                                | [9-6] SAFETYREGION IRQ                                 | [9-6] SAFETYREGION_EN                                | [9-6] SAFETYREGION IRQ                                 | VP1 output MISR signature mismatch, or VP1 output freeze frame detect.<br>The MISR signature generated does not match the expected signature, or the VP1 output frame freeze detection has triggered. |

Table 12-419 describes the second level of interrupts for VP2 output with associated mask and status register bits.

**Table 12-419. DISPC Interrupts - Second Level - VP2 Output**

| Interrupt Name            | DSS_INTERRUPT Mask<br>DSS0_COMMON_VP_IRQENABLE_1 | DSS_INTERRUPT Status<br>DSS0_COMMON_VP_IRQSTATUS_1 | DSS_INTERRUPT Mask<br>DSS0_COMMON_VP_IRQENABLE_1 | DSS_INTERRUPT Status<br>DSS0_COMMON_VP_IRQSTATUS_1 | Description                                                                                                                                          |
|---------------------------|--------------------------------------------------|----------------------------------------------------|--------------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| VPSYNC_IRQ                | [1] VPSYNC_EN                                    | [1] VPSYNC_IRQ                                     | [1] VPSYNC_EN                                    | [1] VPSYNC_IRQ                                     | Sync for VP2 output. Shadow to work copy of registers associated with VP2 has occurred. DSS_VP2_CONTROL[5] GO register bit is cleared.               |
| SECURITYVIOLATION_IRQ     | [10] SECURITYVIOLATION_EN                        | [10] SECURITYVIOLATION_IRQ                         | [10] SECURITYVIOLATION_EN                        | [10] SECURITYVIOLATION_IRQ                         | Security violation for VP2 output. A security violation (for example, a secure video pipeline connected to non-secure VP/VR) has occurred.           |
| FRAMEDONE_IRQ             | [0] VPFRAMEDONE_EN                               | [0] VPFRAMEDONE_IRQ                                | [0] VPFRAMEDONE_EN                               | [0] VPFRAMEDONE_IRQ                                | Frame done for VP2 output. After disabling the VP2 output of the DISPC, the interrupt is set when the active frame related to the VP2 has completed. |
| VSYNC_IRQ                 | [1] VPVSYNC_EN                                   | [1] VPVSYNC_IRQ                                    | [1] VPVSYNC_EN                                   | [1] VPVSYNC_IRQ                                    | VSYNC for VP2 output: VSYNC interrupt for the VP2 has occurred at the end of the frame.                                                              |
| VSYNC_ODD_IRQ             | [2] VPVSYNC_ODD_EN                               | [2] VPVSYNC_ODD_IRQ                                | [2] VPVSYNC_ODD_EN                               | [2] VPVSYNC_ODD_IRQ                                | VSYNC for VP2 output: VSYNC_ODD interrupt has occurred at the end of the frame (EVSYNC received and the field polarity is odd).                      |
| PROGRAMMEDLINENUMBER_I_RQ | [3] VPPROGRAMMEDLINEENUM_BER_EN                  | [3] VPPROGRAMMEDLINEENUM_BER_IRQ                   | [3] VPPROGRAMMEDLINEENUM_BER_EN                  | [3] VPPROGRAMMEDLINEENUM_BER_IRQ                   | Programmed line number. The VP2 has reached the user-programmed line number.                                                                         |
| SYNCCLOSED_IRQ            | [4] VPSYNCCLOSED_EN                              | [4] VPSYNCCLOSED_IRQ                               | [4] VPSYNCCLOSED_EN                              | [4] VPSYNCCLOSED_IRQ                               | Synchronization lost on VP2 output: Occurs when VSYNC width/front or back porches are not wide enough to load the pipeline with data (VP2 output).   |

**Table 12-419. DISPC Interrupts - Second Level - VP2 Output (continued)**

| Interrupt Name     | DSS_INTERRUPT Mask<br>DSS0_COMMON_VP_IRQENABLE_1                                                                                          | DSS_INTERRUPT Status<br>DSS0_COMMON_VP_IRQSTATUS_1                                                                                         | DSS_INTERRUPT Mask<br>DSS0_COMMON_VP_IRQENABLE_1                                                                                          | DSS_INTERRUPT Status<br>DSS0_COMMON_VP_IRQSTATUS_1                                                                                         | Description                                                                                                                                                                                        |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VPSAFETYREGION_IRQ | [9-6] SAFETYREGION_EN<br>Bit [9] = Safety Region 3<br>Bit [8] = Safety Region 2<br>Bit [7] = Safety Region 1<br>Bit [6] = Safety Region 0 | [9-6] SAFETYREGION_IRQ<br>Bit [9] = Safety Region 3<br>Bit [8] = Safety Region 2<br>Bit [7] = Safety Region 1<br>Bit [6] = Safety Region 0 | [9-6] SAFETYREGION_EN<br>Bit [9] = Safety Region 3<br>Bit [8] = Safety Region 2<br>Bit [7] = Safety Region 1<br>Bit [6] = Safety Region 0 | [9-6] SAFETYREGION_IRQ<br>Bit [9] = Safety Region 3<br>Bit [8] = Safety Region 2<br>Bit [7] = Safety Region 1<br>Bit [6] = Safety Region 0 | VP2 output MISR signature mismatch, or VP2 output freeze frame detect. The MISR signature generated does not match the expected signature, or the VP2 output frame freeze detection has triggered. |

#### 12.9.1.4.1.6 DISPC DMA Engine

The DISPC DMA engine:

- Requests and supplies data from system memory to the VID and VIDL pipelines through the system interconnect, based on the configuration of the video pipeline settings.
- Is fully programmable and fetches pixel data via 128-bit requests using 1D burst.

Each pipeline has a dedicated DMA buffer and channel with independent settings. If a pipeline is disabled (that is, not used), then its DMA buffer can be assigned to another pipeline by configuring the DSS0\_COMMON\_DISPC\_GLOBAL\_BUFFER register. For example, unused buffers for VIDL pipeline can be used by VID pipeline.

Each DMA channel supports a total of 8 line buffers, each of which can store 1280 32-bit pixels.

- The size of the DMA buffer associated to the video lite pipeline (VIDL1) is 8x320x128-bit.
- The size of the DMA buffer associated to the video pipeline (VID) is 8x320x128-bit.

The DMA engine fetches encoded pixels from the system memory only when the video layer is enabled (a valid configuration has been programmed for the video layer), that is, the video window is present and the video pipeline is active.

##### 12.9.1.4.1.6.1 DISPC DMA Addressing and Bursts

For each line to be fetched, the DMA engine address generator:

- Calculates the pixel address
- Aligns the address
- Determines byte enable pattern
- Determines 1D burst length

The meaning of the address bits is as follows:

- Bits [31-0]: system (DDR) memory address (pixel address)
- Bits [37-32]: 32 bits + address extension

The address extension bits are defined by the programmable parameter DSS0\_VID\_BA\_EXT\_0/DSS0\_VID\_BA\_EXT\_1 and DSS0\_VID\_BA\_UV\_EXT\_0/DSS0\_VID\_BA\_UV\_EXT\_1 registers, optionally used to extend the BA memory addressing to 48-bit addressed external memory space (that is, to extend DISPC address space into 4GB+ space).

The DDR scan pixel addresses are generated by the DMA engine in order to read data from the system memory. The base address defines the start address of the first pixel, and then the address is incremented based on the number of pixels per line, offset between two consecutive lines and number of lines. The DSS0\_VID\_ROW\_INC register allow the access to a frame using 1D bursts (but as a two-dimensional block) by adding a fixed address offset at the end of a line. The ROW\_INC can also be used to skip lines from the input frame.

The byte address of each pixel in the frame buffer located in the system memory is determined by:

Pixel address = base\_address + x × (bpp/8) + y × (width × (bpp/8) + increment), where:

- "base\_address" corresponds to the base address defined by:
  - DSS0\_VID\_BA\_0/DSS0\_VID\_BA\_1[31-0] BA register bit-fields for all formats, and Y frame buffer in case of YUV-NV12 format. Optional extension bits in DSS0\_VID\_BA\_EXT\_0/DSS0\_VID\_BA\_EXT\_1 registers.
  - DSS0\_VID\_BA\_UV\_0/DSS0\_VID\_BA\_UV\_1[31-0] BA register bit-fields for UV frame buffer in case of YUV-NV12 format. Optional extension bits in DSS0\_VID\_BA\_UV\_EXT\_0/DSS0\_VID\_BA\_UV\_EXT\_1 registers.
- "bpp" corresponds to the number of bits per pixel defined by the DSS0\_VID\_ATTRIBUTES[6-1] FORMAT register bit-field.
- "width" corresponds to the number of pixels per line defined by the DSS0\_VID\_PICTURE\_SIZE[11-0] MEMSIZEX + 1 register bit-field.
- "increment" corresponds to the number of bytes to skip between two contiguous lines defined by the DSS0\_VID\_ROW\_INC[31-0] ROWINC – 1 register bit-field.
- "x" corresponds to the pixel position on the x-axis.

- "y" corresponds to the pixel position on the y-axis.

---

**Note**

Since the base address is aligned on pixel size boundary the horizontal resolution is one pixel. In case of YUV422 formats, the resolution is 4 bytes (2 pixels). In case of RGB24 packed format the resolution is 4 pixels. In case of Y frame buffer (YUV-NV12 format) the resolution is one byte. The vertical resolution is one line.

In case of YUV422 format, the number of pixels per line shall be a multiple of 2 pixels and the size of a pixel shall be considered as 2 bytes. In case of YUV420-NV12 or YUV420-NV21 format, the Y buffer shall be considered as an 8-bit frame buffer, and the CbCr shall be considered as a 16-bit frame buffer. The pixel size is 1 byte and 2 bytes, respectively for Y and CbCr.

For YUV420-NV12 or YUV420-NV21 format, the pixel values are defined in two separate buffers (Y and UV buffers). The first buffer consists of Y values (8 bits for each Y sample). The second buffer consists of CbCr values (16 bits for each pair of CbCr samples). The base address of the Y and UV buffers are as defined earlier in this section.

In case of interlaced mode, DSS0\_VID\_BA\_0 and DSS0\_VID\_BA\_UV\_0 registers define the base address of the even field, and DSS0\_VID\_BA\_1 and DSS0\_VID\_BA\_UV\_1 registers define the base address of the odd field.

The number of bytes to skip between pixels and between lines are defined using DSS0\_VID\_PIXEL\_INC and DSS0\_VID\_ROW\_INC registers, respectively. They define the values to be used for the Y buffer. For the CbCr buffer, the DSS0\_VID\_ROW\_INC\_UV register define the values.

---

**Table 12-420** summarizes the register settings for a simple access of a picture in the system memory.

**Table 12-420. DISPC Register Settings for Accessing Image in Internal Memory**

| Video Pipeline Registers                                            | Value                                                                                |
|---------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| DSS0_VID_BA_0 <sup>(1)</sup> and DSS0_VID_BA_1 <sup>(2)</sup>       | The physical base address (PBA) of image in the memory for all formats and Y buffer. |
| DSS0_VID_BA_EXT_0 and DSS0_VID_BA_EXT_1                             | Address extension bits of PBA for all formats and Y buffer.                          |
| DSS0_VID_BA_UV_0 <sup>(1)</sup> and DSS0_VID_BA_UV_1 <sup>(2)</sup> | The physical base address (PBA) of UV buffers image in the memory.                   |
| DSS0_VID_BA_UV_EXT_0 and DSS0_VID_BA_UV_EXT_1                       | Address extension bits of PBA for UV buffers.                                        |
| DSS0_VID_PIXEL_INC                                                  | 1 or other in pixel incremental value.                                               |
| DSS0_VID_ROW_INC                                                    | 1 or other in row incremental value. Used for Y buffer.                              |
| DSS0_VID_ROW_INC_UV                                                 | 1 or other in row incremental value. Used for UV buffer.                             |

(1) Base address of even field, in case of interlaced mode.

(2) Base address of odd field, in case of interlaced mode.

An interconnect request (128 bits) corresponds to one or several pixels, depending on the bits per pixel. Therefore, the DMA engine determines the appropriate burst sequence to optimize the fetching of each new line. The DMA engine must prevent a single burst from crossing two lines. The DMA engine supports only 1D burst. 1D burst is used, if the fetch data is linear in memory. The size of the burst can be one of the following values: 1x128-bit, 2x128-bit, 4x128-bit, or 8x128-bit. Because the burst size must be aligned to the burst boundary, in case of misalignment, the DMA engine may issue one or more smaller burst requests.

#### 12.9.1.4.1.6.2 DISPC Read DMA Buffers

When the vertical front porch (VFP) period starts after the last horizontal front porch (HFP) of the last line, the DMA buffers are flushed according to the video port output associated with the particular video pipeline. The DMA engine restarts fetching data from the memory through the DSS Initiator port. Enabling or disabling the DISPC flushes the DMA buffers.

Programmable high and low thresholds, independent for each DMA buffer, are used by the DMA engine to start and stop requesting data through the Initiator port.

- When low threshold (set in the DSS0\_VID\_BUF\_THRESHOLD [15-0] BUFLOWTHRESHOLD register bit-field) is reached, the DMA engine starts a request on the device interconnect to fill the DMA buffer.
- When high threshold (set in the DSS0\_VID\_BUF\_THRESHOLD [31-16] BUFHIGHTHRESHOLD register bit-field) is reached, the DMA engine stops requesting encoded pixels.

---

#### Note

The configuration of thresholds for optimal performance can be defined using the DSS0\_VID\_BUF\_SIZE\_STATUS [15-0] BUFSIZE register field value, as follows:

- For high threshold: BUFSIZE (in number of 128-bit words) – 1
- For low threshold: BUFSIZE (in number of 128-bit words) – burst size (in number of 128-bit words)

The following limitations for BUFLOWTHRESHOLD values must be also considered:

- If the scaler in VID pipeline is disabled, BUFLOWTHRESHOLD can be programmed as low as interconnect latency and pixel output rate allow it.
- If the scaler in VID pipeline is enabled, BUFLOWTHRESHOLD must be programmed to guarantee that at least four full lines can be stored.

To avoid underflow at the beginning of a frame and have sufficient encoded pixel data to start some processing, a preloading of the DMA buffer is configurable between a fixed value of bytes and the high threshold value. The preload ensures a minimum number of pixels present in the buffer. When the preload value is reached, the associated channel will start pulling pixels out of the DMA buffer. To enable the preload based on the value entered in the DSS0\_VID\_PRELOAD [11-0] PRELOAD register bit-field, the DSS0\_VID\_ATTRIBUTES [19] BUFPRELOAD register bit must be set to 0x0.

The vertical blanking between two frames must be long enough to allow fetching the number of pixels defined by the DSS0\_VID\_PRELOAD register and preloading the whole video pipeline. If the value set in the preload register is greater than some overflow conditions detected by the hardware, then data will start to be read from the video DMA buffer before the preload value is reached. If SYNCLOST\_IRQ event occurs the video buffer needs to be increased (buffer merge). Preload value must be greater or equal to low threshold, and smaller or equal to high threshold value.

---

#### Note

When self-refresh mode is selected (which means that the data in the DMA buffer are used for multiple frames) the DMA buffers are not flushed at the end of each frame. Each DMA buffer has an independent control for selecting the self-refresh mode. For more information, see [Section 12.9.1.4.1.6.8.2, DISPC DMA Ultra-Low Power Mode](#).

---

#### 12.9.1.4.1.6.3 DISPC Flip/Mirror Support

DISPC supports on-the-fly source image flip along the x/y-axis for 8-bit/component formats (ARGB or YUV) to create a mirror effect on the source data. The DMA engine reads the source frame from right to left by requesting burst transfers for each line in negative address increments while performing each burst transfer as a linear incremental burst. The read data is repacked and stored in the line buffer incrementally - effectively storing the frame as a flipped image for the processing pipeline. The configuration of the flip/mirror operation is explained in [Table 12-421](#).

**Table 12-421. DISPC Flip/Mirror Configuration**

| Flip Direction                   | FLIP Bit | Base Address                     | Byte Increment                   |
|----------------------------------|----------|----------------------------------|----------------------------------|
| Along Y-axis (vertical mirror)   | 1        | Start of window                  | 1                                |
| Along X-axis (horizontal mirror) | 0        | Start of last line of the window | -(2(width of the line in bytes)) |

**Table 12-421. DISPC Flip/Mirror Configuration (continued)**

| Flip Direction                                                   | FLIP Bit | Base Address                     | Byte Increment                               |
|------------------------------------------------------------------|----------|----------------------------------|----------------------------------------------|
| Along both X-axis and Y-axis<br>(horizontal and vertical mirror) | 1        | Start of last line of the window | $-(2^{(\text{width of the line in bytes})})$ |

In [Table 12-421](#):

- The FLIP bit is located in `DSS0_VID_ATTRIBUTES` register.
- The base address of the video buffer must be configured as explained in [Section 12.9.1.4.1.6.1, DISPC DMA Addressing and Bursts](#).
- The number of bytes to increment at the end of the row in the video buffer can be configured through `DSS0_VID_ROW_INC` and `DSS0_VID_ROW_INC_UV` registers. For more information, see [Section 12.9.1.4.1.6.1, DISPC DMA Addressing and Bursts](#), and [Section 12.9.1.4.1.6.4, DISPC DMA Predecimation](#).

#### **12.9.1.4.1.6.4 DISPC DMA Predecimation**

The predecimation process consists of downscaling an image by fetching only the necessary pixels out of the memory. Vertical and horizontal predecimation are possible:

- Vertical predecimation: The picture stored in memory can be predecimated vertically by skipping lines. Burst mode is used to fetch the data when skipping lines. Only the lines that will be used by the DISPC are fetched from memory; the other lines are skipped. The DMA engine sends requests only for the useful lines using 1D burst. The base address indicates the first valid pixel to fetch from memory. The number of lines to skip is set in the `DSS0_VID_ROW_INC` and `DSS0_VID_ROW_INC_UV` registers.
- Horizontal predecimation: When fetching data from memory, it is possible to skip 1 out of 2 pixels, up to 1 of 2047 pixels, by setting the `DSS0_VID_PIXEL_INC` register to the number of pixels to skip (n), multiplied by the size of a pixel (in bytes), +1. The condition to generate a burst is that there is at least one useful pixel per 128-bit OCP request. Therefore, when the pixels are 16/32-bit, the maximum number of pixels that can be skipped is 8/4. If `PixelWidthInBytes+BytesToSkip` is greater than 16, the programmed burst is changed into single request.

No decimation is supported when the input format is 1, 2, 4, or 8-bit BITMAP.

For RGB and YUV420 data formats, each pixel data container in memory holds 1 pixel. Thus, when configuring the `DSS0_VID_PIXEL_INC` register, the value of n equals the number of pixels to skip:

- For RGB format, one pixel data container = 32 bits = 1 pixel
- For YUV format:
  - One Y pixel data container = 8 bits = 1 pixel
  - One UV pixel data container = 16 bits = 1 pixel

For YUV422 format, each 32-bit pixel data container holds the Luma components for 2 pixels, and the Chrominance component of 1 pixel (see [Figure 12-476](#)). Therefore, for the valid values of the `PIXELINC` bit field in the case of the following YUV422 format, caution must be taken because n equals the number of pixel data containers to skip, and not the number of pixels:

- For n = 1, `PIXELINC` = 5
- For n = 2, `PIXELINC` = 9
- For n = 3, `PIXELINC` = 13
- For n = 4, `PIXELINC` = 17, etc.



**Figure 12-476. DISPC YUV422 Predecimation**

#### 12.9.1.4.1.6.5 DISPC DMA MFLAG Mechanism

The MFLAG mechanism allows a dynamic increase of the priority of DISPC real-time traffic, when required, based on the fullness of the DISPC DMA read buffers.

The MFLAG mechanism is used when fullness of the DMA buffers is critical (close to underflow). The mechanism is implemented for all DMA buffers of the video pipelines.

Programmable buffer thresholds (forming hysteresis) are used to indicate when a local MFLAG signal is generated. The 1-bit MFLAG signal is generated on DISPC Initiator port in order to inform the system that the outstanding requests from DISPC shall be considered with higher priority in order to get faster interconnect responses. The MFLAG signal is asynchronous to any ongoing interconnect transaction.

Each pipeline maintains its own MFLAG bit. The MFLAG bit is asserted depending on the fullness of the DMA buffers associated with the pipeline and depending on the thresholds programmed by software. All MFLAG signals are OR-ed together to generate the single 1-bit MFLAG for the Initiator port connected to the DISPC DMA engine.

The threshold for video pipelines corresponds to the fullness of the associated DMA buffer, and is defined by two threshold parameters:

- HT\_MFLAG: High threshold.
  - For read access from video pipelines, when the pipeline buffer reaches the programmed value, the associated local MFLAG signal goes low (deasserted).
  - This threshold can be programmed in the DSS0\_VID\_MFLAG\_THRESHOLD [31-16] HT\_MFLAG register field.
- LT\_MFLAG: Low threshold.
  - For read access from video pipelines, when the pipeline buffer reaches the programmed value, the associated local MFLAG signal goes high (asserted).
  - This threshold can be programmed in the DSS0\_VID\_MFLAG\_THRESHOLD [15-0] LT\_MFLAG register field.

Summary of the MFLAG value, based on DMA read buffer fullness:

- If DMA read buffer fullness < LT\_MFLAG, then MFLAG signal = 1
- If LT\_MFLAG < DMA read buffer fullness < HT\_MFLAG, then MFLAG signal = 1
- If DMA read buffer fullness > HT\_MFLAG, then MFLAG signal = 0

By default, the MFLAG mechanism is disabled (DSS0\_COMMON\_DISPC\_GLOBAL\_MFLAG\_ATTRIBUTE[1-0] MFLAG\_CTRL register field = 0x0), and the MFLAG signal is low (de-asserted). The arbitration scheme for the pipelines is the same as described in [Section 12.9.1.4.1.6.7, DISPC DMA Arbitration](#). That is, round-robin either between high-priority pipelines, or between normal-priority pipelines (if all pipelines are of normal priority).

When the MFLAG\_CTRL register field is set to 0x2, the MFLAG mechanism is enabled, and the MFLAG signal is dynamically set to 0 or 1, depending on DMA buffer fullness and programmed threshold levels, as explained previously in this section. In this case, the arbitration scheme for the pipelines is round-robin between those

high-priority pipelines, which have asserted their local MFLAG signals. If there are no high-priority pipelines with their local MFLAG signals asserted, then the arbitration scheme is the same as described in [Section 12.9.1.4.1.6.7, DISPC DMA Arbitration](#).

The DSS0\_COMMON\_DISPC\_GLOBAL\_MFLAG\_ATTRIBUTE[6] MFLAG\_START bit defines the following additional rules for the MFLAG mechanism:

- If the MFLAG\_START bit is set to 0x0 (default value), then when the DMA buffer is empty at the beginning of the frame, the MFLAG signal of each pipeline is kept at 0 until PRELOAD is reached (for more information on preloading, see [Section 12.9.1.4.1.6.2, DISPC Read DMA Buffers](#)). Then, based on the setting of the DSS0\_COMMON\_DISPC\_GLOBAL\_MFLAG\_ATTRIBUTE[1-0] MFLAG\_CTRL register field, the MFLAG signal is generated and DISPC internal logic is arbitrating between pipeline requests.
- If the MFLAG\_START bit is set to 0x1, then even in the beginning of the frame when the DMA buffer is empty, the configuration of DSS0\_COMMON\_DISPC\_GLOBAL\_MFLAG\_ATTRIBUTE[1-0] MFLAG\_CTRL register field determines the generation of the MFLAG signal.

#### 12.9.1.4.1.6.6 DISPC DMA Priority Requests Control

The DSS0\_COMMON\_DSS\_CBA\_CFG register controls the priority level for DMA requests going out to the memory through the system interconnect.

As explained in [Section 12.9.1.4.1.6.5, DISPC DMA MFLAG Mechanism](#), the DISPC Initiator port generates a 1-bit MFLAG output signal to raise the priority of all requests made on that port, if any of its DMA buffers runs critically low (determined by a set of user programmable threshold values for each buffer).

DSS uses the MFLAG signal from DISPC to set a 3-bit priority level output (*Mpriority*) for the Initiator port to either a low or high value (configurable in DSS0\_COMMON\_DSS\_CBA\_CFG[2-0] PRI\_LO and [5-3] PRI\_HI register fields with optional values of 0~7) as follows:

- When MFLAG = 0, the PRI\_LO register field determines the value of the Mpriority output for the normal transactions.
- When MFLAG = 1, the PRI\_HI register field determines the value of the Mpriority output for the high-priority transactions.

This Mpriority output directly drives the respective input of the system interconnect port, which corresponds to the DISPC DMA Initiator port.

#### CAUTION

Upon a hardware reset, DSS0\_COMMON\_DSS\_CBA\_CFG[2-0] PRI\_LO and [5-3] PRI\_HI register fields are set by default to 4 and 1, respectively. Afterwards, these priority level register fields can only be modified by a secure host.

#### 12.9.1.4.1.6.7 DISPC DMA Arbitration

The read requests sent to the system interconnect are pipelined and arbitrated in a round-robin scheme. The default arbitration scheme can be modified by setting the priority attribute of each pipeline as defined in the DSS0\_VID\_ATTRIBUTES[23] ARBITRATION register bit.

By default, all pipelines have the same priority (normal priority), which means all pipeline requests are treated in a round-robin order manner. If one or more pipelines require a higher number of requests going to the system interconnect, its priority can be moved up to high priority. In this case, the high-priority pipeline is granted access before any pipeline in normal priority. If more than one active pipeline is in high priority, then the behavior is the same as all active pipelines in normal priority. Normal active pipelines are not treated until all high active pipelines are finished. The ARBITRATION bit cannot be modified during the entire frame.

#### 12.9.1.4.1.6.8 DISPC DMA Power Modes

##### 12.9.1.4.1.6.8.1 DISPC DMA Low Power Mode

Each DMA buffer can be associated to the pipeline or merged with other DMA buffers. The total number of DMA buffers for each individual pipeline is from 0 (pipeline inactive) to number of pipelines (in that case all the DMA buffers are associated to a single pipeline) supported by the DMA engine.

The user is responsible for configuring correctly the number of DMA buffers to guarantee no underflow. The DMA buffers allocated to each pipeline shall be greater or equal to the minimum required DMA buffer to support the throughput and the system latency.

When the size of the buffer is changed, the thresholds shall be re-programmed by the user to reflect the new DMA buffer configuration. Increasing the size of the buffer used enables to put the interconnect and the system memory in standby for a longer period, therefore, leading to a possible system power reduction.

The low power mode of the DISPC DMA can also be achieved by keeping the thresholds (bit-fields [31-16] BUFHIGHTHRESHOLD and [15-0] BUFLOWTHRESHOLD of DSS0\_VID\_BUF\_THRESHOLD register) farther apart. The farther they are there will be longer periods of idling on the DMA fetch interface resulting in lower power. The user needs to ensure a minimum value of BUFLOWTHRESHOLD, so that there is no underflow.

##### 12.9.1.4.1.6.8.2 DISPC DMA Ultra-Low Power Mode

In ultra-low power mode, the system interconnect is used to fill up the DMA buffers to store all the data required to display a full frame. Then, the system interconnect is not used anymore to fetch new pixels for the following frames. The data are fetched once into the DMA buffer and then the following frames re-use the DMA buffer to display on the screen.

The programming of the ultra-low power mode is independent for each pipeline and is achieved via the DSS0\_VID\_ATTRIBUTES[24] SELFREFRESH register bit. One pipeline may have all frame pixels into the DMA buffer and other pipeline may have to refill the DMA buffers along the display scan, because the frame buffer is too big to be stored in the DMA buffer.

Two ultra-low power modes can be entered, manual or automatic mode:

- Manual self-refresh mode: Starting self-refresh mode is done manually by setting the SELFREFRESH bit to 0x1 after capturing a frame in the DMA buffers. Self-refresh mode is stopped by setting the SELFREFRESH bit to 0x0. Software must first disable the SELFREFRESH bit during at least one frame in order to capture the data (by setting the GOBIT register bit of the video port the pipeline is associated with). Once the DSS0\_VP\_CONTROL[5] GOBIT bit has been set, the software must read the GOBIT bit to ensure that the frame has been loaded into the buffer, then it can set the SELFREFRESH bit to 1. Once SELFREFRESH is enabled, the fetch of data from the system memory is stopped for the following frames. The software needs to reset the SELFREFRESH bit in order to restart fetching data from system memory.
- Automatic self-refresh mode: By setting the DSS0\_VID\_ATTRIBUTES[17] SELFREFRESHAUTO bit to 0x1, the transition from disabled to enabled for self-refresh mode is controlled by hardware. This allows the software to reset the SELFREFRESH bit to "disabled", and then automatically after the fetch of the first frame the hardware switches back SELFREFRESH bit to "enabled". The SELFREFRESH must be disabled during at least one frame in order to capture the data, so software must reset the bit to 0 every time the data in the DMA buffer needs to be updated. The hardware reads the data inside the DMA buffer without accessing the interconnect and system memory during the frame, then modifies the SELFREFRESH bit to reflect the current state of the self-refresh mode by setting the bit to 0x1.

#### 12.9.1.4.1.7 DISPC Pixel Data Formats

The video pipelines support various types of memory formats, as listed in [Table 12-422](#).

For BITMAP formats the nibble mode (pixels in each byte are packed in reverse order) can be enabled by setting the DSS0\_VID\_ATTRIBUTES[10] NIBBLEMODE register bit to 0x1.

The pixel data format can be selected by loading the corresponding value from [Table 12-422](#) in the DSS0\_VID\_ATTRIBUTES [6-1] FORMAT register field.

**Table 12-422. DISPC Supported Pixel Data Formats**

| FORMAT Register Field Value |                    | Pixel Format <sup>(4)</sup> | Component Bit Depth         |
|-----------------------------|--------------------|-----------------------------|-----------------------------|
| Alpha                       | Alpha-X            |                             |                             |
| 0x00                        | 0x20               | ARGB16-4444                 | 4                           |
| 0x01                        | 0x21               | ABGR16-4444                 | 4                           |
| 0x02                        | 0x22               | RGBA16-4444                 | 4                           |
| 0x03                        | NA                 | RGB16-565                   | 5(R,B), 6(G)                |
| 0x04                        | NA                 | BGR16-565                   | 5(R,B), 6(G)                |
| 0x05                        | 0x25               | ARGB16-1555                 | 1(A), 5(R,G,B)              |
| 0x06                        | 0x26               | ABGR16-1555                 | 1(A), 5(R,G,B)              |
| 0x07                        | 0x27               | ARGB32-8888                 | 8                           |
| 0x08                        | 0x28               | ABGR32-8888                 | 8                           |
| 0x09                        | 0x29               | RGBA32-8888                 | 8                           |
| 0x0A                        | 0x2A               | BGRA32-8888                 | 8                           |
| 0x0B                        | NA                 | RGB24-888                   | 8                           |
| 0x0C                        | NA                 | BGR24-888                   | 8                           |
| 0x0E                        | 0x2E               | ARGB32-2101010              | 2(A),10(R,G,B)              |
| 0x0F                        | 0x2F               | ABGR32-2101010              | 2(A),10(R,G,B)              |
| 0x10                        | 0x30               | ARGB64-16161616             | 16                          |
| 0x11                        | 0x31               | RGBA64-16161616             | 16                          |
| 0x12                        | NA                 | BITMAP1                     | 1                           |
| 0x13                        | NA                 | BITMPA2                     | 2                           |
| 0x14                        | NA                 | BITMAP4                     | 4                           |
| 0x15                        | NA                 | BITMAP8                     | 8                           |
| 0x16                        | NA                 | RGB565A8 <sup>(1)</sup>     | 5(R,B), 6(G), separate 8(A) |
| 0x17                        | NA                 | BGR565A8 <sup>(1)</sup>     | 5(R,B), 6(G), separate 8(A) |
| Packed                      | Planar             | Pixel Format                | Component Bit Depth         |
| 0x3E                        | NA                 | YUV422-YUV2                 | 8/10/12 <sup>(3)</sup>      |
| 0x3F                        | NA                 | YUV422-UYVY                 | 8/10/12 <sup>(3)</sup>      |
| NA                          | 0x3D               | YUV420-NV12                 | 8/10/12 <sup>(3)</sup>      |
| NA                          | See <sup>(2)</sup> | YUV420-NV21                 | 8/10/12                     |

- (1) The video pipelines support an optional 8-bit Alpha plane (separate buffer), if the pixel format of the source/destination buffer is either RGB16-565 or BGR16-565.
- (2) NV21 formats for YUV420 are indirectly supported through chroma swapping during the color space conversion.
- (3) 10bit/12bit versions of these YUV formats are also supported in both packed and unpacked (in 16-bit container) formats. For unpacked formats, both LSB or MSB alignments are supported. These configurations are set using a separate configuration register DSS0\_VID\_ATTRIBUTES2. Default is 8-bit packed format support.
- (4) All RGB formats with alpha component include both pre/non-pre-multiplied data support. Also, alpha can be disabled to work as X (can be replaced with global alpha value).

Figure 12-477 shows the pixel data memory organization for the bitmap pixel formats.

## BITMAP 1-bpp (0x12)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |    |    |    |    |    |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|----|----|----|----|----|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 1<br>0 |    |    |    |    |    |
| P31    | P30    | P29    | P28    | P27    | P26    | P25    | P24    | P23    | P22    | P21    | P20    | P19    | P18    | P17    | P16    | P15    | P14    | P13    | P12    | P11    | P10    | P9     | P8     | P7     | P6     | P5     | P4 | P3 | P2 | P1 | P0 |

## BITMAP 2-bpp (0x13)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 1<br>0 |  |
| P15    | P14    | P13    | P12    | P11    | P10    | P9     | P8     | P7     | P6     | P5     | P4     | P3     | P2     | P1     | P0     |        |        |        |        |        |        |        |        |        |        |        |  |

## BITMAP 1-bpp (0x14)

|         |        |        |         |        |        |         |        |        |         |        |        |         |        |        |         |        |        |         |        |        |         |        |        |        |        |        |
|---------|--------|--------|---------|--------|--------|---------|--------|--------|---------|--------|--------|---------|--------|--------|---------|--------|--------|---------|--------|--------|---------|--------|--------|--------|--------|--------|
| 3<br>1  | 3<br>0 | 2<br>9 | 2<br>8  | 2<br>7 | 2<br>6 | 2<br>5  | 2<br>4 | 2<br>3 | 2<br>2  | 2<br>1 | 2<br>0 | 1<br>9  | 1<br>8 | 1<br>7 | 1<br>6  | 1<br>5 | 1<br>4 | 1<br>3  | 1<br>2 | 1<br>1 | 1<br>0  | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 1<br>0 |
| Pixel 7 |        |        | Pixel 6 |        |        | Pixel 5 |        |        | Pixel 4 |        |        | Pixel 3 |        |        | Pixel 2 |        |        | Pixel 1 |        |        | Pixel 0 |        |        |        |        |        |

## BITMAP 1-bpp (0x15)

|         |        |        |        |        |        |         |        |        |        |        |        |         |        |        |        |        |        |         |        |        |        |        |        |        |        |        |
|---------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1  | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5  | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9  | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3  | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 1<br>0 |
| Pixel 3 |        |        |        |        |        | Pixel 2 |        |        |        |        |        | Pixel 1 |        |        |        |        |        | Pixel 0 |        |        |        |        |        |        |        |        |

For BITMAP P-1/2/4 bpp, the Nibble mode (pixels in each byte are packed in reverse order) is also supported.

## BITMAP 1-bpp (0x12) – Nibble Mode

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |    |    |    |    |    |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|----|----|----|----|----|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 1<br>0 |    |    |    |    |    |
| P24    | P25    | P26    | P27    | P28    | P29    | P30    | P31    | P16    | P17    | P18    | P19    | P20    | P21    | P22    | P23    | P8     | P9     | P10    | P11    | P12    | P13    | P14    | P15    | P0     | P1     | P2     | P3 | P4 | P5 | P6 | P7 |

## BITMAP 2-bpp (0x13) – Nibble Mode

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 1<br>0 |  |
| P12    | P13    | P14    | P15    | P8     | P9     | P10    | P11    | P4     | P5     | P6     | P7     | P0     | P1     | P2     | P3     | P4     | P5     | P6     | P7     | P0     | P1     | P2     | P3     |        |        |        |  |

## BITMAP 4-bpp (0x14) – Nibble Mode

|         |        |        |        |        |        |         |        |        |        |        |        |         |        |        |        |        |        |         |        |        |        |        |        |         |        |        |  |  |  |         |  |  |         |  |  |         |  |  |
|---------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|---------|--------|--------|--|--|--|---------|--|--|---------|--|--|---------|--|--|
| 3<br>1  | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5  | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9  | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3  | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>6 | 5<br>4  | 3<br>2 | 1<br>0 |  |  |  |         |  |  |         |  |  |         |  |  |
| Pixel 6 |        |        |        |        |        | Pixel 7 |        |        |        |        |        | Pixel 4 |        |        |        |        |        | Pixel 5 |        |        |        |        |        | Pixel 2 |        |        |  |  |  | Pixel 3 |  |  | Pixel 0 |  |  | Pixel 1 |  |  |

disp-301

**Figure 12-477. DISPC Bitmap Pixel Formats**

Figure 12-478 and Figure 12-479 show the pixel data memory organization for the RGB 16-bit pixel formats.

**ARGB16-4444 (0x00)**

|    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3  | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2  | 3 | 2 | 2 | 2  | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1  | 7 | 1 | 6 | 1  | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| A1 |   |   |   | R1 |   |   |   | G1 |   |   |   | B1 |   |   |   | A0 |   |   |   | R0 |   |   |   | G0 |   |   |   | B0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**xRGB16-4444 (0x20)**

|        |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |        |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|--------|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3      | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2  | 3 | 2 | 2 | 2      | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1  | 7 | 1 | 6 | 1  | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Unused |   |   |   | R1 |   |   |   | G1 |   |   |   | B1 |   |   |   | Unused |   |   |   | R0 |   |   |   | G0 |   |   |   | B0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**ABGR16-4444 (0x01)**

|    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3  | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2  | 3 | 2 | 2 | 2  | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1  | 7 | 1 | 6 | 1  | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| A1 |   |   |   | B1 |   |   |   | G1 |   |   |   | R1 |   |   |   | A0 |   |   |   | B0 |   |   |   | G1 |   |   |   | R0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**xBGR16-4444 (0x21)**

|        |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |        |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|--------|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3      | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2  | 3 | 2 | 2 | 2      | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1  | 7 | 1 | 6 | 1  | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Unused |   |   |   | B1 |   |   |   | G1 |   |   |   | R1 |   |   |   | Unused |   |   |   | B0 |   |   |   | G0 |   |   |   | R0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**RGBA16-4444 (0x02)**

|    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3  | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2  | 3 | 2 | 2 | 2  | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1  | 7 | 1 | 6 | 1  | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| R1 |   |   |   | G1 |   |   |   | B1 |   |   |   | A1 |   |   |   | R0 |   |   |   | G0 |   |   |   | B0 |   |   |   | A0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**RGBx16-4444 (0x22)**

|    |   |   |   |    |   |   |   |    |   |   |   |        |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|----|---|---|---|----|---|---|---|--------|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|--------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3  | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2      | 3 | 2 | 2 | 2  | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1  | 7 | 1 | 6 | 1      | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| R1 |   |   |   | G1 |   |   |   | B1 |   |   |   | Unused |   |   |   | R0 |   |   |   | G0 |   |   |   | B0 |   |   |   | Unused |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**RGB16-565 (0x03)**

|    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3  | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2  | 3 | 2 | 2 | 2  | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| R1 |   |   |   | G1 |   |   |   | B1 |   |   |   | R0 |   |   |   | G0 |   |   |   | B0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**BGR16-565 (0x04)**

|    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3  | 3 | 2 | 2 | 2  | 7 | 2 | 6 | 2  | 5 | 2 | 4 | 2  | 3 | 2 | 2 | 2  | 1 | 2 | 0 | 1  | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| B1 |   |   |   | G1 |   |   |   | R1 |   |   |   | B0 |   |   |   | G0 |   |   |   | R0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

disp-302

**Figure 12-478. DISPC RGB 16-bit Pixel Formats 1**

RGB565A8 (0x16) and BGR565A8 (0x17) are RGB16-565 and BGR16-565, respectively, with a separate Alpha-8bit plane.

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| A3     |        |        |        |        |        |        | A2     |        |        |        |        |        |        | A1     |        |        |        |        |        |        | A0     |        |        |        |        |        |        |        |        |        |

ARGB16-1555 (0x05)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |  |
| A<br>1 | R1     |        |        |        |        |        |        | G1     |        |        |        |        |        |        | B1     |        |        |        |        |        |        | A<br>0 | R0     |        |        |        |        |        |        | B0     |  |

xRGB16-1555 (0x25)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |  |
|        | R1     |        |        |        |        |        |        | G1     |        |        |        |        |        |        | B1     |        |        |        |        |        |        |        | R0     |        |        |        |        |        |        | B0     |  |

ABGR16-1555 (0x06)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |  |
| A<br>1 | B1     |        |        |        |        |        |        | G1     |        |        |        |        |        |        | R1     |        |        |        |        |        |        | A<br>0 | B0     |        |        |        |        |        |        | G0     |  |

xBGR16-1555 (0x26)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |  |
|        | B1     |        |        |        |        |        |        | G1     |        |        |        |        |        |        | R1     |        |        |        |        |        |        |        | B0     |        |        |        |        |        |        | G0     |  |

dispco-303

Figure 12-479. DISPC RGB 16-bit Pixel Formats 2

Figure 12-480 shows the pixel data memory organization for the RGB 24-bit pixel formats.

RGB24-888 (0x0B)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
|        | B1     |        |        |        |        |        |        | R0     |        |        |        |        |        |        | G0     |        |        |        |        |        |        | A<br>0 | B0     |        |        |        |        |        |        | +0x00  |
|        | G2     |        |        |        |        |        |        | B2     |        |        |        |        |        |        | R1     |        |        |        |        |        |        |        | G1     |        |        |        |        |        |        | +0x04  |
|        | R3     |        |        |        |        |        |        | G3     |        |        |        |        |        |        | B3     |        |        |        |        |        |        |        | R2     |        |        |        |        |        |        | +0x08  |

BGR24-888 (0x0C)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
|        | R1     |        |        |        |        |        |        | B0     |        |        |        |        |        |        | G0     |        |        |        |        |        |        |        | R0     |        |        |        |        |        |        | +0x00  |
|        | G2     |        |        |        |        |        |        | R2     |        |        |        |        |        |        | B1     |        |        |        |        |        |        |        | G1     |        |        |        |        |        |        | +0x04  |
|        | B3     |        |        |        |        |        |        | G3     |        |        |        |        |        |        | R3     |        |        |        |        |        |        |        | B2     |        |        |        |        |        |        | +0x08  |

dispco-304

Figure 12-480. DISPC RGB 24-bit Pixel Formats

Figure 12-481 and Figure 12-482 show the pixel data memory organization for the RGB 32-bit pixel formats.

**ARGB32-8888 (0x07)**

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 3 | 2 | 2 | 2 | 2 | 0 | 1 | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| A |   |   |   |   |   |   |   | R |   |   |   |   |   |   |   | G |   |   |   |   |   |   |   | B |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**xRGB32-8888 (0x27)**

|        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3      | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 3 | 2 | 2 | 2 | 2 | 0 | 1 | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Unused |   |   |   |   |   |   |   | R |   |   |   |   |   |   |   | G |   |   |   |   |   |   |   | B |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**ABGR32-8888 (0x08)**

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 3 | 2 | 2 | 2 | 2 | 0 | 1 | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| A |   |   |   |   |   |   |   | B |   |   |   |   |   |   |   | G |   |   |   |   |   |   |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**xBGR32-8888 (0x28)**

|        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3      | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 3 | 2 | 2 | 2 | 2 | 0 | 1 | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Unused |   |   |   |   |   |   |   | B |   |   |   |   |   |   |   | G |   |   |   |   |   |   |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**RGBA32-8888 (0x09)**

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 3 | 2 | 2 | 2 | 2 | 0 | 1 | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1 | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| R |   |   |   |   |   |   |   | G |   |   |   |   |   |   |   | B |   |   |   |   |   |   |   | A |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**RGBx32-8888 (0x29)**

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 3 | 2 | 2 | 2 | 2 | 0 | 1 | 9 | 1 | 8 | 1 | 7 | 1 | 6 | 1      | 5 | 1 | 4 | 1 | 3 | 1 | 2 | 1 | 1 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| R |   |   |   |   |   |   |   | G |   |   |   |   |   |   |   | B |   |   |   |   |   |   |   | Unused |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

dispcl-305

**Figure 12-481. DISPC RGB 32-bit Pixel Formats 1**

BGRA32-8888 (0x0A)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>9 | 8<br>8 | 7<br>7 | 6<br>6 | 5<br>5 | 4<br>4 | 3<br>3 | 2<br>2 | 1<br>1 | 0<br>0 |
| B      |        |        |        |        |        |        |        | G      |        |        |        |        |        |        |        | R      |        |        |        |        |        |        |        | A      |        |        |        |        |        |        |        |

BGRx32-8888 (0x2A)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>9 | 8<br>8 | 7<br>7 | 6<br>6 | 5<br>5 | 4<br>4 | 3<br>3 | 2<br>2 | 1<br>1 | 0<br>0 |
| B      |        |        |        |        |        |        |        | G      |        |        |        |        |        |        |        | R      |        |        |        |        |        |        |        | Unused |        |        |        |        |        |        |        |

ARGB32-2101010 (0x0E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>9 | 8<br>8 | 7<br>7 | 6<br>6 | 5<br>5 | 4<br>4 | 3<br>3 | 2<br>2 | 1<br>1 | 0<br>0 |
| A      |        |        |        |        |        |        |        | R      |        |        |        |        |        |        |        | G      |        |        |        |        |        |        |        | B      |        |        |        |        |        |        |        |

xRGB32-2101010 (0x2E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>9 | 8<br>8 | 7<br>7 | 6<br>6 | 5<br>5 | 4<br>4 | 3<br>3 | 2<br>2 | 1<br>1 | 0<br>0 |
| Unused |        |        |        |        |        |        |        | R      |        |        |        |        |        |        |        | G      |        |        |        |        |        |        |        | B      |        |        |        |        |        |        |        |

ABGR32-2101010 (0x0F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>9 | 8<br>8 | 7<br>7 | 6<br>6 | 5<br>5 | 4<br>4 | 3<br>3 | 2<br>2 | 1<br>1 | 0<br>0 |
| A      |        |        |        |        |        |        |        | B      |        |        |        |        |        |        |        | G      |        |        |        |        |        |        |        | R      |        |        |        |        |        |        |        |

xBGR32-2101010 (0x2F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>9 | 8<br>8 | 7<br>7 | 6<br>6 | 5<br>5 | 4<br>4 | 3<br>3 | 2<br>2 | 1<br>1 | 0<br>0 |
| Unused |        |        |        |        |        |        |        | B      |        |        |        |        |        |        |        | G      |        |        |        |        |        |        |        | R      |        |        |        |        |        |        |        |

dispc-306

**Figure 12-482. DISPC RGB 32-bit Pixel Formats 2**

Figure 12-483 shows the pixel data memory organization for the RGB 64-bit pixel formats.

ARGB64-16161616 (0x10)

xRGB64-16161616 (0x30)

RGBA64-16161616 (0x11)

RGBx64-16161616 (0x31)

Figure 12-483. DISPC RGB 64-bit Pixel Formats

Figure 12-484 and Figure 12-485 show the pixel data memory organization for the YUV 8-bit pixel formats, together with some specific register settings.

ATTRIBUTES2.YUV\_SIZE = 0 (8b)  
ATTRIBUTES2.YUV\_MODE = 0 (N/A)  
ATTRIBUTES2.YUV\_ALIGN = 0 (N/A)

### YUV422 (1-plane/Packed)

YUV2 4:2:2 (0x3E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |      |   |   |   |   |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|------|---|---|---|---|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Cr0    |        |        |        |        |        | Y1     |        |        |        |        |        | Cb0    |        |        |        |        |        | Y0     |        |        |        |   |   | +0x0 |   |   |   |   |   |   |   |
| Cr1    |        |        |        |        |        | Y3     |        |        |        |        |        | Cb1    |        |        |        |        |        | Y2     |        |        |        |   |   | +0x4 |   |   |   |   |   |   |   |
| Cr2    |        |        |        |        |        | Y5     |        |        |        |        |        | Cb2    |        |        |        |        |        | Y4     |        |        |        |   |   | +0x8 |   |   |   |   |   |   |   |
| Cr3    |        |        |        |        |        | Y7     |        |        |        |        |        | Cb3    |        |        |        |        |        | Y6     |        |        |        |   |   | +0xC |   |   |   |   |   |   |   |

UYVY 4:2:2 (0x3F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Y1     |        |        |        |        |        | Cr0    |        |        |        |        |        | Y0     |        |        |        |        |        | Cb0    |        |        |        |        |        | +0x0   |        |        |        |        |        |        |
| Y3     |        |        |        |        |        | Cr1    |        |        |        |        |        | Y2     |        |        |        |        |        | Cb1    |        |        |        |        |        | +0x4   |        |        |        |        |        |        |
| Y5     |        |        |        |        |        | Cr2    |        |        |        |        |        | Y4     |        |        |        |        |        | Cb2    |        |        |        |        |        | +0x0   |        |        |        |        |        |        |
| Y7     |        |        |        |        |        | Cr3    |        |        |        |        |        | Y6     |        |        |        |        |        | Cb3    |        |        |        |        |        | +0x4   |        |        |        |        |        |        |

Figure 12-484. DISPC YUV 8-bit Pixel Formats 1

## YUV420 (2-plane/Planar)

## YUV 4:2:0 – NV12 (0x3D)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Y3     |        |        |        |        |        |        | Y2     |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | +0x0   |        |        |
| Y7     |        |        |        |        |        |        | Y6     |        |        |        |        |        |        | Y5     |        |        |        |        |        |        | Y4     |        |        |        |        |        |        | +0x4   |        |        |
| Y11    |        |        |        |        |        |        | Y10    |        |        |        |        |        |        | Y9     |        |        |        |        |        |        | Y8     |        |        |        |        |        |        | +0x8   |        |        |
| Y15    |        |        |        |        |        |        | Y14    |        |        |        |        |        |        | Y13    |        |        |        |        |        |        | Y12    |        |        |        |        |        |        | +0xC   |        |        |

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Cr1    |        |        |        |        |        |        | Cb1    |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | +0x0   |        |        |
| Cr3    |        |        |        |        |        |        | Cb3    |        |        |        |        |        |        | Cr2    |        |        |        |        |        |        | Cb2    |        |        |        |        |        |        | +0x4   |        |        |
| Cr5    |        |        |        |        |        |        | Cb5    |        |        |        |        |        |        | Cr4    |        |        |        |        |        |        | Cb4    |        |        |        |        |        |        | +0x8   |        |        |
| Cr7    |        |        |        |        |        |        | Cb7    |        |        |        |        |        |        | Cr6    |        |        |        |        |        |        | Cb6    |        |        |        |        |        |        | +0xC   |        |        |

## YUV 4:2:0 – NV21

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Y3     |        |        |        |        |        |        | Y2     |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | +0x0   |        |        |
| Y7     |        |        |        |        |        |        | Y6     |        |        |        |        |        |        | Y5     |        |        |        |        |        |        | Y4     |        |        |        |        |        |        | +0x4   |        |        |
| Y11    |        |        |        |        |        |        | Y10    |        |        |        |        |        |        | Y9     |        |        |        |        |        |        | Y8     |        |        |        |        |        |        | +0x8   |        |        |
| Y15    |        |        |        |        |        |        | Y14    |        |        |        |        |        |        | Y13    |        |        |        |        |        |        | Y12    |        |        |        |        |        |        | +0xC   |        |        |

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Cb1    |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | +0x0   |        |        |
| Cb3    |        |        |        |        |        |        | Cr3    |        |        |        |        |        |        | Cb2    |        |        |        |        |        |        | Cr2    |        |        |        |        |        |        | +0x4   |        |        |
| Cb5    |        |        |        |        |        |        | Cr5    |        |        |        |        |        |        | Cb4    |        |        |        |        |        |        | Cr4    |        |        |        |        |        |        | +0x8   |        |        |
| Cb7    |        |        |        |        |        |        | Cr7    |        |        |        |        |        |        | Cb6    |        |        |        |        |        |        | Cr6    |        |        |        |        |        |        | +0xC   |        |        |

NV21 is not directly supported. It must be specified as NV12 and then the chroma components must be swapped during the YUV to RGB conversion process.

dispC-309

**Figure 12-485. DISPC YUV 8-bit Pixel Formats 2**

Figure 12-486 shows the pixel data memory organization for the YUV 10-bit pixel formats, together with some specific register settings.

YUV 10-bit formats have the same component packing order as 8-bit formats except that the packing is done across a multiple 32-bit word with 2 MSB in each 32-bit word not used.

Note: Each new line in memory must start at a 128-bit aligned address for this format

ATTRIBUTES2.YUV\_SIZE = 1 (10b)  
 ATTRIBUTES2.YUV\_MODE = 0 (Packed)  
 ATTRIBUTES2.YUV\_ALIGN = 0 (N/A)

YUV422 (1-plane/Packed)

YUV2 4:2:2 – 10bit (0x3E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 6<br>5 | 4<br>3 | 3<br>2 | 1<br>0 |  |
|        |        | Y1     |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | +0x0   |        |        |        |        |  |
|        |        | Cb1    |        |        |        |        |        |        | Y2     |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | +0x4   |        |        |        |        |  |
|        |        | Y4     |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | Y3     |        |        |        |        |        |        | +0x8   |        |        |        |        |  |
|        |        | Cr2    |        |        |        |        |        |        | Y5     |        |        |        |        |        |        | Cb2    |        |        |        |        |        |        | +0xC   |        |        |        |        |  |

UYVY 4:2:2 – 10bit (0x3F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 6<br>5 | 4<br>3 | 3<br>2 | 1<br>0 |  |
|        |        | Cr0    |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | +0x0   |        |        |        |        |  |
|        |        | Y2     |        |        |        |        |        |        | Cb1    |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | +0x4   |        |        |        |        |  |
|        |        | Cb2    |        |        |        |        |        |        | Y3     |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | +0x8   |        |        |        |        |  |
|        |        | Y5     |        |        |        |        |        |        | Cr2    |        |        |        |        |        |        | Y4     |        |        |        |        |        |        | +0xC   |        |        |        |        |  |

YUV420 (2-plane/Planar)

YUV 4:2:0 – NV12 (10-bit) (0x3D)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 6<br>5 | 4<br>3 | 3<br>2 | 1<br>0 |  |
|        |        | Y2     |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | +0x0   |        |        |        |        |  |
|        |        | Y5     |        |        |        |        |        |        | Y4     |        |        |        |        |        |        | Y3     |        |        |        |        |        |        | +0x4   |        |        |        |        |  |
|        |        | Y8     |        |        |        |        |        |        | Y7     |        |        |        |        |        |        | Y6     |        |        |        |        |        |        | +0x8   |        |        |        |        |  |
|        |        | Y11    |        |        |        |        |        |        | Y10    |        |        |        |        |        |        | Y9     |        |        |        |        |        |        | +0x4   |        |        |        |        |  |

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 6<br>5 | 4<br>3 | 3<br>2 | 1<br>0 |  |
|        |        | Cb1    |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | +0x0   |        |        |        |        |  |
|        |        | Cr2    |        |        |        |        |        |        | Cb2    |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | +0x4   |        |        |        |        |  |
|        |        | Cb4    |        |        |        |        |        |        | Cr3    |        |        |        |        |        |        | Cb3    |        |        |        |        |        |        | +0x8   |        |        |        |        |  |
|        |        | Cr5    |        |        |        |        |        |        | Cb5    |        |        |        |        |        |        | Cr4    |        |        |        |        |        |        | +0xC   |        |        |        |        |  |

dispc-310

**Figure 12-486. DISPC YUV 10-bit Pixel Formats**

Figure 12-487 and Figure 12-488 show the pixel data memory organization for the YUV 12-bit pixel formats, together with some specific register settings.

YUV 12-bit formats have the same component packing order as 8-bit formats except that the packing is done across a multiple 64-bit word with 4 MSB in each 64-bit word not used.

Note: Each new line in memory must start at a 128-bit aligned address for this format

ATTRIBUTES2.YUV\_SIZE = 2 (12b)  
 ATTRIBUTES2.YUV\_MODE = 0 (Packed)  
 ATTRIBUTES2.YUV\_ALIGN = 0 (N/A)

YUV422 (1-plane)

YUV2 4:2:2 – 12bit (0x3E)

|          |        |        |        |        |        |        |        |        |        |        |        |        |        |           |        |        |        |        |        |        |           |        |        |        |        |        |        |           |
|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-----------|--------|--------|--------|--------|--------|--------|-----------|--------|--------|--------|--------|--------|--------|-----------|
| 3<br>1   | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7    | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0    | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 2<br>1 | 0<br>0 |           |
| Y1[7:0]  |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | Y0        |        |        |        |        |        |        | Cr0       |        |        |        |        |        |        | +0x0      |
| Y2       |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | Y1 [11:8] |        |        |        |        |        |        | Cb1       |        |        |        |        |        |        | +0x4      |
| Cr1[7:0] |        |        |        |        |        |        | Y3     |        |        |        |        |        |        | Cb2       |        |        |        |        |        |        | Y4        |        |        |        |        |        |        | +0x8      |
| Y6[7:0]  |        |        |        |        |        |        | Cr2    |        |        |        |        |        |        | Y5        |        |        |        |        |        |        | Cr1[11:8] |        |        |        |        |        |        | +0xC      |
| Y7       |        |        |        |        |        |        | Cb3    |        |        |        |        |        |        | Y6        |        |        |        |        |        |        | Cr3       |        |        |        |        |        |        | +0x10     |
| Cb4[7:0] |        |        |        |        |        |        | Y8     |        |        |        |        |        |        | Cr4       |        |        |        |        |        |        | Y9        |        |        |        |        |        |        | Cb4[11:8] |
|          |        |        |        |        |        |        |        |        |        |        |        |        |        |           |        |        |        |        |        |        |           |        |        |        |        |        |        | +1C       |

UYVY 4:2:2 – 12bit (0x3F)

|          |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |       |
|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-------|
| 3<br>1   | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>6 | 5<br>4 | 3<br>2 | 2<br>1 | 0<br>0 |       |
| Cr0[7:0] |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | +0x0  |
| Cb1      |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | Y2     |        |        |        |        |        |        | +0x4  |
| Y3[7:0]  |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | Y2     |        |        |        |        |        |        | Cr2    |        |        |        |        |        |        | +0x8  |
| Y4       |        |        |        |        |        |        | Cb2    |        |        |        |        |        |        | Y3     |        |        |        |        |        |        | Cr2    |        |        |        |        |        |        | +0xC  |
| Cb3[7:0] |        |        |        |        |        |        | Y5     |        |        |        |        |        |        | Cr3    |        |        |        |        |        |        | Y6     |        |        |        |        |        |        | +0x10 |
| Cr3      |        |        |        |        |        |        | Cb4    |        |        |        |        |        |        | Y7     |        |        |        |        |        |        | Cr4    |        |        |        |        |        |        | +0x14 |
| Y8[7:0]  |        |        |        |        |        |        | Cb4    |        |        |        |        |        |        | Y9     |        |        |        |        |        |        | Cr4    |        |        |        |        |        |        | +0x18 |
|          |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        | +1C   |

dispc-311

**Figure 12-487. DISPC YUV 12-bit Pixel Formats 1**

**YUV420 (2-plane)**
**YUV 4:2:0 – NV12 (12-bit) (0x3D)**

|         |        |        |        |        |        |        |        |        |        |        |        |          |        |        |        |        |        |        |        |        |        |        |        |          |        |        |        |        |        |        |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|----------|--------|--------|--------|--------|--------|--------|
| 3<br>1  | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9   | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 6<br>7   | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Y2[7:0] |        |        |        |        |        | Y1     |        |        |        |        |        | Y0       |        |        |        |        |        | +0x0   |        |        |        |        |        | +0x4     |        |        |        |        |        |        |
| Y4      |        |        |        |        |        | Y3     |        |        |        |        |        | Y2[11:8] |        |        |        |        |        | +0x8   |        |        |        |        |        | +0xC     |        |        |        |        |        |        |
| Y7[7:0] |        |        |        |        |        | Y6     |        |        |        |        |        | Y5       |        |        |        |        |        | Y8     |        |        |        |        |        | Y7[11:8] |        |        |        |        |        |        |
|         |        |        |        |        |        |        |        |        |        |        |        |          |        |        |        |        |        |        |        |        |        |        |        |          |        |        |        |        |        |        |

|          |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |           |        |        |        |        |        |        |
|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-----------|--------|--------|--------|--------|--------|--------|
| 3<br>1   | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 6<br>7    | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Cb1[7:0] |        |        |        |        |        | Cr0    |        |        |        |        |        | Cb0    |        |        |        |        |        | +0x0   |        |        |        |        |        | +0x4      |        |        |        |        |        |        |
| Cr3[7:0] |        |        |        |        |        | Cb3    |        |        |        |        |        | Cr1    |        |        |        |        |        | Cr2    |        |        |        |        |        | Cr3[11:8] |        |        |        |        |        |        |
|          |        |        |        |        |        | Cr4    |        |        |        |        |        | Cb4    |        |        |        |        |        | +0x8   |        |        |        |        |        | +0xC      |        |        |        |        |        |        |
|          |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        | dispc-312 |        |        |        |        |        |        |

**Figure 12-488. DISPC YUV 12-bit Pixel Formats 2**

Figure 12-489 through Figure 12-491 show the pixel data memory organization for the YUV 10-bit/12-bit unpacked pixel formats in 16-bit container, together with some specific register settings.

YUV 10-bit/12-bit unpacked formats have the same component packing order as 8-bit formats except that each component is stored in a 16-bit container (with MSB or LSB bits within the 16-bit container not used depending on the MSB/LSB alignment).

ATTRIBUTES2.YUV\_SIZE = 1 or 2 (10b or 12b)

ATTRIBUTES2.YUV\_MODE = 1 (Unpacked)

ATTRIBUTES2.YUV\_ALIGN = 0 or 1 (LSB or MSB aligned)

YUV422 (1-plane)

10-bit unpacked LSB aligned

YUV2 4:2:2 – 10bit (0x3E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 7<br>6 | 6<br>5 | 5<br>4 | 4<br>3 | 3<br>2 | 2<br>1 | 1<br>0 |
| unused |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | +0x0   |        |        |
| unused |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | +0x4   |        |        |

UYVY 4:2:2 – 10bit (0x3F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 7<br>6 | 6<br>5 | 5<br>4 | 4<br>3 | 3<br>2 | 2<br>1 | 1<br>0 |
| unused |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | +0x0   |        |        |
| unused |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | +0x4   |        |        |

10-bit unpacked MSB aligned

YUV2 4:2:2 – 10bit (0x3E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 7<br>6 | 6<br>5 | 5<br>4 | 4<br>3 | 3<br>2 | 2<br>1 | 1<br>0 |
| Cb0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | unused |        |        |        |        |        |        | +0x0   |        |        |
| Cr0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | unused |        |        |        |        |        |        | +0x4   |        |        |

UYVY 4:2:2 – 10bit (0x3F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 8<br>7 | 7<br>6 | 6<br>5 | 5<br>4 | 4<br>3 | 3<br>2 | 2<br>1 | 1<br>0 |
| Y0     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | +0x0   |        |        |
| Y1     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | +0x4   |        |        |

dispc-313

**Figure 12-489. DISPC YUV 10-bit/12-bit Unpacked Pixel Formats 1**

YUV422 (1-plane)

12-bit unpacked LSB aligned

YUV2 4:2:2 – 12bit (0x3E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| unused |        |        |        |        |        | Cb0    |        |        |        |        |        | unused |        |        |        |        |        | Y0     |        |        |        |        |        | +0x0   |        |        |        |        |        |        |
| unused |        |        |        |        |        | Cr0    |        |        |        |        |        | unused |        |        |        |        |        | Y1     |        |        |        |        |        | +0x4   |        |        |        |        |        |        |

UYVY 4:2:2 – 12bit (0x3F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| unused |        |        |        |        |        | Y0     |        |        |        |        |        | unused |        |        |        |        |        | Cb0    |        |        |        |        |        | +0x0   |        |        |        |        |        |        |
| unused |        |        |        |        |        | Y1     |        |        |        |        |        | unused |        |        |        |        |        | Cr0    |        |        |        |        |        | +0x4   |        |        |        |        |        |        |

12-bit unpacked MSB aligned

YUV2 4:2:2 – 12bit (0x3E)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Cb0    |        |        |        |        |        | unused |        |        |        |        |        | Y0     |        |        |        |        |        | unused |        |        |        |        |        | +0x0   |        |        |        |        |        |        |
| Cr0    |        |        |        |        |        | unused |        |        |        |        |        | Y1     |        |        |        |        |        | Cr0    |        |        |        |        |        | unused |        |        |        |        |        |        |

UYVY 4:2:2 – 12bit (0x3F)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9<br>8 | 7<br>8 | 6<br>7 | 5<br>6 | 4<br>5 | 3<br>4 | 2<br>3 | 1<br>2 | 0<br>1 |
| Y0     |        |        |        |        |        | unused |        |        |        |        |        | Cb0    |        |        |        |        |        | unused |        |        |        |        |        | 0x0    |        |        |        |        |        |        |
| Y1     |        |        |        |        |        | unused |        |        |        |        |        | Cr0    |        |        |        |        |        | unused |        |        |        |        |        |        |        |        |        |        |        |        |

dispc-314

**Figure 12-490. DISPC YUV 10-bit/12-bit Unpacked Pixel Formats 2**

## YUV420 (2-plane)

10-bit unpacked LSB aligned

## YUV 4:2:0 – NV12 (10-bit) (0x3D)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| unused |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y0     |   |   |   |   |   |   | +0x0 |   |   |   |
| unused |        |        |        |        |        |        | Y3     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y2     |   |   |   |   |   |   | +0x4 |   |   |   |

  

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| unused |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb0    |   |   |   |   |   |   | +0x0 |   |   |   |
| unused |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb1    |   |   |   |   |   |   | +0x4 |   |   |   |

10-bit unpacked MSB aligned

## YUV 4:2:0 – NV12 (10-bit) (0x3D)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| Y1     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x0 |   |   |   |
| Y3     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y2     |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x4 |   |   |   |

  

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| Cr0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x0 |   |   |   |
| Cr1    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb1    |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x4 |   |   |   |

12-bit unpacked LSB aligned

## YUV 4:2:0 – NV12 (12-bit) (0x3D)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| unused |        |        |        |        |        |        | Y1     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y0     |   |   |   |   |   |   | +0x0 |   |   |   |
| unused |        |        |        |        |        |        | Y3     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y2     |   |   |   |   |   |   | +0x4 |   |   |   |

  

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| unused |        |        |        |        |        |        | Cr0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb0    |   |   |   |   |   |   | +0x0 |   |   |   |
| unused |        |        |        |        |        |        | Cr1    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb1    |   |   |   |   |   |   | +0x4 |   |   |   |

12-bit unpacked MSB aligned

## YUV 4:2:0 – NV12 (12-bit) (0x3D)

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| Y1     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y0     |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x0 |   |   |   |
| Y3     |        |        |        |        |        |        | unused |        |        |        |        |        |        | Y2     |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x4 |   |   |   |

  

|        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |      |   |   |   |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|------|---|---|---|
| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
| Cr0    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb0    |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x0 |   |   |   |
| Cr1    |        |        |        |        |        |        | unused |        |        |        |        |        |        | Cb1    |        |        |        |        |        |        | unused |   |   |   |   |   |   | +0x4 |   |   |   |

dispc-315

**Figure 12-491. DISPC YUV 10-bit/12-bit Unpacked Pixel Formats 3**

#### 12.9.1.4.1.8 DISPC Video Pipelines

DISPC includes two input pipelines:

- Video pipeline (VID)
- Video lite pipeline (VIDL1)

The video pipeline (VID) consists of:

- VC-1 range mapping unit for YUV422/YUV420 input formats;
- Replication logic for ARGB input formats;
- One 256 x 24-bit entries Color Look-up Table (CLUT);
- Polyphase-filter based resizer unit (scaler) supporting chroma upsampling;
- Color Space Conversion (CSC) unit (YUV to RGB), which can be used also for programmable BCHS (Brightness/Contrast/Hue/Saturation) control;

The video lite pipeline (VIDL1) is identical to the video pipeline (VID), except for:

- Polyphase-filter based resizer (scaler) is not included;
- Chroma upsampling is done using dedicated YUV420-to-422 and YUV422-to-444 upsamplers (instead of using the scaler);

Each pipeline processing block can be independently bypassed.



**Figure 12-492. DISPC Video Pipeline Configuration**



**Figure 12-493. DISPC Video Lite Pipeline Configuration**

The input of each pipeline is connected to the video DMA buffer controller. Each pipeline pixel output is always connected to the overlay managers (OVR1 and OVR2). Each pipeline configuration supports various BITMAP, RGB (ARGB and RGBA), and YUV formats, as listed in [Table 12-422, DISPC Pixel Data Formats](#).

The 256-entry CLUT is either used to convert BITMAP (1, 2, 4, or 8-bit indexed formats) into RGB format, or for RGB to RGB inverse gamma correction. For a BITMAP format data, scaling is not supported. Scaling and color

look-up table features are mutually exclusive. If the color look-up feature is enabled, then video pipeline scaler has to be disabled.

For chroma sub-sampled YUV formats (YUV422 and YUV420-NV12/NV21):

- VID pipeline: the scaler unit upsamples the chrominance data using both vertical and horizontal polyphase filters;
- VID1 pipeline: dedicated YUV420 to YUV422, and YUV422 to YUV444 chroma upsamplers are used;

For ARGB source data with less than/equal to 10-bit component data size the replication logic (ARGB expansion) converts the data to ARGB48 by replicating the MSBs into the LSBs:

- When scaling is disabled (or no scaler supported), the resulting ARGB48 data is directly provided to the pipeline output;
- When vertical scaling is engaged, the resulting ARGB48 data is first truncated to ARGB8888, and then converted to ARGB10101010 (by MSBs replication into LSBs), before being fed to the vertical scaler input;
- When vertical scaling is disabled, but horizontal scaling is engaged, the resulting ARGB48 data is directly provided to the horizontal scaler input;

A pipeline can be enabled by setting the DSS0\_VID\_ATTRIBUTES[0] ENABLE register bit. If the video pipeline is disabled, the video window does not exist on the screen and the whole video pipeline and its DMA are inactive. Prior to enabling the video layer a valid configuration has to be set by the user.

---

#### Note

The DISPC input pipelines, VID and VID1L, will be commonly referred to as *video pipeline (VID)* in the following sections. Any differences in their functionality will be highlighted.

---

#### 12.9.1.4.1.8.1 DISPC VID Replication Logic

The replication logic (ARGB expansion) converts ARGB pixel formats into ARGB48 format by replicating the MSBs into the LSBs. The logic is always enabled.

Table 12-423 shows how some of the ARGB formats supported by video pipelines are remapped into ARGB48 by default.

**Table 12-423. DISPC VID Replication: ARGB Pixel Formats Remapping into ARGB48-12121212**

| Formats     | A[11:0]            | R[11:0]            | G[11:0]            | B[11:0]            |
|-------------|--------------------|--------------------|--------------------|--------------------|
|             | MSB - LSB          | MSB - LSB          | MSB - LSB          | MSB - LSB          |
| xRGB12-4444 | 111111111111       | R[3:0]R[3:0]R[3:0] | G[3:0]G[3:0]G[3:0] | B[3:0]B[3:0]B[3:0] |
| RGBx12-4444 | 111111111111       | R[3:0]R[3:0]R[3:0] | G[3:0]G[3:0]G[3:0] | B[3:0]B[3:0]B[3:0] |
| RGB16-565   | 111111111111       | R[4:0]R[4:0]R[4:3] | G[5:0]G[5:0]       | B[4:0]B[4:0]B[4:3] |
| xRGB16-1555 | 111111111111       | R[4:0]R[4:0]R[4:3] | G[4:0]G[4:0]G[4:3] | B[4:0]B[4:0]B[4:3] |
| ARGB16-1555 | AAAAAAAAAA         | R[4:0]R[4:0]R[4:3] | G[4:0]G[4:0]G[4:3] | B[4:0]B[4:0]B[4:3] |
| ARGB16-4444 | A[3:0]A[3:0]A[3:0] | R[3:0]R[3:0]R[3:0] | G[3:0]G[3:0]G[3:0] | B[3:0]B[3:0]B[3:0] |
| RGBA16-4444 | A[3:0]A[3:0]A[3:0] | R[3:0]R[3:0]R[3:0] | G[3:0]G[3:0]G[3:0] | B[3:0]B[3:0]B[3:0] |
| ARGB32-8888 | A[7:0]A[7:4]       | R[7:0]R[7:4]       | G[7:0]G[7:4]       | B[7:0]B[7:4]       |

#### 12.9.1.4.1.8.2 DISPC VID VC-1 Range Mapping Unit

The VC-1 range mapping unit is used when the video frame picture is decoded using a VC-1 codec by the video accelerator. It remaps the Y, Cb, and Cr components to the full range (from the reduced data range) before displaying. The unit is used primarily for YUV4:2:0-NV12 (NV21) pixel format, but also can be applied to YUV4:2:2 pixel formats (YUV2 and UYVY).

The VC-1 range mapping unit is enabled by setting the DSS0\_VID\_ATTRIBUTES2 [0] VC1ENABLE bit to 0x1. The VC-1 range mapping must be enabled only for 8 bits/component YUV input data.

The DSS0\_VID\_ATTRIBUTES2 [3:1] VC1\_RANGE\_Y and [6:4] VC1\_RANGE\_CBCR bit fields are two 3-bit values programmed by the user.

The equations for the mapping process are:

$$Y_{out} = CLIP(((Y_{int} - 128) \times (VC1\_RANGE\_Y + 9) + 4) / 8) + 128$$

$$C_b = CLIP(((C_b - 128) \times (VC1\_RANGE\_CBCR + 9) + 4) / 8) + 128$$

$$C_r = CLIP(((C_r - 128) \times (VC1\_RANGE\_CBCR + 9) + 4) / 8) + 128$$

---

#### Note

The input and output pixel values are unsigned (Y, Cr, and Cb).

The function CLIP () clips to 0 or 255 when minimum or maximum, respectively, is reached. Otherwise, the resulting output remains identical.

---

#### 12.9.1.4.1.8.3 DISPC VID Color Look-Up Table (CLUT)

The video pipeline supports a look up table to perform either of the following operations:

- Conversions of BITMAP formats (1, 2, 4, or 8-bit indexed) into RGB24 format (CLUT mode), or
- Inverse gamma correction on non-linear RGB source data (gamma mode)

The look-up table consists of 3 separate 256 x 8-bit memories and is indexed either by the source BITMAP data or by R/G/B component data. The table is loaded through direct register access by writing to the CLUT registers.

The sequence to load the table is:

1. SW writes (only writes are supported) 32-bit values using single access, or burst access in linear increment burst mode, into DSS0\_VID\_CLUT\_0 through DSS0\_VID\_CLUT\_15 registers. The LSB 24 bits [23:0] are used for the value, and the MSB 8 bits [31:24] are used for the index into the table (see [Figure 12-494](#)).
2. Loop to Step 1, if there is a new access to the CLUT registers. Software can access other registers between two accesses to the CLUT registers.

SW needs to ensure that there is no visible effect when modifying the table, since it is not under hardware control.

The usage of the look-up table in CLUT mode is activated when a BITMAP format is selected in the DSS0\_VID\_ATTRIBUTES[6:1] FORMAT register bit-field.

The usage of the look-up table for RGB inverse gamma correction can be enabled by setting DSS0\_VID\_ATTRIBUTES[30] GAMMAINVERSION register bit.



**Figure 12-494. DISPC VID CLUT/Gamma Data Memory Organization**

---

#### Note

Scaling and color look-up table features are mutually exclusive. If color look-up feature is enabled, then video pipeline scaler has to be disabled.

---

#### 12.9.1.4.1.8.4 DISPC VID Chrominance Resampling

##### 12.9.1.4.1.8.4.1 Chrominance Resampling for VID Pipeline

The chrominance resampling from 8-bpc or 10-bpc to 12-bit color components is always performed using filtering (the scaler unit filter). Chrominance resampling and rescaling can be combined to support native rescaling of YUV formats.

The usage of the scaler unit for resampling the chrominance of YUV420 and YUV422 is shown in [Figure 12-495](#) and [Figure 12-496](#), respectively. The settings of the scaler unit to perform chrominance resampling are described in [Section 12.9.1.4.1.8.5, DISPC VID Scaler Unit](#).



**Figure 12-495. DISPC VID YUV420 to ARGB48 Using Scaler Unit for Resampling Chrominance**



**Figure 12-496. DISPC VID YUV422 to ARGB48 Using Scaler Unit for Resampling Chrominance**

The vertical scaler is not a mandatory block for resampling the chrominance of YUV422 data, as shown in [Figure 12-496](#).

#### 12.9.1.4.1.8.4.2 Chrominance Resampling for VIDL1 Pipeline

VIDL1 pipeline does not include a scaler unit. Chroma upsampling is done using dedicated YUV420 to YUV422, and YUV422 to YUV444 chroma upsamplers.

VIDL1 pipeline converts YUV420 (chroma) data to YUV422 (chroma) using a simple vertical average filter (average of two adjacent chroma lines to generate a missing line except for the very bottom line which is generated by repeating the previous chroma line). If the video image is a sub-image of a larger video frame data, then the vertical Luma line offset from the top should be an even number.

VIDL1 pipeline converts YUV422 data to YUV444 format using a 4-tap filter (implementing the Catmull-Rom algorithm) to generate missing chroma data as shown below:

$$Cout[2*i] = Cin[i]$$

$$Cout[2*i+1] = CLIP (-1/16*Cin[i-1] + 9/16*Cin[i] + 9/16*Cin[i+1] - 1/16*Cin[i+2])$$

The missing chroma data is generated as a simple weighted average of the surrounding 4 chroma values, which is equivalent to a 4x1 filter kernel with values: [-1/16, 9/16, 9/16, -1/16]. In this algorithm, edge effects are treated by repeating the first and last pixel.

#### 12.9.1.4.1.8.5 DISPC VID Scaler Unit

##### Note

Only VID pipeline includes a resizer unit (scaler). VIDL1 pipeline does not include a scaler.

The programmable scaler filter works with all supported video formats, including formats with alpha channel. Alpha channel is scaled with the same parameters as RGB color components. For the YUV formats, Y and Cb/Cr are processed independently. An RGB 64-bit source (16 bits per component) is truncated to 8-bit, if scaler is enabled. Otherwise, it will be truncated to ARGB48 format in the scaler bypass mode. 10-bit/12-bit YUV source is also truncated to 8-bit, since the scaler is enabled to either upsample the chroma component and/or resize the YUV frame data directly.

The filter is based on a finite impulse response (FIR) filter with 16 phases. The filter is a 5-tap for horizontal filtering, and can be configured for 3 or 5 taps for vertical filtering. The filtering can be used for various processing:

- Up-sampling of the picture
- Down-sampling of the picture
- Anti-aliasing reduction
- Chrominance resampling in case of YUV data formats

The following limitations must be considered:

- The up-sampling ratio is up to x16.
- The down-sampling ratio using 3-tap configuration is down to x0.5 for RGB format.
- The down-sampling ratio using 5-tap configuration is down to x0.25 for RGB format.

#### Note

The user must set the correct size and position of the original video before resize in order for the up-sampled/down-sampled video to be displayed inside the screen boundaries.

Figure 12-497 shows an example of video up-sampling, with corresponding video window attributes.



**Figure 12-497. DISPC Video Window Attributes**

The video window attributes can be configured in the following register bit-fields:

- Source data format (input to the scaler unit) in DSS0\_VID\_ATTRIBUTES [6-1] FORMAT bit-field
- Video picture width in system memory (frame buffer) in DSS0\_VID\_PICTURE\_SIZE [11-0] MEMSIZEX bit-field. The window width is from 1 up to 4096 pixels. All the integer values in the range [1:4096] are allowed except for YUV 422 formats. In case of YUV2422 and UYVY422 formats the width has to be a multiple of 2 pixels.
- Video picture height in system memory (frame buffer) in DSS0\_VID\_PICTURE\_SIZE [27-16] MEMSIZEY bit-field. The window width is from 1 up to 4096 pixels. All the integer values in the range [1:4096] are allowed.
- Video window width at pipeline output (after resizing) in DSS0\_VID\_SIZE [11-0] SIZEX bit-field. The window width is from 1 up to 4096 pixels. All the integer values in the range [1:4096] are allowed up to the screen width minus the horizontal start location of the window on the screen.

- Video window height at pipeline output (after resizing) in DSS0\_VID\_SIZE [27-16] SIZEY bit-field. The window height is from 1 up to 4096 pixels. All the integer values in the range [1:4096] are allowed up to the screen height minus the vertical start location of the window on the screen.
- Video window overlay X-position in DSS0\_OVR\_ATTRIBUTES\_0 [17-6] POSX bit-field. See [Section 12.9.1.4.1.9, DISPC Overlay Managers](#).
- Video window overlay Y-position in DSS0\_OVR\_ATTRIBUTES\_0 [30-19] POSY bit-field. See [Section 12.9.1.4.1.9, DISPC Overlay Managers](#).
- For configuration of LPP and PPL video port output display parameters, see [Section 12.9.1.4.1.10.7, DISPC VP Timing Generator and Display Panel Settings](#).

For vertical up-sampling and down-sampling in a 3-tap configuration, the equations are:

| <p style="text-align: center;">For RGB formats</p> $Aout(n) = \left( \sum_{i=-1}^{i=1} Ci(\Phi) \times Ain(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Rout(n) = \left( \sum_{i=-1}^{i=1} Ci(\Phi) \times Rin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Gout(n) = \left( \sum_{i=-1}^{i=1} Ci(\Phi) \times Gin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Bout(n) = \left( \sum_{i=-1}^{i=1} Ci(\Phi) \times Bin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$                                                                                                                                                                                                                                                                                                                                                                                                                   | <p style="text-align: center;">For YUV formats</p> $Yout(n) = \left( \sum_{i=-1}^{i=1} Cyi(\Phi y) \times Yin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Cout(n) = \left( \sum_{i=-1}^{i=1} Cci(\Phi c) \times Cbin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Crout(n) = \left( \sum_{i=-1}^{i=1} Cci(\Phi c) \times Crin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ |            |          |            |                            |         |         |                       |         |         |                         |         |         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|------------|----------------------------|---------|---------|-----------------------|---------|---------|-------------------------|---------|---------|
| <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th style="text-align: left; padding: 2px;">Component</th> <th style="text-align: left; padding: 2px;">Vertical</th> <th style="text-align: left; padding: 2px;">Horizontal</th> </tr> </thead> <tbody> <tr> <td style="text-align: left; padding: 2px;">Cwidth (Coefficient Width)</td> <td style="text-align: left; padding: 2px;">10 bits</td> <td style="text-align: left; padding: 2px;">10 bits</td> </tr> <tr> <td style="text-align: left; padding: 2px;">InWidth (Input Width)</td> <td style="text-align: left; padding: 2px;">10 bits</td> <td style="text-align: left; padding: 2px;">12 bits</td> </tr> <tr> <td style="text-align: left; padding: 2px;">OutWidth (Output Width)</td> <td style="text-align: left; padding: 2px;">12 bits</td> <td style="text-align: left; padding: 2px;">12 bits</td> </tr> </tbody> </table> |                                                                                                                                                                                                                                                                                                                                                                                                          | Component  | Vertical | Horizontal | Cwidth (Coefficient Width) | 10 bits | 10 bits | InWidth (Input Width) | 10 bits | 12 bits | OutWidth (Output Width) | 12 bits | 12 bits |
| Component                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Vertical                                                                                                                                                                                                                                                                                                                                                                                                 | Horizontal |          |            |                            |         |         |                       |         |         |                         |         |         |
| Cwidth (Coefficient Width)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 10 bits                                                                                                                                                                                                                                                                                                                                                                                                  | 10 bits    |          |            |                            |         |         |                       |         |         |                         |         |         |
| InWidth (Input Width)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10 bits                                                                                                                                                                                                                                                                                                                                                                                                  | 12 bits    |          |            |                            |         |         |                       |         |         |                         |         |         |
| OutWidth (Output Width)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 12 bits                                                                                                                                                                                                                                                                                                                                                                                                  | 12 bits    |          |            |                            |         |         |                       |         |         |                         |         |         |

(10)

For vertical and horizontal up-sampling and down-sampling in a 5-tap configuration, the equations are:

| <p style="text-align: center;">For RGB formats</p> $Aout(n) = \left( \sum_{i=-2}^{i=2} Ci(\Phi) \times Ain(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Rout(n) = \left( \sum_{i=-2}^{i=2} Ci(\Phi) \times Rin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Gout(n) = \left( \sum_{i=-2}^{i=2} Ci(\Phi) \times Gin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Bout(n) = \left( \sum_{i=-2}^{i=2} Ci(\Phi) \times Bin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$                                                                                                                                                                                                                                                                                                                                                                                                                   | <p style="text-align: center;">For YUV formats</p> $Yout(n) = \left( \sum_{i=-2}^{i=2} Cyi(\Phi y) \times Yin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Cout(n) = \left( \sum_{i=-2}^{i=2} Cci(\Phi c) \times Cbin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ $Crout(n) = \left( \sum_{i=-2}^{i=2} Cci(\Phi c) \times Crin(n+i) \right) \gg (Cwidth - (OutWidth - InWidth) - 1)$ |            |          |            |                            |         |         |                       |         |         |                         |         |         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|------------|----------------------------|---------|---------|-----------------------|---------|---------|-------------------------|---------|---------|
| <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th style="text-align: left; padding: 2px;">Component</th> <th style="text-align: left; padding: 2px;">Vertical</th> <th style="text-align: left; padding: 2px;">Horizontal</th> </tr> </thead> <tbody> <tr> <td style="text-align: left; padding: 2px;">Cwidth (Coefficient Width)</td> <td style="text-align: left; padding: 2px;">10 bits</td> <td style="text-align: left; padding: 2px;">10 bits</td> </tr> <tr> <td style="text-align: left; padding: 2px;">InWidth (Input Width)</td> <td style="text-align: left; padding: 2px;">10 bits</td> <td style="text-align: left; padding: 2px;">12 bits</td> </tr> <tr> <td style="text-align: left; padding: 2px;">OutWidth (Output Width)</td> <td style="text-align: left; padding: 2px;">12 bits</td> <td style="text-align: left; padding: 2px;">12 bits</td> </tr> </tbody> </table> |                                                                                                                                                                                                                                                                                                                                                                                                          | Component  | Vertical | Horizontal | Cwidth (Coefficient Width) | 10 bits | 10 bits | InWidth (Input Width) | 10 bits | 12 bits | OutWidth (Output Width) | 12 bits | 12 bits |
| Component                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Vertical                                                                                                                                                                                                                                                                                                                                                                                                 | Horizontal |          |            |                            |         |         |                       |         |         |                         |         |         |
| Cwidth (Coefficient Width)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 10 bits                                                                                                                                                                                                                                                                                                                                                                                                  | 10 bits    |          |            |                            |         |         |                       |         |         |                         |         |         |
| InWidth (Input Width)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10 bits                                                                                                                                                                                                                                                                                                                                                                                                  | 12 bits    |          |            |                            |         |         |                       |         |         |                         |         |         |
| OutWidth (Output Width)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 12 bits                                                                                                                                                                                                                                                                                                                                                                                                  | 12 bits    |          |            |                            |         |         |                       |         |         |                         |         |         |

(11)

### Note

The pixel (n + 1) is the previous pixel with respect to pixel (n). The line (n + 1) is the previous line with respect to line (n).

The coefficients Ci() depend on the phase between input and output pixels.

The coefficients are different for Y and Cr/Cb filtering because the calculations are independent due to the chrominance resampling for YUV422 and YUV420.

First, the vertical filter is applied to the encoded input pixel data, and then the horizontal filter is applied on the resulting pixel values to generate the output pixel values. The vertical input of the filter consists of:

- Six lines of  $1280 \times 32$  bits for 5-tap configuration
- Three lines of  $2560 \times 32$  bits for 3-tap configuration

Table 12-424 lists some of the scaler supported configurations.

**Table 12-424. DISPC VID Line Buffer Width for Scaler Unit**

| Pixel Format                                        | Maximum Input Width (Pixels) for 5-tap | Maximum Input Width (Pixels) for 3-tap |
|-----------------------------------------------------|----------------------------------------|----------------------------------------|
| 32 bits per pixel (ARGB32-8888, ARGB-2101010, etc.) | 1280 pixels wide <sup>(1)</sup>        | 2560 pixels wide                       |
| YUV420, YUV422                                      | 2560 pixels wide                       | 4096 pixels wide                       |

- (1) For the 5-tap configuration, the 6th video line is used on the output of the horizontal scaler, so that horizontal down-scaling can be supported with a minimum clock ratio equal to 1. The maximum output width is limited to 1280 pixels in order to be able to support clock ratio of 1 due to the 6th video line buffer. The 6th video line is also used in order to start the next output line generation while the video pipeline output is being stalled by the overlay manager (either due to display in blanking period and/or in background pixel period). The 6th line buffer is actually 48-bit wide to allow storage of ARGB48 format pixel data.

At the beginning of frame scaling processing, the first line may be duplicated multiple times depending on the initial vertical phase programmed for the poly-phase filter.

At the end of frame scaling processing the last line is duplicated, if the scaling logic requires loading more lines and the last line has been reached.

Similarly, the first pixel may be duplicated multiple times depending on the initial horizontal phase programmed for the poly-phase filter. The last pixel is duplicated, if the scaling logic requires loading more pixels and the last pixel has been reached.

The programmable coefficients of the polyphase filters are signed 10-bit values (except for the central coefficient, which is unsigned). The vertical video scaler has a 10-bit input and a 12-bit output. The horizontal scaling stage takes the resulting 12-bit input and produces 12-bit output.

Figure 12-498 and Figure 12-499 show the scaler macro-architecture for components A, R, G, and B. Figure 12-500 and Figure 12-501 show the scaler macro-architecture for components Y, Cr, and Cb.

#### Note

The scaling and CSC clipping is set by the same bit, DSS0\_VID\_ATTRIBUTES[11] FULLRANGE.



**Figure 12-498. DISPC VID Macro-Architecture of the Horizontal Scaling for A, R, G, and B Components (5-tap Restriction)**



**Figure 12-499. DISPC VID Macro-Architecture of the Vertical Scaling for A, R, G, and B Components (5 taps only)**



**Figure 12-500. DISPC VID Macro-Architecture of the Horizontal Scaling for Y, Cr, and Cb Components (5-tap Restriction)**



**Figure 12-501. DISPC VID Macro-Architecture of the Vertical Scaling for Y, Cr, and Cb Components (5 and 3 taps)**

Table 12-425 list the register fields in the function of the coefficients for the VID horizontal scaler in the DSS0\_VID\_FIR\_COEF\_H0\_0 to DSS0\_VID\_FIR\_COEF\_H0\_8, and DSS0\_VID\_FIR\_COEF\_H12\_0 to DSS0\_VID\_FIR\_COEF\_H12\_15 registers.

**Table 12-425. DISPC Register Fields Associated to Coefficients for ARGB and Y Configuration in VID Horizontal Scaler**

| Phases | Ch(2)                                      | Ch(1)                                      | Ch(0)                                              | Ch(-1)                                     | Ch(-2)                                     |
|--------|--------------------------------------------|--------------------------------------------|----------------------------------------------------|--------------------------------------------|--------------------------------------------|
|        | Signed coefficient [29-20] FIRHC2 bitfield | Signed coefficient [19-10] FIRHC1 bitfield | Unsigned central coefficient [9-0] FIRHC0 bitfield | Signed coefficient [19-10] FIRHC1 bitfield | Signed coefficient [29-20] FIRHC2 bitfield |
| 0      | DSS0_VID_FIR_COE_F_H12_0                   | DSS0_VID_FIR_COE_F_H12_0                   | DSS0_VID_FIR_COE_F_H0_0                            | DSS0_VID_FIR_COE_F_H12_0                   | DSS0_VID_FIR_COE_F_H12_0                   |
| 1      | DSS0_VID_FIR_COE_F_H12_1                   | DSS0_VID_FIR_COE_F_H12_1                   | DSS0_VID_FIR_COE_F_H0_1                            | DSS0_VID_FIR_COE_F_H12_15                  | DSS0_VID_FIR_COE_F_H12_15                  |
| 2      | DSS0_VID_FIR_COE_F_H12_2                   | DSS0_VID_FIR_COE_F_H12_2                   | DSS0_VID_FIR_COE_F_H0_2                            | DSS0_VID_FIR_COE_F_H12_14                  | DSS0_VID_FIR_COE_F_H12_14                  |
| 3      | DSS0_VID_FIR_COE_F_H12_3                   | DSS0_VID_FIR_COE_F_H12_3                   | DSS0_VID_FIR_COE_F_H0_3                            | DSS0_VID_FIR_COE_F_H12_13                  | DSS0_VID_FIR_COE_F_H12_13                  |
| 4      | DSS0_VID_FIR_COE_F_H12_4                   | DSS0_VID_FIR_COE_F_H12_4                   | DSS0_VID_FIR_COE_F_H0_4                            | DSS0_VID_FIR_COE_F_H12_12                  | DSS0_VID_FIR_COE_F_H12_12                  |
| 5      | DSS0_VID_FIR_COE_F_H12_5                   | DSS0_VID_FIR_COE_F_H12_5                   | DSS0_VID_FIR_COE_F_H0_5                            | DSS0_VID_FIR_COE_F_H12_11                  | DSS0_VID_FIR_COE_F_H12_11                  |
| 6      | DSS0_VID_FIR_COE_F_H12_6                   | DSS0_VID_FIR_COE_F_H12_6                   | DSS0_VID_FIR_COE_F_H0_6                            | DSS0_VID_FIR_COE_F_H12_10                  | DSS0_VID_FIR_COE_F_H12_10                  |
| 7      | DSS0_VID_FIR_COE_F_H12_7                   | DSS0_VID_FIR_COE_F_H12_7                   | DSS0_VID_FIR_COE_F_H0_7                            | DSS0_VID_FIR_COE_F_H12_9                   | DSS0_VID_FIR_COE_F_H12_9                   |
| 8      | DSS0_VID_FIR_COE_F_H12_8                   | DSS0_VID_FIR_COE_F_H12_8                   | DSS0_VID_FIR_COE_F_H0_8                            | DSS0_VID_FIR_COE_F_H12_8                   | DSS0_VID_FIR_COE_F_H12_8                   |
| 9      | DSS0_VID_FIR_COE_F_H12_9                   | DSS0_VID_FIR_COE_F_H12_9                   | DSS0_VID_FIR_COE_F_H0_7                            | DSS0_VID_FIR_COE_F_H12_7                   | DSS0_VID_FIR_COE_F_H12_7                   |
| 10     | DSS0_VID_FIR_COE_F_H12_10                  | DSS0_VID_FIR_COE_F_H12_10                  | DSS0_VID_FIR_COE_F_H0_6                            | DSS0_VID_FIR_COE_F_H12_6                   | DSS0_VID_FIR_COE_F_H12_6                   |
| 11     | DSS0_VID_FIR_COE_F_H12_11                  | DSS0_VID_FIR_COE_F_H12_11                  | DSS0_VID_FIR_COE_F_H0_5                            | DSS0_VID_FIR_COE_F_H12_5                   | DSS0_VID_FIR_COE_F_H12_5                   |
| 12     | DSS0_VID_FIR_COE_F_H12_12                  | DSS0_VID_FIR_COE_F_H12_12                  | DSS0_VID_FIR_COE_F_H0_4                            | DSS0_VID_FIR_COE_F_H12_4                   | DSS0_VID_FIR_COE_F_H12_4                   |

**Table 12-425. DISPC Register Fields Associated to Coefficients for ARGB and Y Configuration in VID Horizontal Scaler (continued)**

| Phases | Ch(2)                        | Ch(1)                        | Ch(0)                      | Ch(-1)                      | Ch(-2)                      |
|--------|------------------------------|------------------------------|----------------------------|-----------------------------|-----------------------------|
| 13     | DSS0_VID_FIR_COE<br>F_H12_13 | DSS0_VID_FIR_COE<br>F_H12_13 | DSS0_VID_FIR_COE<br>F_H0_3 | DSS0_VID_FIR_COE<br>F_H12_3 | DSS0_VID_FIR_COE<br>F_H12_3 |
| 14     | DSS0_VID_FIR_COE<br>F_H12_14 | DSS0_VID_FIR_COE<br>F_H12_14 | DSS0_VID_FIR_COE<br>F_H0_2 | DSS0_VID_FIR_COE<br>F_H12_2 | DSS0_VID_FIR_COE<br>F_H12_2 |
| 15     | DSS0_VID_FIR_COE<br>F_H12_15 | DSS0_VID_FIR_COE<br>F_H12_15 | DSS0_VID_FIR_COE<br>F_H0_1 | DSS0_VID_FIR_COE<br>F_H12_1 | DSS0_VID_FIR_COE<br>F_H12_1 |

### Note

In Table 12-425, the cells without color are duplicated from the grey cells.

Similar table approach applies to the vertical scaler (registers DSS0\_VID\_FIR\_COEF\_V0\_0 to DSS0\_VID\_FIR\_COEF\_V0\_8, and DSS0\_VID\_FIR\_COEF\_V12\_0 to DSS0\_VID\_FIR\_COEF\_V12\_15 are used).

Similar table approach applies to the coefficients for Cb/Cr filtering in case of YUV format (registers DSS0\_VID\_FIR\_COEF\_H0\_C\_0 to DSS0\_VID\_FIR\_COEF\_H0\_C\_8, and DSS0\_VID\_FIR\_COEF\_H12\_C\_0 to DSS0\_VID\_FIR\_COEF\_H12\_C\_15, and DSS0\_VID\_FIR\_COEF\_V0\_C\_0 to DSS0\_VID\_FIR\_COEF\_V0\_C\_8 and DSS0\_VID\_FIR\_COEF\_V12\_C\_0 to DSS0\_VID\_FIR\_COEF\_V12\_C\_15 are used).

The VID scaler unit vertical and/or horizontal sampling is selected by configuring the DSS0\_VID\_ATTRIBUTES[8-7] RESIZEENABLE bit field.

Prior to enabling the video up/down-sampling block a valid configuration has to be set by the user. After configuring the required VID registers change the DSS0\_VP\_CONTROL[5] GOBIT register bit of the video port the video pipeline is associated with. The software has to wait before setting the GO bit that the hardware has reset the bit. The software reset is not recommended since the application cannot guarantee to be able to reset it before the H/W.

The following fields define the configuration of the video up-sampling/down-sampling block in the VID pipeline for ARGB and YUV formats:

- Vertical upsampling and downsampling increment value in the [23-0] FIRVINC bit field of DSS0\_VID\_FIRV (for ARGB and Y) and DSS0\_VID\_FIRV2 (for CbCr) registers. The unsigned integer value range is  $2^{23}$ . Software calculates the value using the following equation:

$$FIRVINC = 2^{21} * \left( \frac{MEMSIZEY+1}{SIZEY+1} \right)$$

dispc-066

- Horizontal upsampling and downsampling increment value in the [23-0] FIRHINC bit field of the DSS0\_VID\_FIRH (for ARGB and Y) and DSS0\_VID\_FIRH2 (for CbCr) registers. The unsigned integer value range is [1:16384]. Software calculates the value using the following equation:

$$FIRHINC = 2^{21} * \left( \frac{MEMSIZEH+1}{SIZEH+1} \right)$$

dispc-067

- Vertical up/downsampling accumulator value in the [23-0] VERTICALACCU bit field of the DSS0\_VID\_ACCUV\_0 and DSS0\_VID\_ACCUV\_1 (for ARGB and Y), and DSS0\_VID\_ACCUV2\_0 and DSS0\_VID\_ACCUV2\_1 (for CbCr) registers. The accumulator value indicates on which phase the vertical filtering starts. The DSS0\_VID\_ACCUV\_0 register is used for progressive output, while for interlace output both DSS0\_VID\_ACCUV\_0 and DSS0\_VID\_ACCUV\_1 registers are used. The DSS0\_VID\_ACCUV2\_0 and DSS0\_VID\_ACCUV2\_1 registers are used in the same manner for progressive or interlace output.

- Vertical upsampling and downsampling line buffer configuration via the DSS0\_VID\_ATTRIBUTES[21] VERTICALTAPS bit: The default value at reset time is 0x0 (3-tap configuration is used). If the bit field is reset, the 3-tap configuration is used.
- Horizontal upsampling and downsampling accumulator value in the [23-0] HORIZONTALACCU bit field of the DSS0\_VID\_ACCUH\_0 and DSS0\_VID\_ACCUH\_1 (for ARGB and Y), and DSS0\_VID\_ACCUH2\_0 and DSS0\_VID\_ACCUH2\_1 (for CbCr) registers. The accumulator value indicates on which phase the horizontal filtering starts. The register DSS0\_VID\_ACCUH\_0 is used for progressive output, while for interlace output both DSS0\_VID\_ACCUH\_0 and DSS0\_VID\_ACCUH\_1 registers are used. The DSS0\_VID\_ACCUH2\_0 and DSS0\_VID\_ACCUH2\_1 are used in the same manner for progressive or interlace output.

Table 12-426 lists the scaler vertical and horizontal accumulator values and phases.

**Table 12-426. DISPC VID Scaler Vertical and Horizontal Accumulator Phases**

| Accumulator Value<br>(MSB bits) | Phases f |
|---------------------------------|----------|
| 0                               | 0        |
| 256 or -3840                    | 1        |
| 512 or -3584                    | 2        |
| 768 or -3328                    | 3        |
| 1024 or -3072                   | 4        |
| 1280 or -2816                   | 5        |
| 1536 or -2560                   | 6        |
| 1792 or -2304                   | 7        |
| 2048 or -2048                   | 8        |
| 2304 or -1792                   | 9        |
| 2560 or -1536                   | 10       |
| 2816 or -1280                   | 11       |
| 3072 or -1024                   | 12       |
| 3328 or -768                    | 13       |
| 3584 or -512                    | 14       |
| 3840 or -256                    | 15       |

- Vertical upsampling and downsampling central coefficients:
  - For ARGB and Y, the vertical upsampling and downsampling central coefficients are defined in the DSS0\_VID\_FIR\_COEF\_V0\_0 to DSS0\_VID\_FIR\_COEF\_V0\_8 registers. There are 9 registers for the 16 phases with 1 coefficient for each of them. Symmetrical implementation is used, so only 9 coefficients are used. Each register contains one 10-bit unsigned coefficient (the central one).
  - Four CbCr, the vertical upsampling and downsampling central coefficients are set in DSS0\_VID\_FIR\_COEF\_V0\_C\_0 to DSS0\_VID\_FIR\_COEF\_V0\_C\_8 registers.
- Vertical upsampling and downsampling coefficients:
  - For ARGB and Y, the vertical upsampling and downsampling coefficients are defined in the DSS0\_VID\_FIR\_COEF\_V12\_0 to DSS0\_VID\_FIR\_COEF\_V12\_15 registers. There are 16 registers for the 16 phases with 2 coefficient for each of them, so a total of 32 programmable coefficients for the vertical up/down-sampling block. Each register contains two 10-bit signed coefficients.
  - Four CbCr, the vertical upsampling and downsampling coefficients are set in DSS0\_VID\_FIR\_COEF\_V12\_C\_0 to DSS0\_VID\_FIR\_COEF\_V12\_C\_15 registers.
- Horizontal upsampling and downsampling central coefficients:
  - For ARGB and Y, the horizontal upsampling and downsampling central coefficients are defined in the DSS0\_VID\_FIR\_COEF\_H0\_0 to DSS0\_VID\_FIR\_COEF\_H0\_8 registers. There are 9 registers for the 16 phases with 1 coefficient for each of them. Symmetrical implementation is used, so only 9 coefficients are used. Each register contains one 10-bit unsigned coefficient (the central one).

- Four CbCr, the horizontal upsampling and downsampling central coefficients are set in DSS0\_VID\_FIR\_COEF\_H0\_C\_0 to DSS0\_VID\_FIR\_COEF\_H0\_C\_8 registers.
- Horizontal upsampling and downsampling coefficients:
  - For ARGB and Y, the horizontal upsampling and downsampling coefficients are defined in the DSS0\_VID\_FIR\_COEF\_H12\_0 to DSS0\_VID\_FIR\_COEF\_H12\_15 registers. There are 16 registers for the 16 phases with 2 coefficient for each of them, so a total of 32 programmable coefficients for the horizontal up/down-sampling block. Each register contains two 10-bit signed coefficients.
  - Four CbCr, the horizontal upsampling and downsampling coefficients are set in DSS0\_VID\_FIR\_COEF\_H12\_C\_0 to DSS0\_VID\_FIR\_COEF\_H12\_C\_15 registers.

The YUV filtering is based on the equations of the ARGB filtering. In addition to the registers used for ARGB filtering configuration, a second set of registers for filtering is used. The first set of registers is used for Y configuration (instead of ARGB configuration) and the second set of registers is used for CbCr filtering configuration. The two sets of registers can be the same when the YUV format is not converted to RGB after filtering. When the RGB conversion is required after filtering, then the chrominance needs to be re-sampled with a different filtering configuration because:

- Chrominance samples are offset to the luminance samples. That is, DSS0\_VID\_FIRH2 and DSS0\_VID\_FIRV2, and DSS0\_VID\_ACCUV2\_0/DSS0\_VID\_ACCUV2\_1 and DSS0\_VID\_ACCUH2\_0/ DSS0\_VID\_ACCUH2\_1 registers need to be configured differently than DSS0\_VID\_FIRH and DSS0\_VID\_FIRV, and DSS0\_VID\_ACCUH\_0/DSS0\_VID\_ACCUH\_1 and DSS0\_VID\_ACCUV\_0/ DSS0\_VID\_ACCUV\_1 registers used for the luminance filtering.
- Chrominance is sub-sampled by two horizontally only in case of YUV422, and horizontally and vertically in case of YUV420. The coefficients for the vertical chrominance re-sampling are identical to the coefficients for vertical luminance filtering in case of YUV422. The coefficients for the horizontal and vertical chrominance re-sampling are different than the ones for luminance filtering in case of YUV420.

#### 12.9.1.4.1.8.6 DISPC VID Color Space Conversion YUV to RGB

The Color Space Conversion (CSC) unit converts the video-encoded pixel values from YUV444 format into ARGB48 format (12-bit value per component A, R, G, and B, with A fixed at 0xFFFF).

In case of YUV420 or YUV422 formats, a chrominance resampling to YUV444 is performed before converting the YUV into RGB values (see [Section 12.9.1.4.1.8.4, DISPC VID Chrominance Resampling](#)). The YUV422/YUV420 to YUV444 chrominance resampling is a pre-processing to the color space conversion.

[Figure 12-502](#) and [Figure 12-503](#) show the  $3 \times 3$  11-bit coefficients used to convert from YUV444 into ARGB48. The value of A component is fixed at 0xFFFF in the output. The coefficients are set according to the standard used to encode the pixel data in YUV color space. [Table 12-427](#) summarizes the coefficients with their respective register bit fields.

**Table 12-427. DISPC VID CSC - YUV to RGB Register Settings**

| Coefficients | Register Fields                      |
|--------------|--------------------------------------|
| $R_Y$        | DSS0_VID_CSC_COEF0[10-0] C00         |
| $R_{Cr}$     | DSS0_VID_CSC_COEF0[26-16] C01        |
| $R_{Cb}$     | DSS0_VID_CSC_COEF1[10-0] C02         |
| $G_Y$        | DSS0_VID_CSC_COEF1[26-16] C10        |
| $G_{Cr}$     | DSS0_VID_CSC_COEF2[10-0] C11         |
| $G_{Cb}$     | DSS0_VID_CSC_COEF2[26-16] C12        |
| $B_Y$        | DSS0_VID_CSC_COEF3[10-0] C20         |
| $B_{Cr}$     | DSS0_VID_CSC_COEF3[26-16] C21        |
| $B_{Cb}$     | DSS0_VID_CSC_COEF4[10-0] C22         |
| Y offset     | DSS0_VID_CSC_COEF5[15-3] PREOFFSET1  |
| Cr offset    | DSS0_VID_CSC_COEF5[31-19] PREOFFSET2 |
| Cb offset    | DSS0_VID_CSC_COEF6[15-3] PREOFFSET3  |

- Limited video data range conversion

If the active range for the luminance samples (Y) is [256:3760] and for the chrominance samples (Cb and Cr) is [256:3840], the following equation in [Figure 12-502](#) (based on 11-bit coefficients) must be used to convert the YUV to RGB. To clip the values of R, G, and B output components to the full output data range [0:4095], set the DSS0\_VID\_ATTRIBUTES[11] FULLRANGE bit to 0x1.

$$\begin{bmatrix} R_{\text{OUT}} \\ G_{\text{OUT}} \\ B_{\text{OUT}} \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} R_Y & R_{cr} & R_{cb} \\ G_Y & G_{cr} & G_{cb} \\ B_Y & B_{cr} & B_{cb} \end{bmatrix} * \begin{bmatrix} Y_{\text{IN}} - 256 \\ Cr_{\text{IN}} - 2048 \\ Cb_{\text{IN}} - 2048 \end{bmatrix}$$

dispco-005

**Figure 12-502. DISPC VID CSC YCbCr to RGB Equation (Limited Video Range), 12-Bit Outputs**

In [Figure 12-502](#), the offset values (-256, -2048, -2048) are also programmed via corresponding register bit-fields shown in [Table 12-427, DISPC VID CSC - YUV to RGB Register Settings](#).

- Full video data range conversion

If the active range for the luminance samples (Y) and chrominance samples (Cb and Cr) is [0:4095], the following equation in [Figure 12-503](#) (based on 11-bit coefficients) must be used to convert the YUV to RGB. To clip the values of R, G, and B output components to the full output data range [0:4095], set the DSS0\_VID\_ATTRIBUTES[11] FULLRANGE bit to 0x1.

$$\begin{bmatrix} R_{\text{OUT}} \\ G_{\text{OUT}} \\ B_{\text{OUT}} \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} R_Y & R_{cr} & R_{cb} \\ G_Y & G_{cr} & G_{cb} \\ B_Y & B_{cr} & B_{cb} \end{bmatrix} * \begin{bmatrix} Y_{\text{IN}} \\ Cr_{\text{IN}} - 2048 \\ Cb_{\text{IN}} - 2048 \end{bmatrix}$$

dispco-006

**Figure 12-503. DISPC VID CSC YCbCr to RGB Equation (Full Video Range), 12-Bit Outputs**

In [Figure 12-503](#), the offset values (0, -2048, -2048) are also programmed via corresponding register bit-fields shown in [Table 12-427, DISPC VID CSC - YUV to RGB Register Settings](#).

#### Note

In case of YUV420-NV21 data, the coefficients for Cr and Cb must be swapped in order to correctly support YUV420-NV21 format.

The scaling and CSC clipping is set by the same bit, DSS0\_VID\_ATTRIBUTES[11] FULLRANGE.

#### 12.9.1.4.1.8.7 DISPC VID Brightness/Contrast/Saturation/Hue Control

The brightness/contrast/saturation controls are implemented in the same Color Space Conversion (CSC) block by making adjustments to the conversion coefficients and input/output offset values as shown in [Figure 12-504](#):

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \begin{bmatrix} m * A0 & m * k * B0 & m * k * C0 \\ m * A1 & m * k * B1 & m * k * C1 \\ m * A2 & m * k * B2 & m * k * C2 \end{bmatrix} \begin{bmatrix} Y + Y_{\text{offset\_adj}} \\ Cr + Cr_{\text{offset}} \\ Cb + Cb_{\text{offset}} \end{bmatrix} + \begin{bmatrix} R_{\text{offset}} \\ G_{\text{offset}} \\ B_{\text{offset}} \end{bmatrix}$$

dispco-101

**Figure 12-504. DISPC VID Brightness/Contrast/Saturation Equation for YUV to RGB**

In [Figure 12-504](#) the following terminology is used:

- A/B/C coefficients and the offset parameters are for YUV to RGB conversion. See [Table 12-428](#) below for coefficients and offsets mapping to register fields.

- The gain term (m) is used for contrast control. The allowed range is:  $0 < m \leq 2.0$  (where  $m=1$  means contrast bypass).
- The gain term (k) is used for saturation control. The allowed range is:  $0 < k \leq 2.0$  (where  $k=1$  means saturation bypass).
- The brightness offset (b) is added to  $Y_{\text{offset\_adj}}$ . The allowed range (for 8-bit example) is:  $-128 \leq b \leq +127$  (where  $b=0$  means brightness bypass).

The hue adjustment can also be built into the above equation (Figure 12-504) to comprehend the following Cb/Cr hue angle adjustments:

$$Cb_{\text{hue\_adj}} = (Cb \cdot \cos\theta + Cr \cdot \sin\theta)$$

$Cr_{\text{hue\_adj}} = (Cr \cdot \cos\theta - Cb \cdot \sin\theta)$ , where  $\theta$  is the desired hue angle (with  $\theta=0$  meaning hue adjustment bypass)

The final combined matrix equation for controlling brightness/contrast/saturation/hue (BCSH) during YUV to RGB conversion is shown in Figure 12-505

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \begin{bmatrix} m \cdot A0 & m \cdot k \cdot [B0 \cdot \cos(Hue) + C0 \cdot \sin(Hue)] & m \cdot k \cdot [C0 \cdot \cos(Hue) - B0 \cdot \sin(Hue)] \\ m \cdot A1 & m \cdot k \cdot [B1 \cdot \cos(Hue) + C1 \cdot \sin(Hue)] & m \cdot k \cdot [C1 \cdot \cos(Hue) - B1 \cdot \sin(Hue)] \\ m \cdot A2 & m \cdot k \cdot [B2 \cdot \cos(Hue) + C2 \cdot \sin(Hue)] & m \cdot k \cdot [C2 \cdot \cos(Hue) - B2 \cdot \sin(Hue)] \end{bmatrix} \begin{bmatrix} Y + Y_{\text{offset\_adj}} \\ Cr + Cr_{\text{offset}} \\ Cb + Cb_{\text{offset}} \end{bmatrix} + \begin{bmatrix} R_{\text{offset}} \\ G_{\text{offset}} \\ B_{\text{offset}} \end{bmatrix}$$

dispic-102

**Figure 12-505. DISPC VID Brightness/Contrast/Saturation/Hue Equation for YUV to RGB**

Gain and offset terms in the above equation (Figure 12-505) are programmed in the hardware registers as adjusted CSC coefficients (11-bit signed) and offset values (13-bit signed) to control the brightness, contrast, saturation and hue. Mapping of the coefficients and offsets to register fields is provided in Table 12-428. Outputs are clipped to keep the output values in the proper range.

**Table 12-428. DISPC VID BCSH Register Settings for YUV to RGB**

| Coefficients | Register Fields                       |
|--------------|---------------------------------------|
| A0           | DSS0_VID_CSC_COEF0[10-0] C00          |
| B0           | DSS0_VID_CSC_COEF0[26-16] C01         |
| C0           | DSS0_VID_CSC_COEF1[10-0] C02          |
| A1           | DSS0_VID_CSC_COEF1[26-16] C10         |
| B1           | DSS0_VID_CSC_COEF2[10-0] C11          |
| C1           | DSS0_VID_CSC_COEF2[26-16] C12         |
| A2           | DSS0_VID_CSC_COEF3[10-0] C20          |
| B2           | DSS0_VID_CSC_COEF3[26-16] C21         |
| C2           | DSS0_VID_CSC_COEF4[10-0] C22          |
| Y offset     | DSS0_VID_CSC_COEF5[15-3] PREOFFSET1   |
| Cr offset    | DSS0_VID_CSC_COEF5[31-19] PREOFFSET2  |
| Cb offset    | DSS0_VID_CSC_COEF6[15-3] PREOFFSET3   |
| R offset     | DSS0_VID_CSC_COEF6[31-19] POSTOFFSET1 |
| G offset     | DSS0_VID_CSC_COEF7[15-3] POSTOFFSET2  |
| B offset     | DSS0_VID_CSC_COEF7[31-19] POSTOFFSET3 |

For RGB input formats, the same CSC block can be used to adjust contrast, brightness, saturation, and hue using the matrix equation from Figure 12-506.

$$\begin{bmatrix} Rout \\ Gout \\ Bout \end{bmatrix} = \begin{bmatrix} m * A0 & m * k * [B0 * \cos(Hue) + C0 * \sin(Hue)] & m * k * [C0 * \cos(Hue) - B0 * \sin(Hue)] \\ m * A1 & m * k * [B1 * \cos(Hue) + C1 * \sin(Hue)] & m * k * [C1 * \cos(Hue) - B1 * \sin(Hue)] \\ m * A2 & m * k * [B2 * \cos(Hue) + C2 * \sin(Hue)] & m * k * [C2 * \cos(Hue) - B2 * \sin(Hue)] \end{bmatrix} \begin{bmatrix} a0 & b0 & c0 \\ a1 & b1 & c1 \\ a2 & b2 & c2 \end{bmatrix} \begin{bmatrix} Rin \\ Gin \\ Bin \end{bmatrix} + \begin{bmatrix} R\_offset \\ G\_offset \\ B\_offset \end{bmatrix}$$

Coefficients a/b/c are related to A/B/C (for RGB to YUV and YUV to RGB conversions) as follows:

$$\begin{bmatrix} a0 & b0 & c0 \\ a1 & b1 & c1 \\ a2 & b2 & c2 \end{bmatrix} = \begin{bmatrix} A0 & B0 & C0 \\ A1 & B1 & C1 \\ A2 & B2 & C2 \end{bmatrix} - 1$$

dispc-103

**Figure 12-506. DISPC VID Brightness/Contrast/Saturation/Hue Equation for RGB Input**

In Figure 12-506 the following specifics apply:

- A/B/C coefficients and the RGB offset parameters mapping to register fields is provided in [Table 12-428](#).
- The gain term (m) is used for contrast control. The allowed range is:  $0 < m \leq 2.0$  (where  $m=1$  means contrast bypass).
- The gain term (k) is used for saturation control. The allowed range is:  $0 < k \leq 2.0$  (where  $k=1$  means saturation bypass).
- The brightness is controlled by the RGB offset values.
- The Hue angle is used to adjust hue. Hue  $\theta=0$  means hue adjustment bypass.

Outputs are clipped to keep the output values in the proper range.

#### 12.9.1.4.1.8.8 DISPC VID Luma Key Support

The video pipeline supports luma key transparency for Blue-ray video layer composition. When enabled, Y value of each pixel will be checked against luma key range values. The range values are defined in DSS0\_VID\_LUMAKEY register fields, as follows: [11-0] LUMAKEYMIN < Y < [27-16] LUMAKEYMAX. If this condition is true, then the pixel alpha value will be forced to zero (transparent) to make the pixel transparent during the blending process in the overlay manager.

#### 12.9.1.4.1.9 DISPC Overlay Managers

An overlay manager (OVR) is responsible for compositing selected input layers together to generate the final display output frame. DISPC implements two identical overlay managers (see [Figure 12-474, DISPC Architecture Overview](#)):

- OVR1, with output connected to Video Port (VP1).
- OVR2, with output connected to Video Port (VP2).

Each OVR is preceded by a programmable input pipeline selector which re-maps the outputs of the selected input pipeline according to the overlay manager z-order configuration.

The output of each OVR is connected to the Color Phase Rotation (CPR) unit through a gamma table of the corresponding video port.



dispc-104

**Figure 12-507. DISPC Overlay Manager and Input Selector**

---

#### Note

The DISPC overlay managers, OVR1 and OVR2, will be commonly referred to as *overlay manager* (OVR) in the following sections.

---

##### 12.9.1.4.1.9.1 DISPC Overlay Input Selector

The overlay input selector before the overlay manager is a n-input to n-output crossbar switch. As such, any input can be connected to any output in the selector. The selection is based on the z-order layer selection in the overlay configuration through the following register fields:

- DSS0\_OVR\_ATTRIBUTES\_0[4-1] CHANNELIN field for layer 0, z-order 0
- DSS0\_OVR\_ATTRIBUTES\_1[4-1] CHANNELIN field for layer 1, z-order 1

The z-order determines the order in which the selected layers are blended together to generate the final output by the overlay manager:

- The lowest enabled order input is the bottom-most layer, just above the background color
- The highest enabled order input is the top-most layer

The OVR input selector also passes the following attributes from the selected input pipeline to the corresponding selector output port:

- Source pipeline size attributes:
  - Number of pixels per line (from DSS0\_VID\_SIZE [11-0] SIZEX register field)
  - Number of lines (from DSS0\_VID\_SIZE [27-16] SIZEY register field)
- Source pipeline global blending level (from DSS0\_VID\_GLOBAL\_ALPHA register)

Then, the overlay manager uses the above listed attributes as input layer attributes along with POSX and POSY overlay manager configuration parameters. POSX and POSY can be configured as follows:

- For layer 0, z-order 0, in DSS0\_OVR\_ATTRIBUTES\_0[17-6] POSX and [30-19] POSY register fields
  - For layer 1, z-order 1, in DSS0\_OVR\_ATTRIBUTES\_1[17-6] POSX and [30-19] POSY register fields
- 

#### Note

The output of an input pipeline can be mapped to more than one overlay manager simultaneously, if and only if the following conditions are true:

- All video port timing generators controlling the overlay managers are identically programmed (same frame width/height with same blanking parameters running at same frame rate) and clocked by the same pixel clock source, and ...
- The pipeline output is positioned on each display output at the same frame position.

The software is responsible for managing the pipeline assignment and setting up the video port timing generators properly in order to avoid any resource conflicts that may cause the DSS to lock up (sync loss).

---

##### 12.9.1.4.1.9.2 DISPC Overlay Mechanism

The overlay mechanism consists of displaying more than one layer (VID and/or VIDL1 pipeline layers) using:

- A priority rule based on the display Z-order (selected by configuring the overlay input selector, as described in [Section 12.9.1.4.1.9.1](#))
- Transparency color keys configuration (destination and source transparency)
- Alpha blending values (using the alpha component of each pixel or a global alpha value set by the user)
- Size and position attributes of the source window data, as described in [Section 12.9.1.4.1.9.1](#)

The overlay manager is configured using the Z-order parameter. The Z-order value defined for each pipeline indicates the visibility order to the window on the screen. If the Z-order value of window A is lower than the Z-order to layer B, then layer A is displayed below layer B. The transparency color keys and the alpha blending factors are then used to blend the layers together (see [Section 12.9.1.4.1.9.2.1, Overlay Alpha Blender](#), and [Section 12.9.1.4.1.9.2.2, Overlay Transparency Color Keys](#)).

Figure 12-508 gives an example of how input pipeline frame outputs are merged together to generate the final display output.



**Figure 12-508. DISPC Overlay Example and Display Attributes**

As shown in Figure 12-508, each input pipeline generates one rectangular sub-frame output in ARGB48 format. The overlay is responsible for positioning the sub-frame in the display output frame (specified by DSS0\_VP\_SIZE\_SCREEN[11-0] PPL and [27-16] LPP video port register fields), using the overlay window position parameters (specified by DISPC\_OVR\_ATTRIBUTES\_0/DISPC\_OVR\_ATTRIBUTES\_1 [17-6] POSX and [30-19] POSY overlay register fields), and the window size parameters (specified by DSS0\_VID\_SIZE[11-0] SIZEX and [27-16] SIZEY pipeline register fields). When the overlay manager does not require the input pipeline data (either because it is currently outputting the background color pixel or it is being stalled by the VP output module), the overlay manager stalls the input pipeline.

When there are no video-encoded pixels at a specific position, the programmable solid background color appears. The solid background color is set in the DSS0\_OVR\_DEFAULT\_COLOR and DSS0\_OVR\_DEFAULT\_COLOR2 registers.

The entire pixels of the video window have to be inside the display screen. Depending on the width of the buffer to be displayed in the video layer and the position, the width must be adjusted by software to limit the right edge of the window inside the display screen. The same is also true for the video layer height in the input pipe line configuration.

#### 12.9.1.4.1.9.2.1 Overlay Alpha Blender

The alpha blending value is defined by:

- The component value A when using an ARGB or RGBA pixel format (alpha in the source pixel data is converted to 8-bit alpha value in the input pipeline logic):
  - For ARGB-1555, the alpha blending is defined using a 1-bit value. It is converted into an 8-bit value by duplicating the 1-bit value (see [Table 12-429](#)).
  - For ARGB-4444, the alpha blending is defined using a 4-bit value. It is converted into an 8-bit value by duplicating the 4-bit value (see [Table 12-429](#)).
  - If the pixel format contains no alpha blending value, the pixel alpha value is considered to be 0xFF, and if alpha is equal to 0xFF, there is no multiplication.
  - For BITMAP or YUV formats, there is no alpha blending factor associated with each pixel value. Only the global alpha blending factor associated with the window displaying the BITMAP or YUV format is used.
- The global alpha blending value can be set in the DSS0\_VID\_GLOBAL\_ALPHA register of the input pipeline, and is updated in synch with the selected output channel.
- The modulated alpha blending value (that is, a total alpha blending value, when a combination of the pixel alpha blending value A and a global alpha blending are present) is determined as: Alpha = (Pixel Alpha × Global Alpha) / 256.

[Table 12-429](#) shows the remapping and the percentage of alpha blending achieved.

**Table 12-429. DISPC Overlay Alpha Blending – ARGB**

| Alpha Blending 1-Bit Value<br>(ARGB16-1555) | Alpha Blending 4-Bit Value<br>(ARGB16-4444) | Alpha Blending 8-Bit Value<br>(Converted Value) | % Blending         |
|---------------------------------------------|---------------------------------------------|-------------------------------------------------|--------------------|
| 0x0                                         | 0x0                                         | 0x00                                            | 100% (transparent) |
| N/A                                         | 0x1                                         | 0x11                                            | 93.33%             |
| N/A                                         | 0x2                                         | 0x22                                            | 86.6%              |
| N/A                                         | ...                                         | ...                                             | ...                |
| N/A                                         | 0xE                                         | 0xEE                                            | 6.6%               |
| 0x1                                         | 0xF                                         | 0xFF                                            | 0% (opaque)        |

#### Premultiplied Alpha

The image ARGB may have its RGB component already premultiplied with the alpha (AR'G'B') where:

- $R' = A \cdot R$
- $G' = A \cdot G$
- $B' = A \cdot B$

In that case, the processing is as follows:

- Color components of premultiplied layers are multiplied with the global alpha, if global alpha is not equal to 0.
- Color components of the composed underlying layer are multiplied with  $(1 - A \cdot \text{global alpha})$ .

The additional premultiplied alpha option is accessible through the DSS0\_VID\_ATTRIBUTES [28]

PREMULTIPLYALPHA register bit of the input pipeline. The following settings are available:

- PREMULTIPLYALPHA bit = 0: Source is not premultiplied with alpha. Full blending is done in the overlay manager.
- PREMULTIPLYALPHA bit = 1: Source is premultiplied with alpha. Partial blending is done.

#### Note

There is no alpha blending between the background and the next layer (layer-0) above it.

Layer-0 cannot be pre-multiplied, if the overlay output is driving the display, since that layer (or the background color) defines the bottom most layer. In this case, layer-0 alpha is 1 always.

#### 12.9.1.4.1.9.2.2 Overlay Transparency Color Keys

The overlay manager supports two color transparency modes - source and destination. These modes cannot be active at the same time.

The source transparency is tied to the top most layer, so the layer to have this transparency applied to has to be mapped to the highest z-ordered input (layer-1) of the overlay manager. The destination transparency is tied to the bottom most layer, so the layer to have this transparency applied to has to be mapped to the lowest z-ordered input (layer-0) of the overlay manager.

The source and destination transparencies are defined as following:

- Source color transparency: Top layer pixel that meets the source transparency color check is made transparent.
- Destination color transparency: Top layer pixel is made transparent, only if the bottom layer pixel does not meet the destination transparency color check.

The transparency color key is enabled via the DSS0\_OVR\_CONFIG[10] TCKLCDENABLE register bit.

The minimum transparency color values are specified in the TRANSCOLORKEY field of the DSS0\_OVR\_TRANS\_COLOR\_MIN and DSS0\_OVR\_TRANS\_COLOR\_MIN2 registers.

The maximum transparency color values are specified in the TRANSCOLORKEY field of the DSS0\_OVR\_TRANS\_COLOR\_MAX and DSS0\_OVR\_TRANS\_COLOR\_MAX2 registers.

The transparency color key values defined in the registers are compared with the pixel values. If each color component (R, G, and B) is in the range defined by MIN and MAX, then there is a match. If at least one of the color component is not in the range, then there is no match.

##### • Source transparency color key

The values of the source transparency color key define the range of encoded pixel data considered as a transparent pixel. The encoded pixel values with the source color key value inside the valid range are not visible, and the encoded pixel values of the under layers or solid background color are visible.

The source transparency color key can be used with YUV and RGB formats (ARGB, RGB, RGBA, xRGB, and RGBx). In that case the A information is ignored for the comparison between the pixel value and the color key value. It is possible to use YUV formats with some care, since the comparison is between the input pixel value of the overlay manager from pipeline and the color key value. The YUV data is converted to RGB format. The user must consider the color space conversion processing in order to define the RGB color key value used for the comparison, in case the original format is YUV.

The scaler can be enabled as a preprocessor in the video pipelines. The pixel scaling processing can be considered in order to define the color key value to be used after the rescaling for the comparison between the input pixel value to the overlay manager and the color key value.

The source transparency color key mode is selected by setting the DSS0\_OVR\_CONFIG[11] TCKLCDSELECTION register bit to 0x1.

[Figure 12-509](#) shows an example of source transparency color key usage. The pixels with the transparency color key are not displayed. Instead, pixels of the resulting layer underneath are shown.



**Figure 12-509. DISPC Overlay Source Transparency Color Key Example**

- **Destination transparency color key**

The destination transparency color key values define the range of the encoded pixels in layer-0 (bottom layer), which are not going to be displayed. That is, the encoded pixel values matching the destination color key value range are pixels not visible on the screen. Pixels at the same position in the layers above layer-0 are visible. The destination transparency color key is applicable in the layer in the background only when there is an overlap between the layer in background position and the layer just above it, otherwise, the destination transparency color key is ignored. See [Section 12.9.1.4.1.9.2, DISPC Overlay Mechanism](#), for details on layer position depending on the Z-order parameter.

The destination transparency color key can be used only with RGB formats (ARGB, RGB, xRGB, RGBA, and RGBx). In that case the A information is ignored for the comparison between the pixel value and the color key value. It is possible to use YUV formats with some care since the comparison is between the input pixel value of the overlay manager from pipeline and the color key value. The YUV data is converted to RGB format. The user must consider the color space conversion processing in order to define the RGB color key value used for the comparison in case the original format is YUV.

The scaler can be enabled as a preprocessor in the pipelines. The pixel scaling processing must be considered in order to define the color key value to be used after rescaling for the comparison between the input pixel value to the overlay manager and the color key value.

The source transparency color key mode is selected by setting the DSS0\_OVR\_CONFIG[11] TCKLCDSELECTION register bit to 0x0.

[Figure 12-510](#) shows an example of the destination color key usage. The pixels from layer-0 (bottom layer) equal to the transparency color key are not displayed and are replaced by the pixels from layer-1 (top layer). All other layer-0 pixels, different from the transparency color key, are displayed over layer-1.



dispc-022

**Figure 12-510. DISPC Overlay Destination Transparency Color Key Example**

#### 12.9.1.4.1.9.3 Overlay 3D Support

In order to support S3D (Stereoscopic 3D) by combining in hardware left and right frames into the same output frame, the following configurations (defined by HDMI 1.4b standard specification) can be used:

- Separate pipeline mode: Left/Right or Top/Bottom. One layer is used for left/top and another layer is used for right/bottom.

#### 12.9.1.4.1.9.4 Overlay Color Bar Insertion

Each overlay manager supports a simple internal color bar insertion in each display output path to enable testing of display output interface without using the frame buffer data from the memory.

The colors are: White, Yellow, Cyan, Green, Magenta, Red, Blue, Black, as shown in below. These make three primary colors, three secondary colors, white, and black.



dispc-105

**Figure 12-511. DISPC Overlay Internal Color Bar**

When the DSS0\_OVR\_CONFIG[1] COLORBAREN register bit is set to 1, the overlay output data is replaced by the predefined ARGB48 color bar data.

When color bar mode is used, the color space conversion matrix should be appropriately programmed, so that it can convert the full-range RGB to the desired color format.

Table 12-430. DISPC Overlay Color Bar Table

| Color   | G      | B      | R      |
|---------|--------|--------|--------|
| White   | 0xFFFF | 0xFFFF | 0xFFFF |
| Yellow  | 0xFFFF | 0      | 0xFFFF |
| Cyan    | 0xFFFF | 0xFFFF | 0      |
| Green   | 0xFFFF | 0      | 0      |
| Magenta | 0      | 0xFFFF | 0xFFFF |
| Red     | 0      | 0      | 0xFFFF |
| Blue    | 0      | 0xFFFF | 0      |
| Black   | 0      | 0      | 0      |

#### 12.9.1.4.1.10 DISPC Video Port Outputs

DISPC implements two identical Video Port (VP) outputs:

- VP1 processes data received from Overlay Manager 1 (OVR1)
- VP2 processes data received from Overlay Manager 2 (OVR2)

A VP output path consists of several processing blocks (see Figure 12-512):

- Gamma correction unit
- Color phase rotation (CPR) unit, also used for RGB to YUV color space conversion (CSC)
- Active matrix dithering with TDM (multiple cycle output format)
- BT.656/BT.1120
- Timing generator
- Async buffer



Figure 12-512. DISPC VP Output Architecture

The CSC processing can be configured to occur either before or after the gamma correction in the VP output module via the DSS0\_VP\_CONFIG[26] COLORCONVPOS register bit. For RGB to YUV color space conversion, the conversion must be done after the gamma correction. For other RGB output applications, the conversion must be done before the final gamma correction.

#### Note

The DISPC video port (VP) outputs, VP1 and VP2, will be commonly referred to as *video port (VP)* in the following sections.

#### 12.9.1.4.1.10.1 DISPC VP Gamma Correction Unit

The VP supports a look up table to perform the gamma correction on the display output. The look up table consists of 3 separate 256x8-bit memories, which are indexed by R/G/B component data.

When performing gamma correction, the selected encoded pixel values from the video pipeline path are sent by the overlay manager to the gamma curve table. Each R/G/B component of the encoded pixel value is used as a pointer to index 1 out of 256 x 24-bit gamma curve entries in the table. Each 8-bit component is replaced with the 8-bit table value corresponding to R, G, or B component. The table is loaded by software via the DSS0\_VP\_GAMMA\_TABLE\_0 through DSS0\_VP\_GAMMA\_TABLE\_15 registers. It is possible to load only part of the table. For each access to the table, the 24-bit value is associated with index in the table by concatenating the 24-bit value (LSB of 32-bit access) and the 8-bit index value (MSB of the 32-bit access).

The sequence to load the gamma table is:

1. SW writes (only writes are supported) 32-bit gamma correction values using single access, or burst access in linear increment burst mode, into the 64-byte region starting at DSS0\_VP\_GAMMA\_TABLE\_0 register address. The LSB 24 bits [23:0] are used for the value, and the MSB 8 bits [31:24] are used for the index into the table.
2. Loop to step #1, if there is a new access to the gamma table register. The software can access other registers between two accesses to the gamma table register.

Software needs to ensure that there is no visible effect when modifying the table, since it is not under hardware control.

The usage of the gamma table is activated by setting DSS0\_VP\_CONFIG[2] GAMMAENABLE register bit.

Figure 12-513 describes the format of one of the gamma curve values in the memory.



**Figure 12-513. DISPC VP Output Gamma Table Write Data Format**

#### 12.9.1.4.1.10.2 DISPC VP Color Phase Rotation Unit

If required, a color phase rotation (CPR) processing can be applied on the "gamma" data before the spatial/temporal dithering.

The CPR can be selected to correct the non-pure white backlight of the display panel by using a programmable matrix to convert the 36-bit RGB pixel value into a new 36-bit RGB pixel value. The matrix is programmed through a set of nine 11-bit signed coefficients. The output of the calculation is clipped to [0:4095]. The CPR is enabled by setting the DSS0\_VP\_CONFIG[15] CPR bit to 0x1.

The CPR processing is expressed by the equation shown in Figure 12-514. Table 12-431 lists all coefficients with their respective register bitfields for settings.

$$\begin{bmatrix} R_{out} \\ G_{out} \\ B_{out} \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} Rr & Rg & Rb \\ Gr & Gg & Gb \\ Br & Bg & Bb \end{bmatrix} * \begin{bmatrix} R_{in} \\ G_{in} \\ B_{in} \end{bmatrix}$$

dispc-023

**Figure 12-514. DISPC VP CPR Matrix**

**Table 12-431. DISPC VP CPR and CSC Coefficients with Associated Register Fields**

| Register Field               | Color Phase Rotation | Color Space Conversion<br>RGB to YUV |
|------------------------------|----------------------|--------------------------------------|
| DSS0_VID_CSC_COEF0[10-0] C00 | RR                   | YR                                   |

**Table 12-431. DISPC VP CPR and CSC Coefficients with Associated Register Fields (continued)**

| Register Field                           | Color Phase Rotation | Color Space Conversion<br>RGB to YUV |
|------------------------------------------|----------------------|--------------------------------------|
| DSS0_VID_CSC_COEF0[26-16] C01            | RG                   | YG                                   |
| DSS0_VID_CSC_COEF1[10-0] C02             | RB                   | YB                                   |
| DSS0_VID_CSC_COEF1[26-16] C10            | GR                   | CrR                                  |
| DSS0_VID_CSC_COEF2[10-0] C11             | GG                   | CrG                                  |
| DSS0_VID_CSC_COEF2[26-16] C12            | GB                   | CrB                                  |
| DSS0_VID_CSC_COEF3[10-0] C20             | BR                   | CbR                                  |
| DSS0_VID_CSC_COEF3[26-16] C21            | BG                   | CbG                                  |
| DSS0_VID_CSC_COEF4[10-0] C22             | BB                   | CbB                                  |
| DSS0_VID_CSC_COEF6[31-19]<br>POSTOFFSET1 | -                    | R offset                             |
| DSS0_VID_CSC_COEF7[15-3]<br>POSTOFFSET2  | -                    | G offset                             |
| DSS0_VID_CSC_COEF7[31-19]<br>POSTOFFSET3 | -                    | B offset                             |

#### 12.9.1.4.1.10.3 DISPC VP Color Space Conversion - RGB to YUV

The RGB to YUV color space conversion (CSC) in the video port is done by using the same programmable logic used for CPR. If CPR is also required, then the process can be combined with the CSC processing by adjusting matrix coefficients. [Table 12-431](#) lists the associated coefficients with their respective register bit-fields. The CSC processing is enabled by setting the DSS0\_VP\_CONFIG[24] COLORCONVENABLE register bit.

The color space conversion can be selected in order to convert from 36-bit RGB to YUV444. The conversion matrix is programmed through a set of nine 11-bit signed coefficients. The result is clipped to [256:3760] for the luminance and [256:3840] for the chrominance, when a full-range YUV output is not desired (equivalent to clipping to [16..235] and [16..240] in 8-bit video). In this case the DSS0\_VP\_CONFIG[25] FULLRANGE register bit must be set to 0x0.

$$\begin{bmatrix} Y_{OUT} \\ Cr_{OUT} \\ Cb_{OUT} \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} Y_R & Y_G & Y_B \\ Cr_R & Cr_G & Cr_B \\ Cb_R & Cb_G & Cb_B \end{bmatrix} * \begin{bmatrix} R_{IN} \\ G_{IN} \\ B_{IN} \end{bmatrix} + \begin{bmatrix} 256 \\ 2048 \\ 2048 \end{bmatrix}$$

dispc-098

**Figure 12-515. DISPC VP CSC RGB to YUV Matrix (FULLRANGE=0)**

If the programmed active range for the luminance samples (Y) and chrominance samples (Cb and Cr) is [0:4095], then the values Y, Cb, and Cr are clipped to the range [0:4095]. The following equation gives the 11-bit coefficients of the RGB to YUV color space conversion, for full-range (when DSS0\_VP\_CONFIG[25] FULLRANGE = 0x1).

$$\begin{bmatrix} Y_{OUT} \\ Cr_{OUT} \\ Cb_{OUT} \end{bmatrix} = \frac{1}{256} * \begin{bmatrix} Y_R & Y_G & Y_B \\ Cr_R & Cr_G & Cr_B \\ Cb_R & Cb_G & Cb_B \end{bmatrix} * \begin{bmatrix} R_{IN} \\ G_{IN} \\ B_{IN} \end{bmatrix} + \begin{bmatrix} 0 \\ 2048 \\ 2048 \end{bmatrix}$$

dispc-099

**Figure 12-516. DISPC VP CSC RGB to YUV Matrix (FULLRANGE=1)**

In order to provide YUV422 data to the BT.656 or BT.1120 blocks, the YUV444 format is further converted to YUV422 by sub-sampling the chrominance values. The hardware does this by averaging two-by-two the

chrominance samples. The conversion from YUV444 to YUV422 is performed when the color space conversion in the VP is enabled.

#### 12.9.1.4.1.10.4 DISPC VP BT.656 and BT.1120 Modes

Each VP output can be configured in BT.656 or BT.1120 mode. The following standards are not supported in BT.656 mode:

- BT.470 (Support for conventional Analog TV Systems)
- BT.803 (The avoidance of interference generated by digital television studio equipment)
- BT.1364 (Format of ancillary data signals carried in digital component studio interfaces)

Unsupported formats when BT.1120 mode is used:

- BT.1364 (Support for Ancillary Data during blanking period)

BT.656/BT.1120 modes use embedded EAV/SAV syncs.

Enabling BT.656 or BT.1120 format for a VP output is done by setting DSS0\_VP\_CONFIG[20] BT656ENABLE or [21] BT1120ENABLE register bit, respectively

---

#### Note

It is not possible to enable BT.656 and BT.1120 mode simultaneously on the same output.

---

Figure 12-517 shows signal mapping on video port DATA[23:0] output data bus. Bits 9 to 0 are dedicated for BT.656 mode (10-bit). In BT.656 mode however, for compatibility with existing 8-bit interfaces, the two LSBs are ignored and only bits [9-2] are effectively used.

|        |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |        |   |   |   |   |   |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|--------|---|---|---|---|---|
| 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5      | 4 | 3 | 2 | 1 | 0 |
| Unused |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | BT.656 |   |   |   |   |   |

**Figure 12-517. DISPC VP Data Mapping for BT.656 Mode**

Figure 12-518 shows signal mapping on video port DATA[23:0] output data bus for BT.1120 mode. Bits [19-10] (CbCr) and [9-0] (Y) are used in 20-bit mode. Bits [19-12] (CbCr) and [9-2] (Y) are used in 16-bit mode (YCbCr422).

|        |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                             |   |   |   |   |   |   |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------------------------|---|---|---|---|---|---|
| 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                           | 5 | 4 | 3 | 2 | 1 | 0 |
| Unused |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | BT.1120 (CbCr, 20-bit mode) |   |   |   |   |   |   |

disp-049x

**Figure 12-518. DISPC VP Data Mapping for BT.1120 Mode**

VP outputs support both interlace and progressive content in BT.656/BT.1120 modes. For more information on timings configuration, see [Section 12.9.1.4.1.10.7, DISPC VP Timing Generator and Display Panel Settings](#).

---

#### Note

In progressive BT.656/BT.1120 mode the maximum output resolution will be limited, as it requires two pixel clock cycles to send out one pixel.

---

#### 12.9.1.4.1.10.4.1 DISPC BT Mode Blanking

During the transmission of the video signal, the portion of the stream in-between active video data segments is known as the horizontal blanking interval.

Strictly speaking this entire region is the blanking interval, but this interval also includes the EAV and SAV codes. The remaining bytes of information in a digital blanking interval are filled with values corresponding to the

blanking levels of the Cb, Y and Cr signals respectively, and in accordance with the standard multiplex sequence for the stream (CbYCrY..). The blanking levels are as follows:

- Cb = 80h
- Y = 10h
- Cr = 80h.

The sequence in the BLANKING region of the data stream is therefore: 80h, 10h, 80h, 10h....80h, 10h

For more details on setting the blanking timing values for BT.1120 and/or BT.656 mode, see [Section 12.9.1.4.1.10.7, DISPC VP Timing Generator and Display Panel Settings](#).

#### 12.9.1.4.1.10.4.2 DISPC BT Mode EAV and SAV

The End of Active Video (EAV) and Start of Active Video (SAV) parts of the stream are timing codes. Their function can be summarized as follows:

- EAV – marks the end of the active video data within the current line and therefore also the start of the subsequent line.
- SAV – heralds the start of the active video data within the current line.

These codes are embedded within the BT.656 video data stream, thereby eliminating the need for additional timing signals (HSYNC, VSYNC) to be included as part of the interface.

Both EAV and SAV codes are comprised of a sequence of four bytes ( FFh – 00h – 00h - XY). The first three bytes in the sequence constitute a fixed preamble. The fourth byte, contains information about the field being transmitted (Field 1 or Field 2 in an interlaced video signal), the state of field blanking (Vertical) and the state of line blanking (Horizontal). The bit assignment for this byte of the code is shown in [Figure 12-519](#), with the function of each bit described in [Table 12-432](#).

| MSB |   |   |   |    |    |    |    | LSB |  |  |  |  |  |  |  |
|-----|---|---|---|----|----|----|----|-----|--|--|--|--|--|--|--|
| 1   | F | V | H | P3 | P2 | P1 | P0 |     |  |  |  |  |  |  |  |

**Figure 12-519. DISPC BT Mode Bit-Assignment for the Fourth Byte of EAV/SAV Codes**

**Table 12-432. DISPC BT Mode Bit Function**

| Bit | Symbol | Function                                                                                                                                                                                                                                                  |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | 1      | Always set to '1'.                                                                                                                                                                                                                                        |
| 6   | F      | Field bit.<br>0 – Field 1<br>1 – Field 2                                                                                                                                                                                                                  |
| 5   | V      | Vertical Blanking Status bit. This bit goes High during a vertical field blanking interval, otherwise it remains Low.                                                                                                                                     |
| 4   | H      | Horizontal Blanking Status bit.<br>0 – byte is part of SAV code (i.e. stream is entering an active video data region for the current line)<br>1 – byte is part of EAV code (i.e. stream has entered a horizontal blanking interval - start of a new line) |
| 3   | P3     | Protection bit 3                                                                                                                                                                                                                                          |
| 2   | P2     | Protection bit 2                                                                                                                                                                                                                                          |
| 1   | P1     | Protection bit 1                                                                                                                                                                                                                                          |
| 0   | P0     | Protection bit 0                                                                                                                                                                                                                                          |

The protection bits allow for detection and correction of 1-bit errors and the detection of 2-bit errors. The status of P3, P2, P1 and P0 depend on the states of bits F, V, and H. This dependency is shown in [Table 12-433](#).

**Table 12-433. DISPC BT Mode Status of Protection Bits in Function of F, V, and H**

| F | V | H | P3 | P2 | P1 | P0 |
|---|---|---|----|----|----|----|
| 0 | 0 | 0 | 0  | 0  | 0  | 0  |

**Table 12-433. DISPC BT Mode Status of Protection Bits in Function of F, V, and H (continued)**

| F | V | H | P3 | P2 | P1 | P0 |
|---|---|---|----|----|----|----|
| 0 | 0 | 1 | 1  | 1  | 0  | 1  |
| 0 | 1 | 0 | 1  | 0  | 1  | 1  |
| 0 | 1 | 1 | 0  | 1  | 1  | 0  |
| 1 | 0 | 0 | 0  | 1  | 1  | 1  |
| 1 | 0 | 1 | 1  | 0  | 1  | 0  |
| 1 | 1 | 0 | 1  | 1  | 0  | 0  |
| 1 | 1 | 1 | 0  | 0  | 0  | 1  |

#### 12.9.1.4.1.10.5 DISPC VP Spatial/Temporal Dithering

The active spatial/temporal dithering logic can be enabled to minimize the color banding when displaying the data on an LCD panel with color depth lower than 24-bit. The dithering logic is integrated after the color/gamma conversion blocks and before the TDM (Time Division Multiplexed) block. The spatial/temporal dithering algorithm is based on the (x,y) pixel position and frame rate control (the value of removed bits and the frame number). The dithering logic can process the pixels over one frame, two frames, or four frames. The number of frames is selected by setting the DSS0\_VP\_CONTROL[31-30] SPATIALTEMPORALDITHERINGFRAMES register field. In the case of a single frame, only spatial processing is applied. In case of multiple frames, both spatial and temporal processing are applied to the pixels. The number of frame is initialized before enabling the spatial/temporal dithering logic. It must be never changed by the software while the spatial/temporal logic is enabled. The spatial/temporal dithering logic is enabled by setting the DSS0\_VP\_CONTROL[7] STDITHERENABLE bit to 0x1.

##### Note

- If the interface data bus is smaller than the pixel format size and spatial/temporal dithering is not enabled, the MSBs of the pixel color components are output on the interface data bus.
- If the interface data bus is larger than the pixel format size, then by programming the pixel components replication active/inactive the MSB is replicated to the LSB of the interface data bus.

#### 12.9.1.4.1.10.6 DISPC VP Multiple Cycle Output Format (TDM)

The pixels (only RGB components) after the active matrix dithering unit are formatted on one or multiple cycles (from 1 to 3 cycles). On three cycles, two pixels can concatenate and send to the panel. The cycle format is selected through the DSS0\_VP\_CONTROL[24-23] TDMCYCLEFORMAT bit field. The number of bits for each cycle is set in the DSS0\_VP\_DATA\_CYCLE\_0 register for the first cycle, the DSS0\_VP\_DATA\_CYCLE1 register for the second cycle, and the DSS0\_VP\_DATA\_CYCLE2 register for the third cycle. The output interface data bus width, when TDM mode is enabled (DSS0\_VP\_CONTROL[20] TDENABLE register bit = 1), can be 8, 9, 12, or 16 bits, configurable through the DSS0\_VP\_CONTROL[22-21] TDMPARALLELMODE register field.

When the TDM is disabled (DSS0\_VP\_CONTROL[20] TDENABLE = 0), the video port output interface data bus width is configured through the DSS0\_VP\_CONTROL[10-8] DATALINES register field.

When using TDM mode, only up to 24 bits per pixel can be output on the interface. For higher color depth, only the upper bits are kept before converting each pixel into TDM output.

Figure 12-520 through Figure 12-523 show various examples of TDM settings in the function of pixel data formats and the interface data bus width.

| 24-bpp  |           |           |           |
|---------|-----------|-----------|-----------|
|         | 1st cycle | 2nd cycle | 3rd cycle |
| Data[7] | R0[7]     | G0[7]     | B0[7]     |
| Data[6] | R0[6]     | G0[6]     | B0[6]     |
| Data[5] | R0[5]     | G0[5]     | B0[5]     |
| Data[4] | R0[4]     | G0[4]     | B0[4]     |
| Data[3] | R0[3]     | G0[3]     | B0[3]     |
| Data[2] | R0[2]     | G0[2]     | B0[2]     |
| Data[1] | R0[1]     | G0[1]     | B0[1]     |
| Data[0] | R0[0]     | G0[0]     | B0[0]     |

  

| 18-bpp  |           |           |           |
|---------|-----------|-----------|-----------|
|         | 1st cycle | 2nd cycle | 3rd cycle |
| Data[7] | R0[5]     | G0[3]     | x         |
| Data[6] | R0[4]     | G0[2]     | x         |
| Data[5] | R0[3]     | G0[1]     | x         |
| Data[4] | R0[2]     | G0[0]     | x         |
| Data[3] | R0[1]     | B0[5]     | x         |
| Data[2] | R0[0]     | B0[4]     | x         |
| Data[1] | G0[5]     | B0[3]     | B0[1]     |
| Data[0] | G0[4]     | B0[2]     | B0[0]     |

CONTROL[24-23] TDMCYCLEFORMAT = 0x2

DATA\_CYCLE0 = 0x00000008

DATA\_CYCLE1 = 0x00000008

DATA\_CYCLE2 = 0x00000008

CONTROL[24-23] TDMCYCLEFORMAT = 0x2

DATA\_CYCLE0 = 0x00000008

DATA\_CYCLE1 = 0x00000008

DATA\_CYCLE2 = 0x00000002

| 16-bpp  |           |           |
|---------|-----------|-----------|
|         | 1st cycle | 2nd cycle |
| Data[7] | R0[4]     | G0[2]     |
| Data[6] | R0[3]     | G0[1]     |
| Data[5] | R0[2]     | G0[0]     |
| Data[4] | R0[1]     | B0[4]     |
| Data[3] | R0[0]     | B0[3]     |
| Data[2] | G0[5]     | B0[2]     |
| Data[1] | G0[4]     | B0[1]     |
| Data[0] | G0[3]     | B0[0]     |

  

| 12-bpp  |           |           |
|---------|-----------|-----------|
|         | 1st cycle | 2nd cycle |
| Data[7] | R0[3]     | x         |
| Data[6] | R0[2]     | x         |
| Data[5] | R0[1]     | x         |
| Data[4] | R0[0]     | x         |
| Data[3] | G0[3]     | B0[3]     |
| Data[2] | G0[2]     | B0[2]     |
| Data[1] | G0[1]     | B0[1]     |
| Data[0] | G0[0]     | B0[0]     |

CONTROL[24-23] TDMCYCLEFORMAT = 0x1

DATA\_CYCLE0 = 0x00000008

DATA\_CYCLE1 = 0x00000008

CONTROL[24-23] TDMCYCLEFORMAT = 0x1

DATA\_CYCLE0 = 0x00000008

DATA\_CYCLE1 = 0x00000004

dispc-057

**Figure 12-520. DISPC VP TDM 8-Bit Interface Settings**

| 24-bpp    |           |           | 18-bpp    |           |  |
|-----------|-----------|-----------|-----------|-----------|--|
| 1st cycle | 2nd cycle | 3rd cycle | 1st cycle | 2nd cycle |  |
| Data[8]   | R0[7]     | G0[6]     | x         |           |  |
| Data[7]   | R0[6]     | G0[5]     | x         |           |  |
| Data[6]   | R0[5]     | G0[4]     | x         |           |  |
| Data[5]   | R0[4]     | G0[3]     | B0[5]     |           |  |
| Data[4]   | R0[3]     | G0[2]     | B0[4]     |           |  |
| Data[3]   | R0[2]     | G0[1]     | B0[3]     |           |  |
| Data[2]   | R0[1]     | G0[0]     | B0[2]     |           |  |
| Data[1]   | R0[0]     | B0[7]     | B0[1]     |           |  |
| Data[0]   | G0[7]     | B0[6]     | B0[0]     |           |  |

CONTROL[24-23] TDMCYCLEFORMAT = 0x2

DATA\_CYCLE0 = 0x00000009

DATA\_CYCLE1 = 0x00000009

DATA\_CYCLE2 = 0x00000006

CONTROL[24-23] TDMCYCLEFORMAT = 0x1

DATA\_CYCLE0 = 0x00000009

DATA\_CYCLE1 = 0x00000009

| 16-bpp    |           |       |
|-----------|-----------|-------|
| 1st cycle | 2nd cycle |       |
| Data[8]   | R0[4]     | x     |
| Data[7]   | R0[3]     | x     |
| Data[6]   | R0[2]     | G0[1] |
| Data[5]   | R0[1]     | G0[0] |
| Data[4]   | R0[0]     | B0[4] |
| Data[3]   | G0[5]     | B0[3] |
| Data[2]   | G0[4]     | B0[2] |
| Data[1]   | G0[3]     | B0[1] |
| Data[0]   | G0[2]     | B0[0] |

CONTROL[24-23] TDMCYCLEFORMAT = 0x1

DATA\_CYCLE0 = 0x00000009

DATA\_CYCLE1 = 0x00000007

| 12-bpp    |           |       |
|-----------|-----------|-------|
| 1st cycle | 2nd cycle |       |
| Data[8]   | R0[3]     | x     |
| Data[7]   | R0[2]     | x     |
| Data[6]   | R0[1]     | x     |
| Data[5]   | R0[0]     | x     |
| Data[4]   | G0[3]     | x     |
| Data[3]   | G0[2]     | x     |
| Data[2]   | G0[1]     | B0[2] |
| Data[1]   | G0[0]     | B0[1] |
| Data[0]   | B0[3]     | B0[0] |

CONTROL[24-23] TDMCYCLEFORMAT = 0x1

DATA\_CYCLE0 = 0x00000009

DATA\_CYCLE1 = 0x00000003

dispc-058

**Figure 12-521. DISPC VP TDM 9-Bit Interface Settings**

| 24-bpp   |           | 18-bpp    |           |           |
|----------|-----------|-----------|-----------|-----------|
|          | 1st cycle | 2nd cycle | 1st cycle | 2nd cycle |
| Data[11] | R0[7]     | G0[3]     | Data[11]  | R0[5]     |
| Data[10] | R0[6]     | G0[2]     | Data[10]  | R0[4]     |
| Data[9]  | R0[5]     | G0[1]     | Data[9]   | R0[3]     |
| Data[8]  | R0[4]     | G0[0]     | Data[8]   | R0[2]     |
| Data[7]  | R0[3]     | B0[7]     | Data[7]   | R0[1]     |
| Data[6]  | R0[2]     | B0[6]     | Data[6]   | R0[0]     |
| Data[5]  | R0[1]     | B0[5]     | Data[5]   | G0[5]     |
| Data[4]  | R0[0]     | B0[4]     | Data[4]   | G0[4]     |
| Data[3]  | G0[7]     | B0[3]     | Data[3]   | G0[3]     |
| Data[2]  | G0[6]     | B0[2]     | Data[2]   | G0[2]     |
| Data[1]  | G0[5]     | B0[1]     | Data[1]   | G0[1]     |
| Data[0]  | G0[4]     | B0[0]     | Data[0]   | G0[0]     |

CONTROL[24-23] TDMCYCLEFORMAT = 0x1  
 DATA\_CYCLE0 = 0x0000000C  
 DATA\_CYCLE1 = 0x0000000C

CONTROL[24-23] TDMCYCLEFORMAT = 0x3  
 DATA\_CYCLE0 = 0x0000000C  
 DATA\_CYCLE1 = 0x00060606  
 DATA\_CYCLE2 = 0x000C0000

| 16-bpp   |           | 12-bpp    |           |       |
|----------|-----------|-----------|-----------|-------|
|          | 1st cycle | 2nd cycle | 1st cycle |       |
| Data[11] | R0[4]     | x         | Data[11]  | R0[3] |
| Data[10] | R0[3]     | x         | Data[10]  | R0[2] |
| Data[9]  | R0[2]     | x         | Data[9]   | R0[1] |
| Data[8]  | R0[1]     | x         | Data[8]   | R0[0] |
| Data[7]  | R0[0]     | x         | Data[7]   | G0[3] |
| Data[6]  | G0[5]     | x         | Data[6]   | G0[2] |
| Data[5]  | G0[4]     | x         | Data[5]   | G0[1] |
| Data[4]  | G0[3]     | x         | Data[4]   | G0[0] |
| Data[3]  | G0[2]     | B0[3]     | Data[3]   | B0[3] |
| Data[2]  | G0[1]     | B0[2]     | Data[2]   | B0[2] |
| Data[1]  | G0[0]     | B0[1]     | Data[1]   | B0[1] |
| Data[0]  | B0[4]     | B0[0]     | Data[0]   | B0[0] |

CONTROL[24-23] TDMCYCLEFORMAT = 0x1  
 DATA\_CYCLE0 = 0x0000000C  
 DATA\_CYCLE1 = 0x00000004

CONTROL[24-23] TDMCYCLEFORMAT = 0x0  
 DATA\_CYCLE0 = 0x0000000C

dispc-059

**Figure 12-522. DISPC VP TDM 12-Bit Interface Settings**

| 24-bpp    |           |           | 18-bpp    |           |
|-----------|-----------|-----------|-----------|-----------|
| 1st cycle | 2nd cycle | 3rd cycle | 1st cycle | 2nd cycle |
| Data[15]  | R0[7]     | B0[7]     | G1[7]     |           |
| Data[14]  | R0[6]     | B0[6]     | G1[6]     |           |
| Data[13]  | R0[5]     | B0[5]     | G1[5]     |           |
| Data[12]  | R0[4]     | B0[4]     | G1[4]     |           |
| Data[11]  | R0[3]     | B0[3]     | G1[3]     |           |
| Data[10]  | R0[2]     | B0[2]     | G1[2]     |           |
| Data[9]   | R0[1]     | B0[1]     | G1[1]     |           |
| Data[8]   | R0[0]     | B0[0]     | G1[0]     |           |
| Data[7]   | G0[7]     | R1[7]     | B1[7]     |           |
| Data[6]   | G0[6]     | R1[6]     | B1[6]     |           |
| Data[5]   | G0[5]     | R1[5]     | B1[5]     |           |
| Data[4]   | G0[4]     | R1[4]     | B1[4]     |           |
| Data[3]   | G0[3]     | R1[3]     | B1[3]     |           |
| Data[2]   | G0[2]     | R1[2]     | B1[2]     |           |
| Data[1]   | G0[1]     | R1[1]     | B1[1]     |           |
| Data[0]   | G0[0]     | R1[0]     | B1[0]     |           |

CONTROL[24-23] TDMCYCLEFORMAT = 0x3

DATA\_CYCLE0 = 0x000000010

DATA\_CYCLE1 = 0x00080808

DATA\_CYCLE2 = 0x00100000

CONTROL[24-23] TDMCYCLEFORMAT = 0x1

DATA\_CYCLE0 = 0x000000010

DATA\_CYCLE1 = 0x000000002

| 16-bpp    |       | 12-bpp    |  |
|-----------|-------|-----------|--|
| 1st cycle |       | 1st cycle |  |
| Data[15]  | R0[4] |           |  |
| Data[14]  | R0[3] |           |  |
| Data[13]  | R0[2] |           |  |
| Data[12]  | R0[1] |           |  |
| Data[11]  | R0[0] |           |  |
| Data[10]  | G0[5] |           |  |
| Data[9]   | G0[4] |           |  |
| Data[8]   | G0[3] |           |  |
| Data[7]   | G0[2] |           |  |
| Data[6]   | G0[1] |           |  |
| Data[5]   | G0[0] |           |  |
| Data[4]   | B0[4] |           |  |
| Data[3]   | B0[3] |           |  |
| Data[2]   | B0[2] |           |  |
| Data[1]   | B0[1] |           |  |
| Data[0]   | B0[0] |           |  |

CONTROL[24-23] TDMCYCLEFORMAT = 0x0

DATA\_CYCLE0 = 0x000000010

CONTROL[24-23] TDMCYCLEFORMAT = 0x0

DATA\_CYCLE0 = 0x00000000C

dispc-060

**Figure 12-523. DISPC VP TDM 16-Bit Interface Settings**

#### 12.9.1.4.1.10.7 DISPC VP Timing Generator and Display Panel Settings

Each video port output has a dedicated timing generator supporting progressive and interlaced mode. It is clocked using the pixel clock and is configured to generate the video data and sync signals to match the desired video display standard timings.

Two-level configuration for enabling the video ports exists:

- Via the individual DSS0\_VP\_CONTROL[0] ENABLE register bit for each VP. It allows each VP to be independently controlled by two different hosts.
- Via the common DSS0\_COMMON\_DISPC\_GLOBAL\_OUTPUT\_ENABLE[2-0] VP\_ENABLE register field. It allows two or more VP timing generators to be in sync by enabling them simultaneously with a single register write.

Both ENABLE and VP\_ENABLE register fields must be set in order for a VP (timing generator) to start.

Figure 12-524 shows the timing generator display parameters.



**Figure 12-524. DISPC VP Display Timing Parameters**

The width of VP output data bus is configured in the DSS0\_VP\_CONTROL[10-8] DATALINES register field, when TDM feature is disabled. When TDM is enabled, the width of the output data bus is defined according to [Section 12.9.1.4.1.10.6, DISPC VP Multiple Cycle Output Format \(TDM\)](#).

The size of the display panel is defined by:

- Number of lines per frame, DSS0\_VP\_SIZE\_SCREEN[27-16] LPP bit field, with a value from 1 to 4096
- Number of pixels per line, DSS0\_VP\_SIZE\_SCREEN[11-0] PPL bit field, with a value from 1 to 4096

Standard HSYNC/VSYNC timing generation is programmable as follows:

- Horizontal front porch is set in the DSS0\_VP\_TIMING\_H[19-8] HFP bit field.
- Horizontal back porch is set in the DSS0\_VP\_TIMING\_H[31-20] HBP bit field.
- Horizontal synchronization pulse width is set in the DSS0\_VP\_TIMING\_H[7-0] HSW bit field.
- Vertical front porch is set in the DSS0\_VP\_TIMING\_V[19-8] VFP bit field.
- Vertical back porch is set in the DSS0\_VP\_TIMING\_V[31-20] VBP bit field.
- Vertical synchronization pulse width is set in the DSS0\_VP\_TIMING\_V[7-0] VSW bit field.

When the output is in BT.1120 or BT.656 mode, the following timing constants are mapped onto the DSS0\_VP\_TIMING\_H and DSS0\_VP\_TIMING\_V registers:

- Progressive mode:
  - Horizontal blanking (12 bits) is set in the {DSS0\_VP\_TIMING\_V[3-0] VSW, DSS0\_VP\_TIMING\_H[7-0] HSW} register fields (up to 2048 bytes of horizontal blanking supported).

- Vertical frame blanking No 1 is set in the DSS0\_VP\_TIMING\_V[19-8] VFP bit field.
- Vertical frame blanking No 2 is set in the DSS0\_VP\_TIMING\_V[31-20] VBP bit field.
- Number of lines per frame is set in the DSS0\_VP\_SIZE\_SCREEN[27-16] LPP bit field.
- Number of pixels per line is set in the DSS0\_VP\_SIZE\_SCREEN[11-0] PPL bit field.
- Interlaced mode:
  - Horizontal blanking (12 bits) is set in the {DSS0\_VP\_TIMING\_V[3-0] VSW, DSS0\_VP\_TIMING\_H[7-0] HSW} register fields (up to 2048 bytes of horizontal blanking supported).
  - Vertical field blanking No.1 for Even Field is set in the DSS0\_VP\_TIMING\_H[19-8] HFP bit field.
  - Vertical field blanking No.2 for Even Field is set in the DSS0\_VP\_TIMING\_H[31-20] HBP bit field.
  - Vertical field blanking No.1 for Odd Field is set in the DSS0\_VP\_TIMING\_V[19-8] VFP bit field.
  - Vertical field blanking No.2 for Odd Field is set in the DSS0\_VP\_TIMING\_V[31-20] VBP bit field.
  - Number of lines per field (even) is set in the DSS0\_VP\_SIZE\_SCREEN[27-16] LPP bit field.
  - Delta number of odd field compared to even field (in a single line) is set in the DSS0\_VP\_SIZE\_SCREEN[15-14] DELTA\_LPP bit field. The DELTA\_LPP field only controls the output channel and not the size of the field fetched from the frame buffer in memory. This field must be set to zero for YUV420 format.
  - Number of pixels per line is set in the DSS0\_VP\_SIZE\_SCREEN[11-0] PPL bit field.

Horizontal/vertical synchronization and output enable signals polarity are programmable by setting the DSS0\_VP\_POL\_FREQ[12] IVS, [13] IHS, and [15] IEO register bits. These signals can be gated by setting the DSS0\_VP\_CONFIG[7] VSYNCGATED and [6] HSYNCGATED register bits. In addition, the alignment between VSYNC and HSYNC signals can be programmed via the DSS0\_VP\_POL\_FREQ[18] ALIGN register bit.

The latch of data can be driven on the rising or falling edge of the pixel clock by setting the DSS0\_VP\_POL\_FREQ[14] IPC register bit. The drive of the SYNC and VSYNC signals in the function of the pixel clock is done by setting the DSS0\_VP\_POL\_FREQ[16] RF bit.

#### Note

To set the pixel clock, CTRL\_MMR\_DPI0\_CLK\_CTRL[8] DPI0\_CLK\_CTRL\_DATA\_CLK\_INVDIS setting should always be opposite the DSS0\_VP\_POL\_FREQ[14] IPC setting, and CTRL\_MMR\_DPI0\_CLK\_CTRL[9] DPI0\_CLK\_CTRL\_SYNC\_CLK\_INVDIS setting should always be opposite the DSS0\_VP\_POL\_FREQ[16] RF setting.

For example, if CTRL\_MMR\_DPI0\_CLK\_CTRL[8] DPI0\_CLK\_CTRL\_DATA\_CLK\_INVDIS is set to 0, DSS0\_VP\_POL\_FREQ[14] IPC should be set to 1.

Each VP output can be configured in progressive output mode or interlaced output mode. The selection is done by writing into the bit-field DSS0\_VP\_CONFIG[22] OUTPUTMODEENABLE register bit. The default setting is for progressive mode. The selection can be changed only when the corresponding VP output is disabled. The configuration is independent for each VP output. It is possible to change the configuration of one of the VP outputs while the other VP is enabled.

The pixel clock for each VP output can be gated by setting the DSS0\_VP\_CONFIG[5] PIXELCLOCKGATED register bit.

The hold time of the pixels on the data bus is determined in clock cycles by the DSS0\_VP\_CONTROL[16-14] HT register field.

#### 12.9.1.4.1.11 DISPC Safety Features

For safety critical system applications, DSS supports the following safety features in hardware:

- Data correctness check: To verify intended data is shown correctly on the display.
- Freeze frame detection: To notify a possible frame freeze, when there is no change in the display frame over multiple frame periods.

These features are implemented by collecting signatures from user-defined regions within each pipeline output frame and the final display output frame, and comparing them to reference signatures provided by the user

(software) and/or to previously saved signatures. The signature from each region is generated by using a MISR (Multiple Input Signature Register) module.

### 12.9.1.4.11.1 Safety Check Regions

DSS supports the following safety check regions to implement the safety features:

- Video pipelines: One safety check region at the output of each video pipeline.
- Video port outputs: Up to four sub-regions within the active video output area of the final display output of each video port.



**Figure 12-525. DISPC Safety Check Regions**

Table 12-434 lists the parameters supported by each of the safety check regions, together with the associated register control fields.

**Table 12-434. DISPC Safety Check Regions Parameters**

| Safety Region Parameter            | Video Pipeline Control Register             | Video Port Sub-region 0 Control Register     | Video Port Sub-region 1 Control Register     | Video Port Sub-region 2 Control Register     | Video Port Sub-region 3 Control Register     |
|------------------------------------|---------------------------------------------|----------------------------------------------|----------------------------------------------|----------------------------------------------|----------------------------------------------|
| X position                         | DSS0_VID_SAFETY_POSITION_N[11-0] POSX       | DSS0_VP_SAFETY_POSITION_0[11-0] POSX         | DSS0_VP_SAFETY_POSITION_1[11-0] POSX         | DSS0_VP_SAFETY_POSITION_2[11-0] POSX         | DSS0_VP_SAFETY_POSITION_3[11-0] POSX         |
| Y position                         | DSS0_VID_SAFETY_POSITION_N[27-16] POSY      | DSS0_VP_SAFETY_POSITION_0[27-16] POSY        | DSS0_VP_SAFETY_POSITION_1[27-16] POSY        | DSS0_VP_SAFETY_POSITION_2[27-16] POSY        | DSS0_VP_SAFETY_POSITION_3[27-16] POSY        |
| Width                              | DSS0_VID_SAFETY_SIZE[11-0] SIZEX            | DSS0_VP_SAFETY_SIZE_0[11-0] SIZEX            | DSS0_VP_SAFETY_SIZE_1[11-0] SIZEX            | DSS0_VP_SAFETY_SIZE_2[11-0] SIZEX            | DSS0_VP_SAFETY_SIZE_3[11-0] SIZEX            |
| Height                             | DSS0_VID_SAFETY_SIZE[27-1] SIZEY            | DSS0_VP_SAFETY_SIZE_0[27-16] SIZEY           | DSS0_VP_SAFETY_SIZE_1[27-16] SIZEY           | DSS0_VP_SAFETY_SIZE_2[27-16] SIZEY           | DSS0_VP_SAFETY_SIZE_3[27-16] SIZEY           |
| Data Correctness Check Mode Enable | DSS0_VID_SAFETY_ATTRIBUTE_ES[1] CAPTUREMODE | DSS0_VP_SAFETY_ATTRIBUTE_ES_0[1] CAPTUREMODE | DSS0_VP_SAFETY_ATTRIBUTE_ES_1[1] CAPTUREMODE | DSS0_VP_SAFETY_ATTRIBUTE_ES_2[1] CAPTUREMODE | DSS0_VP_SAFETY_ATTRIBUTE_ES_3[1] CAPTUREMODE |

**Table 12-434. DISPC Safety Check Regions Parameters (continued)**

| Safety Region Parameter            | Video Pipeline Control Register                 | Video Port Sub-region 0 Control Register           | Video Port Sub-region 1 Control Register           | Video Port Sub-region 2 Control Register           | Video Port Sub-region 3 Control Register           |
|------------------------------------|-------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|
| Freeze Frame Detection Mode Enable | DSS0_VID_SAFETY_ATTRIB_ES[1] CAPTUREMODE        | DSS0_VP_SAFETY_ATTRIB_ES[0] CAPTUREMODE            | DSS0_VP_SAFETY_ATTRIB_ES[1] CAPTUREMODE            | DSS0_VP_SAFETY_ATTRIB_ES[2] CAPTUREMODE            | DSS0_VP_SAFETY_ATTRIB_ES[3] CAPTUREMODE            |
| Region Safety Check Enable         | DSS0_VID_SAFETY_ATTRIB_ES[0] ENABLE             | DSS0_VP_SAFETY_ATTRIB_ES[0] ENABLE                 | DSS0_VP_SAFETY_ATTRIB_ES[1] ENABLE                 | DSS0_VP_SAFETY_ATTRIB_ES[2] ENABLE                 | DSS0_VP_SAFETY_ATTRIB_ES[3] ENABLE                 |
| Freeze Frame Detection Threshold   | DSS0_VID_SAFETY_ATTRIB_ES[10-3] THRESHOLD       | DSS0_VP_SAFETY_ATTRIB_ES[0] [10-3] THRESHOLD       | DSS0_VP_SAFETY_ATTRIB_ES[1] [10-3] THRESHOLD       | DSS0_VP_SAFETY_ATTRIB_ES[2] [10-3] THRESHOLD       | DSS0_VP_SAFETY_ATTRIB_ES[3] [10-3] THRESHOLD       |
| Frames to Skip                     | DSS0_VID_SAFETY_ATTRIB_ES[12-11] FRAMESKIP      | DSS0_VP_SAFETY_ATTRIB_ES[0] [12-11] FRAMESKIP      | DSS0_VP_SAFETY_ATTRIB_ES[1] [12-11] FRAMESKIP      | DSS0_VP_SAFETY_ATTRIB_ES[2] [12-11] FRAMESKIP      | DSS0_VP_SAFETY_ATTRIB_ES[3] [12-11] FRAMESKIP      |
| Reference Signature                | DSS0_VID_SAFETY_REF_SIGN_ATURE[31-0] SIGNATURE  | DSS0_VP_SAFETY_REF_SIGN_ATURE[31-0] SIGNATURE      | DSS0_VP_SAFETY_REF_SIGN_ATURE[1] [31-0] SIGNATURE  | DSS0_VP_SAFETY_REF_SIGN_ATURE[2] [31-0] SIGNATURE  | DSS0_VP_SAFETY_REF_SIGN_ATURE[3] [31-0] SIGNATURE  |
| MISR Seed                          | DSS0_VID_SAFETY_LFSR_SE ED[31-0] SEED           | DSS0_VID_SAFETY_LFSR_SE ED                         | DSS0_VID_SAFETY_LFSR_SE ED                         | DSS0_VID_SAFETY_LFSR_SE ED                         | DSS0_VID_SAFETY_LFSR_SE ED                         |
| MISR Seed Selection                | DSS0_VID_SAFETY_ATTRIB_ES[2] SEEDSELECT         | DSS0_VP_SAFETY_ATTRIB_ES[0] [2] SEEDSELECT         | DSS0_VP_SAFETY_ATTRIB_ES[1] [2] SEEDSELECT         | DSS0_VP_SAFETY_ATTRIB_ES[2] SEEDSELECT             | DSS0_VP_SAFETY_ATTRIB_ES[3] [2] SEEDSELECT         |
| MISR Captured Signature            | DSS0_VID_SAFETY_CAPT_SIG_NATURE[31-0] SIGNATURE | DSS0_VP_SAFETY_CAPT_SIG_NATURE[0] [31-0] SIGNATURE | DSS0_VP_SAFETY_CAPT_SIG_NATURE[1] [31-0] SIGNATURE | DSS0_VP_SAFETY_CAPT_SIG_NATURE[2] [31-0] SIGNATURE | DSS0_VP_SAFETY_CAPT_SIG_NATURE[3] [31-0] SIGNATURE |

Figure 12-526 shows examples of one safety region in the video pipeline output stage and up to 4 possible regions in the final video port output stage.



**Figure 12-526. DISPC Safety Check Region Examples**

The safety region in the video pipeline captures data only if the embedded alpha data is not equal to 0 (that is, non-transparent pixels). The safety regions in the display video port output captures all active video pixels within the region boundary. The (up to four) regions in the display output should be typically non-overlapping areas of the screen, but the hardware does not restrict them to be non-overlapping.

Figure 12-527 shows the locations within DISPC data path where the data is analyzed.



**Figure 12-527. DISPC Safety Check Locations**

#### 12.9.1.4.1.11.2 Safety Signature Generator Using MISR

A 32-bit multiple input signature register (MISR) with 32-bit Galois LFSR polynomial,  $P(x)=X^{32}+X^{22}+X^2+x+1$ , is used to capture a signature of active video pixel data (the 10 MSB bits of each color component) for each safety region, as shown in [Figure 12-528](#) and the algorithm below it.



**Figure 12-528. DISPC Safety 32-bit MISR Implementation**

The MISR (32-bit Galois LFSR based) signature generation algorithm is as follows:

Tap \_polynomial = 32'hE000\_0200

lfsr\_q = seed // initial LFSR value - any none zero value should work

For each (pixel data in the safety region) {

data\_in[31:0] = { 2'b0, r,g,b } // 10 MSB bits of R,G,B components

lfsr\_d = (data\_in(lfsr\_q >> 1))

If (lfsr\_q[0]) lfsr\_d = lfsr\_d<sup>Tap\_polynomial</sup>

lfsr\_q = lfsr\_d

}

signature = lfsr\_q

All MISRs are initialized at the beginning of each frame with a non-zero "seed" value either with the default constant value (0xFFFF\_FFFF) or with the programmable seed configuration value in SAFETY\_LFSR\_SEED register for each group of regions (refer to [Table 12-434, DISPC Safety Check Regions Parameters](#)). Note that a same seed must be used to compare signatures between two frames. If different than the default seed value is desired, then a SEEDSELECT parameter must be set before the corresponding SAFETY\_LFSR\_SEED register is configured with the customer seed value.

All captured signatures from safety regions are memory mapped to read-only registers

SAFETY\_CAPT\_SIGNATURE for each video port (refer to [Table 12-434, DISPC Safety Check Regions Parameters](#)). A SAFETY\_CAPT\_SIGNATURE register is updated with the signature from each sub-region at the end of every frame. This register returns the signature of the last frame data when the MISR is enabled. When MISR is disabled, this register is cleared.

The MISR aliasing (faulty signature matches fault-free signature) probability is:

$(2^{(L-n)}-1)/(2^L-1) = \sim 2^{(L-n)}/2^L = 2^{-n}$  for large L, where

n = length of signature register

L = length of input sequence

Using the above approximation, the result is:

n=4, aliasing probability = 6.25%

n=16, aliasing probability = 0.0015%

...

n=32 (as in DISPC MISR), aliasing probability is  $\sim 2^{-32}$  (negligible)

#### 12.9.1.4.1.11.3 Safety Checks

If the data correctness check is enabled (see [Table 12-434, DISPC Safety Check Regions Parameters](#)):

- When a new signature is generated, it is compared against the reference signature provided by the software. A SAFETY\_REF\_SIGNATURE register must be configured with a reference signature data, see [Table 12-434, DISPC Safety Check Regions Parameters](#).
- If signatures do not match, an interrupt event is generated to indicate data mismatch.

If the freeze frame detection is enabled (see [Table 12-434, DISPC Safety Check Regions Parameters](#)):

- When a new signature is generated, it is first compared against the saved signature (from previous frame).
- If signatures match, an internal counter used to keep track of the number of frames with no data change (for the region) is incremented.
- If signatures do not match, the counter is cleared.
- If the counter value is greater than the user programmed freeze frame detection threshold value (see [Table 12-434, DISPC Safety Check Regions Parameters](#)), an interrupt event (VIDSAFETYREGION\_IRQ or VPSAFETYREGION\_IRQ, see [Section 12.9.1.4.1.5, DISPC Interrupt Requests](#)) is generated to indicate a possible freeze frame detection. The threshold value must be configured with the maximum number of identical successive frames allowed before an interrupt is generated.
- After the comparison, the signature is saved as the previous signature.
- The counter is cleared when the interrupt event is generated or when freeze frame detection check is disabled.

This frame freeze is different from the display frozen due to pipeline lock up. In that case, the DISPC will generate an SYNCLOST\_IRQ and/or DMA VIDBUFFERUNDERFLOW\_IRQ interrupt. The freeze frame detection is for source data frozen while the DSS is working normally.

The two safety checks are continuously performed over multiple frames as long as their mode enable register bits are set.

#### 12.9.1.4.1.11.4 Safety Check Limitations

The safety check will only be available when the DISPC is outputting RGB/YUV component data with separate sync signals. The safety functions are not available for following modes:

- YUV422 embedded sync modes (BT.656 and BT.1120)
- RGB TDM (Time Division Multiplex) mode

#### 12.9.1.4.1.12 DISPC Security Management

##### 12.9.1.4.1.12.1 Security Implementation

DSS supports the following security features:

- Secure mode configuration
- Illegal connection prevention

#### Secure Mode

DISPC supports a secure mode configuration register (DSS0\_COMMON1\_DISPC\_SECURE) which defines the "secure mode" attribute of each pipeline, overlay manager, and video port instance in DISPC. This register can only be modified by a host with an appropriate secure privilege (MReqSecure=1). When the secure bit corresponding to an instance is set by a secure host, the instance is deemed to be in "secure mode" and the DISPC hardware prevents the output of the instance getting connected to a non-secure downstream module. Also, any DMA transfer initiated by a secure pipeline will have its OCP in-band signal MReqSecure set to HIGH to indicate that is a secure mode transaction request.

By default, all pipelines, overlay managers, and video port instances are in a "non-secure mode". The DSS0\_COMMON1\_DISPC\_SECURE register bits are active, only when the DSS0\_COMMON\_DISPC\_SECURE\_DISABLE[0] SECURE\_DISABLE register bit is configured properly to 0x0. When the SECURE\_DISABLE bit is set to 0x1, the DSS0\_COMMON1\_DISPC\_SECURE register bits are non-active and DISPC will behave as non-secure module.

### Illegal Connection Prevention

DISPC hardware enforces the following rules to prevent an illegal connection:

- Secure input pipeline can only connect to a secure overlay manager: If any host (secure or non-secure) configures an overlay manager input selection to connect a secure input pipeline to a non-secure overlay manager, then the DISPC hardware will block the connection and issue a "security violation" interrupt (SECURITYVIOLATION\_IRQ) to alert the host.



**Figure 12-529. DISPC Secure Bit Setting and Illegal Connection Block**

#### 12.9.1.4.1.12.2 Secure Mode Configuration

The secure bit of DSS0\_COMMON1\_DISPC\_SECURE register is set/reset by a secure transaction. When the secure bit has been set, the software in "secure mode" is responsible for checking the DISPC configuration. The secure bit is propagated by DISPC to the system Interconnect in order to qualify all DISPC requests as secure or non-secure requests, based on the secure bits defined in the control register.

When DISPC accesses the frame buffer, in the case the secure bit has been reset and the frame buffer has been set secure, the display controller will receive an "error" in response of non-secure requests.

#### 12.9.1.4.1.13 DISPC Shadow Registers

Some DISPC registers are termed *shadow registers*. The shadow registers allow the software to modify them at any time, without direct effect on the DISPC hardware configuration. When all the values for a given configuration are written into the shadow registers, software must set only one register bit to validate the configuration. When the hardware reaches the end of the current frame and sees that the bit has been set by software, the new configuration is now the configuration used by the hardware.

The DSS0\_VP\_CONTROL[5] GOBIT bit enables the hardware to use the new configuration, for all shadow registers associated with each VP output.

The registers are statically associated to a particular output (for example, timing registers) or dynamically associated to one output at a time (for example, video registers).

#### 12.9.1.4.2 OLDITX Functional Description

##### 12.9.1.4.2.1 OLDITX Overview

The OpenLDI transmitter (OLDITX) supports serialized RGB pixel data transmission between host and flat panel display over LVDS (Low Voltage Differential Sampling) interface. The LVDS interface complies with ANSI/TIA/EIA644-A standard (Electrical Characteristics of Low Voltage Differential Signaling (LVDS) Interface Circuits). The OLDITX consists of 7-to-1 data serializers, and 4-data and 1-clock LVDS outputs. The OLDITX translates 21 or 28-bit wide video/sync data into LVDS data, 3 or 4 bits wide and 7 bits deep. At a maximum pixel rate of 170 MHz, the speed of a single LVDS data lane is 1.19 Gbps providing a total throughput of 4.76 Gbps over a single OLDI link.

Figure 12-530 shows the high level overview of the OLDITX module.



Figure 12-530. OLDITX Block Diagram

##### 12.9.1.4.2.2 OLDITX Clocks

OLDITX receives one pixel clock, `OLDI_FWD_P_CLK`. The pixel clock rate is 1/7 of serial clock rate in single-link mode and 2/7 of serial clock rate in dual-link mode.

OLDITX receives one serial clock (`OLDI_PLL_CLK`) to perform 7-to-1 serialization. `OLDI_PLL_CLK` is 3.5x or 7x `OLDI_FWD_P_CLK` frequency, where  $25\text{MHz} < \text{OLDI\_FWD\_P\_CLK (freq)} < 170\text{MHz}$ .

For more details on OLDITX clocks, see *DSS Integration*.

##### 12.9.1.4.2.3 OLDITX Resets

There are two resets for the OLDITX module:

- Hardware reset, `OLDITX_RST`.
- Software reset, `OLDITX_SW_RST`, driven by `DSS0_VP_DSS_OLDI_CFG[12]` SOFTRST register bit. The software reset is combined with `OLDITX_RST` to drive the reset to all the sub-modules.

The reset status of OLDITX module can be read in `DSS0_COMMON_DSS_SYSSTATUS[5]` `OLDI_RESETDONE` register bit.

##### 12.9.1.4.2.4 OLDITX Input Interface

The input to the OLDITX is a standard DPI interface bus (direct output of a DSS DISPC video port), which consists of the following signals:

- VSync and HSync sync signals
- DE, data enable (active video signal)
- RGB[23:0] parallel data

OLDITX receives 18-bit or 24-bit RGB input source data from the DSS DISPC video port. The DSS interface is clocked on the rising edge of `OLDI_FWD_P_CLK` pixel clock (whose frequency is exactly 1/7 of the

OLDI\_PLL\_CLK serial clock). The DATA, VS, HS, and DE signals are treated as data to be mapped onto the LVDS output shifter. The start of accepting and processing the DSS interface data happens after DSS0\_VP\_DSS\_OLDI\_CFG[0] ENABLE bit is asserted to 0x1 and synchronized to the internal pixel clock.

#### 12.9.1.4.2.4.1 OLDITX 24-bit RGB Input

The 24-bit RGB input source data (either non-dithered or dithered to 24-bit) coming from the DSS DISPC video port is expected to have the components mapping shown in [Table 12-435](#). The DSS0\_VP\_DSS\_OLDI\_CFG[8] MSB register bit must be set for 24-bit input.

**Table 12-435. OLDITX 24-bit RGB Input for 24-bit LVDS Output**

|        |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
|--------|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| 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[7:0] |    |    |    |    |    |    |    | G[7:0] |    |    |    |    |    |   |   | B[7:0] |   |   |   |   |   |   |   |

Both 18-bit and 24-bit LVDS output mappings are supported with this 24-bit input format. For 18-bit LVDS output mapping however, the 6 MSB bits of each component are mapped to the output as shown in [Table 12-436](#). OLDITX does not support dithering to reduce 24-bit RGB input to 18-bit RGB LVDS output. If dithering is required, then DSS DISPC must perform the dithering and send the data to OLDITX as an 18-bit panel data as shown in [Section 12.9.1.4.2.4.2, OLDITX 18-bit RGB Input](#).

**Table 12-436. OLDITX 24-bit RGB Input for 18-bit LVDS Output**

|        |    |    |    |    |        |    |    |        |    |    |    |    |        |   |        |   |   |   |   |        |   |   |   |
|--------|----|----|----|----|--------|----|----|--------|----|----|----|----|--------|---|--------|---|---|---|---|--------|---|---|---|
| 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[5:0] |    |    |    |    | Unused |    |    | G[5:0] |    |    |    |    | Unused |   | B[5:0] |   |   |   |   | Unused |   |   |   |

#### 12.9.1.4.2.4.2 OLDITX 18-bit RGB Input

The 18-bit RGB source data (typically dithered to 18-bit) coming from the DSS DISPC video port is expected to have the component mapping shown in [Table 12-437](#). The DSS0\_VP\_DSS\_OLDI\_CFG[8] MSB register bit must be set for 18-bit input. Only 18-bit LVDS output mapping is supported with this input type.

**Table 12-437. OLDITX 18-bit RGB Input**

|        |    |    |    |        |    |    |    |    |    |        |    |    |    |   |        |   |   |   |   |        |   |   |   |
|--------|----|----|----|--------|----|----|----|----|----|--------|----|----|----|---|--------|---|---|---|---|--------|---|---|---|
| 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
| Unused |    |    |    | R[5:0] |    |    |    |    |    | G[5:0] |    |    |    |   | B[5:0] |   |   |   |   | Unused |   |   |   |

#### 12.9.1.4.2.5 OLDITX Output Mode Configuration

OLDITX0 and OLDITX1 support:

- Single link output mode: This is a single stream format for which up to four serial data lanes (four LVDS pairs) are used to transmit a video stream. An additional lane is used to transmit the pixelclock.
- 2x Single-link (duplication) output mode: This is a dual stream format for which up to four serial data lanes are used to transmit each video stream (8 total). An additional lane is used to transmit each pixel clock.
- Dual link output mode: This is a single stream format which up to eight serial data lanes are used to transmit a video stream. An additional two lanes are used to transmit the pixelclock.

A single OpenLDI interface is capable of driving up to WUXGA (1920x1200@60p, 162 MHz pixel clock) resolution, and can be used as long as the receiving display or link bridge device can accept the video output from the device through a single OpenLDI link. Typically, only display resolutions less than 1366x768 require a single link interface. Adding the second interface for dual-link operation does not increase available bandwidth, but decreases required pixel clock by half.

The sequence of bringing up OLDITX in single link mode is as follows:

- Configure all PLLs that provide the required OLDITX clocks (see [Module Integration](#)).
- Keep OLDITX\_SW\_RST in the default reset state 0 (controlled via DSS0\_VP\_DSS\_OLDI\_CFG[12] SOFTRST register bit).
- Configure the following parameters:

- Input video data and pixel clock source, in DSS0\_VP\_DSS\_OLDI\_CFG[4] SRC register bit
  - OLDITX module enable, in DSS0\_VP\_DSS\_OLDI\_CFG[0] ENABLE register bit
  - DE input polarity, in DSS0\_VP\_DSS\_OLDI\_CFG[7] DEPOL register bit
  - Combining of links, in DSS0\_VP\_DSS\_OLDI\_CFG[11] DUALMODESYNC register bit:
    - Zero for single-link(s)
    - One for dual-link
  - Link mode, in DSS0\_VP\_DSS\_OLDI\_CFG[5] MODE register bit:
    - Zero for single stream
    - One for stream duplication
  - Mapping of video to LVDS channel (for single link mode), in DSS0\_VP\_DSS\_OLDI\_CFG[3-1] MAP register field:
    - A, B, or C Types for single-link
    - D, E, or F Types for dual-link
  - Input data format (for 18-bit LVDS output), in DSS0\_VP\_DSS\_OLDI\_CFG[8] MSB register bit
  - Test pattern enable (must be 0 for normal operation), in DSS0\_VP\_DSS\_OLDI\_CFG[13] TPATCFG register bit
4. Software checks that the PLLs are stable and locked.
  5. Release OLDITX\_SW\_RST = 1 (by configuring DSS0\_VP\_DSS\_OLDI\_CFG[12] SOFTRST register bit).
  6. Software waits for DSS0\_COMMON\_DSS\_SYSSTATUS[5] OLDI\_RESETDONE register bit = 1.
  7. DSS sends RGB data.

Typically, OLDITX should be configured to send out 24-bit RGB data on four LVDS data lanes. But, it can also be configured (via DSS0\_VP\_DSS\_OLDI\_CFG[3-1] MAP register field) to send only 18-bit RGB data (6-bits/component) on three LVDS lanes, when connecting to a low resolution monitor. In this configuration, only 4 LVDS pairs (3 data lanes + 1 clock lane) are active, while the 4th data lane is disabled. When OLDITX is configured to send out 18-bit LVDS-mapped data, then the DSS0\_VP\_DSS\_OLDI\_CFG[8] MSB register bit must be used to select the format of the input source data bus (for more information, see [Section 12.9.1.4.2.4, OLDITX Input Interface](#)).

---

#### Note

Software may change the mode of operation by first asserting low the OLDITX\_SW\_RST reset, then follow the sequence described in this section.

Software needs to ensure that OLDITX\_SW\_RST is asserted low, if the PLLs are not locked.

---

For more information on LVDS data format mapping and LVDS data output bit format, see [Section 12.9.1.2.2, DSS LVDS Interface](#).

#### 12.9.1.4.2.6 OLDITX Loopback Test Mode

OLDITX supports data loopback mode to check for DC faults in the digital (parallel to serial conversion logic) and analog (LVDS transmitter) data signal path.

In the loopback test mode, the sending module (DSS DISPC) drives all OLDITX input signals (data and sync) to either all 1s or 0s. All 1s and all 0s will be captured as a static 1 or 0 at the output of the LVDS loopback receiver (enabled only during the test mode). To ensure that there are no faults in the parallel to serial conversion logic path, a simple pattern check of 1s or 0s is be performed on the serializer data and reported back along with the LVDS loopback value. These signals are then passed back to DSS and mapped to the DSS0\_VP\_DSS\_OLDI\_LB[9-0] LBRDATA register field for test software to read.

For loopback testing of the clock differential output signals, OLDITX drives all 0s or 1s pattern (based on the DSS0\_VP\_DSS\_OLDI\_CFG[10] LBDATA register bit configuration) instead of the normal clock pattern, when the loopback test is enabled.

Since there is no de-serializer in the loopback path, the loopback mode is intended for facilitating a system diagnostic testing with a constant data output (all 0s or 1s) at low-speed. In normal operation, the loopback mode must be disabled.

When loopback is enabled in DSS0\_VP\_DSS\_OLDI\_CFG[9] LBEN register bit, the loopback of data in this order from MSB to LSB {all\_0\_1[4:0], oldi\_ch\_ret\_clock, oldi\_ch\_ret\_data[3:0]} will be returned in DSS0\_VP\_DSS\_OLDI\_LB[9-0] LBRDATA register field.

### Verifying loopback

Set up OLDIRX for a single mode and select the DSS input data. Configure the parameters as shown for either Case 1 or Case 2 below. Set DSS0\_VP\_DSS\_OLDI\_CFG[9] LBEN = 1 and enable OLDIRX to start sending data. Check after 10 pixel clock periods.

Case 1, all 0's stuck-at test:

- DSS0\_VP\_DSS\_OLDI\_CFG[3-1] MAP = 000
- DSS0\_VP\_DSS\_OLDI\_CFG[10] LBDATA = 0
- OLDI\_0\_DATA[23:0] = all 0's (this is input data from DSS)
- OLDI\_0\_HS, OLDI\_0\_VS, OLDI\_0\_DE = 0's (these are input signals from DSS)

Check:

- DSS0\_VP\_DSS\_OLDI\_LB[9-5] LBRDATA = 11111
- DSS0\_VP\_DSS\_OLDI\_LB[4-0] LBRDATA = 00000

Case 2, all 1's stuck-at test:

- DSS0\_VP\_DSS\_OLDI\_CFG[3-1] MAP = 000
- DSS0\_VP\_DSS\_OLDI\_CFG[10] LBDATA = 1
- OLDI\_0\_DATA[23:0] = all 1s (this is input data from DSS)
- OLDI\_0\_HS, OLDI\_0\_VS, OLDI\_0\_DE = 1's (these are input signals from DSS)

Check:

- DSS0\_VP\_DSS\_OLDI\_LB[9-5] LBRDATA = 11111
- DSS0\_VP\_DSS\_OLDI\_LB[4-0] LBRDATA = 11111

Note that DSS0\_VP\_DSS\_OLDI\_LB[3] LBRDATA = 1. In functional operation, the LVDS A30:A36 in 18-bit single mode are not being driven by input data, rather all 0's. In loopback mode, each of A30:A36 is driven by OLDI\_0\_DE. In other single modes, the "reserved or NA" bit fields, as described in the LVDS data format mapping tables in [Section 12.9.1.2.2, DSS LVDS Interface](#), are driven by OLDI\_0\_DE in loopback mode.

### 12.9.2 Graphics Processing Unit (GPU)

**12.9.2.1 GPU Registers Description.....** 2014

### 12.9.2.1 GPU Registers Description

A description of the GPU registers can be found at [GPU Registers Description](#)

Chapter 13  
**On-Chip Debug**

---



This chapter describes the on-chip debug support.

|                                                       |             |
|-------------------------------------------------------|-------------|
| <b>13.1 On-Chip Debug Overview.....</b>               | <b>2016</b> |
| <b>13.2 On-Chip Debug Features.....</b>               | <b>2016</b> |
| <b>13.3 On-Chip Debug Functional Description.....</b> | <b>2017</b> |

## 13.1 On-Chip Debug Overview

This chapter describes the properties and capabilities of the various features available through the On-Chip Debug framework deployed on this device.

The On-Chip Debug framework enables various Debug and Trace use-cases, including:

- **JTAG Tooling** – Access to on-chip debug resources is supported by an IEEE 1149.1 (JTAG) compliant interface that is supported by an Arm® CoreSight™ DAP JTAG-DP.
- **Self-Hosted Tooling** – code running on programmable cores within the device is able to use on-chip debug resources to enable embedded tooling solutions.
- **PCB-level interconnect testing** – IEEE 1149.1 and IEEE 1149.6 compliant Boundary Scan supports product level integration testing
- **Low Power Operation** – When on-chip JTAG and debug management logic is in a low power state, activity sensed on the JTAG interface will cause this logic to be placed in a functional state.
- **Stop Mode debugging** – Debug of embedded processors is supported using various mechanisms that can halt the pipeline of a CPU. Breakpoints (Software and Hardware), Watchpoints, Cross-Triggering, and On-demand (e.g. user requested) halt request mechanisms may be supported based on the capabilities of a given processor.
- **Debug-aware Peripherals** – Peripheral awareness of processor execution state allows safe suspension of peripheral operation. Supported by select peripherals.
- **Synchronized Debug** – Wide deployment of Cross-Triggering allows multiple processors and/or debug elements to be grouped together to process various actions based on a common event occurrence.
- **Processor Trace** – Support for the generation of a trace stream with the encoding of processor state that may include some combination of program flow, timing details (execution and stall), and memory references (address and/or data) with the goal of facilitating processor state reconstruction for debug purposes.
- **Software Messaging Trace** – Support for software messaging trace where embedded code running within the device can be instrumented to use memory writes to send important debug information to a trace stream.
- **System Traffic Trace** – Strategically selected points in the SoC topology are instrumented with trace-capable bus probes that support transaction trace, read-latency monitoring, and throughput computation.
- **Trace Correlation (through timestamping)** – Support for the correlation of different trace streams is enabled through the use of a common global timestamp that is distributed to supported trace sources.
- **Trace data movement** – Trace data movement on chip is supported using standard Arm ATB trace infrastructure components. Concurrent use of the trace bus by multiple trace sources is supported, with each trace source identifiable through a unique ID. An Arm® CoreSight™ Trace Router supports sending a trace stream off-chip (TPIU), to dedicated memory on-chip (TBR), or broadcasted to both (TPIU + TBR).
- **On-Chip trace collection via dedicated buffer** – An on-chip trace buffer is supported by logic that implements capturing trace data until either the memory fills (stop-on-full, system-bridge) or continuously until a request to stop is received (circular buffer). Interleaving of multiple trace streams is made possible through the use of a standardized encoding that embeds trace data along with the corresponding trace source ID.
- **Trace export over TPIU** – Trace data is exported over device LVC MOS pins using a standard protocol that embeds trace data along with the corresponding trace source ID.
- **Trace export over USB** – The on-chip trace buffer is used as an intermediate buffer allowing trace data to be exported over an USB endpoint in real-time.

## 13.2 On-Chip Debug Features

The On-Chip Debug framework provides a comprehensive hardware platform for a rich debug and development experience. The On-Chip Debug framework supports these features:

- An IEEE 1149.1 (JTAG and Boundary Scan) compliant device interface
- Cross-triggering and Debug boot mode device interface
- Trace port device interface
- Advanced power, reset, and clock management to facilitate debug across complex low power modes
- Breakpoint-based debug
- Cross-triggering
- Program flow trace

- System traffic monitoring trace
- Software instrumentation trace
- Trace export via trace port device interface
- Trace capture on-chip via dedicated buffer with options to support stop-on-full, circular-buffer, or data hand-off to various peripherals
- Arm® CoreSight™ compliant debug components deployed to streamline 3rd party tooling support

#### Note

Some features may not be available. See *Module Integration* for more information.

### 13.3 On-Chip Debug Functional Description

#### 13.3.1 On-Chip Debug Block Diagram

A logical partitioning of the On-Chip Debug features deployed on this device is illustrated in [Figure 13-1](#).



**Figure 13-1. On-Chip Debug Block Diagram**

#### Note

SMS0\_TIFSM is intentionally omitted from the block diagram as it is not a debuggable entity.

### 13.3.2 Device Interfaces

AM62x On-Chip Debug features are supported through three device interfaces:

- **JTAG**: IEEE 1149.1 compliant interface that provides access to Boundary Scan and acts as the primary interface for off-chip access to On-Chip debug resources (See [Section 13.3.2.1](#))
- **Trigger and Debug Boot Mode**: Multi-functional interface that supports product level cross-triggering and debug-related boot modes (See [Section 13.3.6](#), [Section 13.3.4](#))
- **Trace Port**: Arm TPIU compliant Trace Port interface is used to facilitate export of trace (See [Section 13.3.12](#))

Texas Instruments supports a variety of eXtended Development System (XDS) JTAG controllers with various debug capabilities beyond only JTAG support. The following document is a good reference for guidelines: [Emulation and Trace Headers](#). More information can also be found here:[XDS Target Connection Guide](#) .

The previous link connects to TI community resources. Linked contents are provided “AS IS” by the respective contributors. They do not constitute TI specifications and do not necessarily reflect TI’s views; see [TI’s Terms of Use](#).

#### 13.3.2.1 JTAG Interface

**Table 13-1. JTAG Interface Signals**

| Signal Name | I/O Type <sup>(1)</sup> | Description                                                                                                                                                                           |
|-------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRSTn       | I                       | <i>Test Reset</i> . Initializes and disables the test interface.                                                                                                                      |
| TCK         | I                       | <i>Test Clock</i> . Controls the timing of the test interface independently from any system clocks. TCK is pulsed by the equipment controlling the test and not by the tested device. |
| TMS         | I                       | <i>Test Mode Select</i> . Controls the transitions of the test interface state machine.                                                                                               |
| TDI         | I                       | <i>Test Data Input</i> . Supplies the data to the JTAG registers.                                                                                                                     |
| TDO         | O/Z                     | <i>Test Data Output</i> . Used to serially output the data from the JTAG registers to the equipment controlling the test.                                                             |

(1) I = Input; I/O = Input or output; O = Output; O/Z = Output or three-state

#### 13.3.2.2 Trigger and Debug Boot Mode Interface

**Table 13-2. Trigger and Debug Boot Mode Interface Signals**

| Signal Name | I/O Type <sup>(1)</sup> | Description                           |
|-------------|-------------------------|---------------------------------------|
| EMU0        | I/O                     | Channel 0 trigger or boot mode select |
| EMU1        | I/O                     | Channel 1 trigger or boot mode select |

(1) I = Input; I/O = Input or output; O = Output; O/Z = Output or three-state

#### 13.3.2.3 Trace Port Interface

**Table 13-3. Trace Port Signals**

| Pin Name      | TPIU Signal Name | I/O Type <sup>(1)</sup> | Description     |
|---------------|------------------|-------------------------|-----------------|
| TRC_CLK       | TRACECLK         | O                       | TraceClock      |
| TRC_CTL       | TRACECTL         | O                       | TraceControl    |
| TRC_DATA[n:0] | TRACEDATA[n:0]   | O                       | TraceData [n:0] |

(1) I = Input; I/O = Input or output; O = Output; O/Z = Output or three-state

#### Note

Note that the Trace Port interface signals are associated with device pins that are multiplexed with other signal functions.

### 13.3.3 Debug and Boundary Scan Access and Control

On-Chip debug resources are made available through three mechanisms:

- JTAG access via DAP and related APs
- JTAG access via Boundary Scan TAP
- Embedded access to debug resources via SoC address space

## DAP

Off-chip debug tools are able to access On-Chip debug resources via the JTAG interface when not in Boundary Scan mode (see below). A CoreSight™ Compliant DAP architecture provides access via a DP and a collection of APs:

- SWJ-DP: Arm® CoreSight™ compliant SWJ Debug Port provides support for a JTAG interface with a 4-bit IR

### Note

Even though an SWJ-DP is implemented on-chip, only JTAG is supported. This device does not support SWD.

- APB-AP: Arm® CoreSight™ APB Access Port provides access to the Debug-APB address space which is the primary configuration space for On-Chip Debug resources.
- AXI-AP: Arm® CoreSight™ AXI Access Port provides access to the SoC address space, allowing visibility and control over system resources.
- Config-AP: TI Configuration AP supports access to SoC debug management registers
- Power-AP: TI Configuration AP supports advanced power, reset, and clock management. (See [Section 13.3.5](#))

[Table 13-4](#) describes the APSEL assignment for this device.

**Table 13-4. DAP APSEL Assignment**

| APSEL | AP           | Description                                |
|-------|--------------|--------------------------------------------|
| 0     | Config-AP    | TI AP - Reserved                           |
| 1     | APB-AP       | Provides access to Debug Config Plane      |
| 2     | AXI-AP       | Provides access to SoC Address Space       |
| 3     | Power-AP     | TI AP - Extended Power/Reset/Clock Control |
| 4-5   | Reserved     | Reserved for future use                    |
| 6     | SEC-AP       | TI AP - Authentication Interface           |
| 7     | SMS TIFS M4F |                                            |
| 8     | MCU_M4F      |                                            |
| 9     | SMS HSM M4F  |                                            |
| 10-31 | Reserved     | Reserved for future use                    |

## Boundary Scan

This device supports boundary scan using an IEEE 1149.1 compliant JTAG TAP that is made visible through the use of a compliance-enable mode (see [Section 13.3.4](#)). IEEE 1149.1 and 1149.6 Boundary Scan support are defined in device-specific BSDL files that can be found in the respective device's product folder on [ti.com](#).

## SoC Address Space

The device architecture provides access to On-Chip debug resources through the SoC Address Space. This includes access to all DAP Access Ports (APs) as well as the Debug-APB address space.

### 13.3.4 Debug Boot Modes and Boundary Scan Compliance

The EMU1 and EMU0 device pins are used to convey debug boot mode behavior and can also be used as part of a boundary scan compliance sequence to enable boundary scan features.

## Debug Boot Mode

EMU1 and EMU0 are sampled when MCU\_PORz is de-asserted and the decoded value determines the debug boot mode behavior as detailed in [Table 13-5](#).

**Table 13-5. Debug Boot Modes**

| Sample Time          | EMU1 | EMU0 | Boot Mode           | Behavior                                                                                                                                              |
|----------------------|------|------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| MCU_PORz deassertion | 0    | 0    | Reserved            | Reserved for future use                                                                                                                               |
|                      | 0    | 1    | Reserved            | Reserved for future use                                                                                                                               |
|                      | 1    | 0    | Wait-In-Reset (WIR) | Device will remain quiescent until a debug connection is established and the debugger releases WIR. This mode is useful for debugging boot sequences. |
|                      | 1    | 1    | Normal              | Device boots normally. Debug can connect at any time but the context will be post-boot.                                                               |

### Boundary Scan Compliance

EMU1 and EMU0 are sampled when TRSTz is de-asserted and the decoded value determines the debug boot mode behavior as detailed in [Table 13-6](#).

**Table 13-6. Boundary Scan Compliance**

| Sample Time       | EMU1 | EMU0 | Boundary Scan Compliance | Behavior                                                                    |
|-------------------|------|------|--------------------------|-----------------------------------------------------------------------------|
| TRSTn deassertion | 0    | 1    | Boundary Scan Enabled    | The device's Boundary Scan TAP is connected to the device's JTAG interface. |
|                   | 0    | 0    |                          |                                                                             |
|                   | 1    | 0    | Boundary Scan Disabled   | The device's SWJ-DP is connected to the device's JTAG interface.            |
|                   | 1    | 1    |                          |                                                                             |

### 13.3.5 Power, Reset, Clock Management

This device includes advanced power, reset, and clock management debug capabilities, including:

- **Wakeup support for debug logic:** logic within the device is able to sense JTAG activity and ensure that debug logic is on and able to service JTAG requests.
- **Reset isolation:** critical configuration and trace datapaths and logic are not sensitive to warm reset
- **Configuration independence:** debug configuration occurs over a debug-only interconnect, separate from SoC traffic to ensure debug logic remains available even during deadlock scenarios.
- **Power-AP:** a CoreSight™ compliant Access Port (AP) developed by TI that provides a standard interface for debug tooling to access status and control over power, reset, and clocking for the system and various LPSC-defined sub-domains.

### 13.3.6 Debug Cross Triggering

This device supports an Arm® CoreSight™ compliant four-channel programmable on-chip Cross Triggering network. In addition to the four-channel on-chip network, this device implements two channels of product level triggering via the EMU0 and EMU1 device pins.

Conceptually, each channel of Cross Triggering can be viewed as mapping of a user-defined set of events to a user-defined set of actions, where the occurrence of any event in the set-of-events results in the generation of the set-of-actions. [Table 13-7](#) provides a domain-level summary of the supported events and actions.

**Table 13-7. Domain-Level Summary of Triggering Capability**

| Domain        | Events                          | Actions                        |
|---------------|---------------------------------|--------------------------------|
| Product-Level | Zero detected on EMU0 input pin | EMU0 output pin driven to Zero |
|               | Zero detected on EMU1 input pin | EMU1 output pin driven to Zero |

**Table 13-7. Domain-Level Summary of Triggering Capability (continued)**

| Domain    | Events                                       | Actions                         |
|-----------|----------------------------------------------|---------------------------------|
| SoC Debug | TBR Acquisition Complete                     | TPIU insert trigger packet      |
|           | TBR Embedded buffer is full                  | TPIU start flush process        |
|           | System reset asserted                        | TBR insert trigger packet       |
|           | Bus Probe-n match                            | TBR start flush process         |
|           | STM write to a TRIG location                 | Bus Probe-n Start               |
|           | STM write to a trigger-enabled stimulus port | Bus Probe-n Stop                |
| SMS0_HSM  | SMS0_HSM has halted                          | SMS0_HSM – halt request         |
|           | ETM External Out (EXTOUT) trigger            | SMS0_HSM – resume request       |
|           | --                                           | ETM External In (EXTIN) trigger |
| MCU_M4F   | MCU_M4F has halted                           | MCU_M4F – halt request          |
|           | ETM External Out (EXTOUT) trigger            | MCU_M4F – resume request        |
|           | --                                           | ETM External In (EXTIN) trigger |
| WKUP_R5F  | WKUP_R5F has halted                          | WKUP_R5F – halt request         |
|           | PMU generated interrupt                      | WKUP_R5F – resume request       |
|           | ETM External Out (EXTOUT) trigger            | ETM External In (EXTIN) trigger |
| A53SS0    | A53SS0 core-n has halted                     | A53SS0 core-n – halt request    |
|           | PMU generated interrupt                      | A53SS0 core-n – resume request  |
|           | ETM generated trigger (external output)      | CTI interrupt                   |
|           | --                                           | ETM External In (EXTIN) trigger |

### 13.3.7 WKUP\_R5F Debug

The WKUP\_R5F includes an Arm Cortex R5F with embedded debug capability, including:

- Independent debug configuration
- ROM Table
- Basic debug functionality
- Cross Triggering
- PMU: Performance Monitor Unit
- ETM: Embedded Trace Macrocell

A summary of the WKUP\_R5F debug capabilities is detailed in [Table 13-8](#).

**Table 13-8. WKUP\_R5F Debug Capabilities**

| Capability  | Feature                              | Notes                                                                                                             |
|-------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| Basic Debug | Independent debug configuration      | Debug resource configuration is performed over a configuration interface that is isolated from functional traffic |
|             | ROM table                            | Facilitates discovery of debug resources within debug configuration address space                                 |
|             | Processor halt                       | Support user-requested entry into the suspended state                                                             |
|             | Single step                          | Execution of a single instruction before entering the suspended state                                             |
|             | Software breakpoints                 | Software breakpoints are supported via opcode replacement                                                         |
|             | Hardware breakpoints                 | Eight Debug Breakpoint resources support hardware breakpoints                                                     |
|             | Hardware watchpoints                 | Eight Debug Watchpoint resources support data address breakpoints                                                 |
|             | Core register access                 | Access to processor core registers                                                                                |
|             | System memory access                 | Access to memory from perspective of CPU                                                                          |
|             | Vector catch                         | Halting in response to an exception                                                                               |
|             | Arm® TrustZone® debug authentication | Provisioning for DBGEN and NIDEN                                                                                  |

**Table 13-8. WKUP\_R5F Debug Capabilities (continued)**

| Capability       | Feature                   | Notes                                                                                                                                                                                              |
|------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cross Triggering | Debug state               | Support for controlling execution state (run, halt) via triggers and creating triggers upon entry into debug state                                                                                 |
|                  | PMU                       | PMU interrupt trigger                                                                                                                                                                              |
|                  | ETM                       | Five ETM external triggers (one ETM Trigger, two external out event triggers, two external in event triggers)                                                                                      |
| PMU              | Profile Counters          | Three counters can be used to count different events available for gathering statistics on the operation of the processor and memory system                                                        |
|                  | Cycle Counter             | One dedicated counter available for counting CPU clock cycles                                                                                                                                      |
| ETM              | Triggering Infrastructure | Comprehensive triggering infrastructure supports use of comparators (address, data value, context ID), counters, sequencer state, an external inputs and outputs to control the enabling of trace. |
|                  | Instruction trace         | Supports tracing of instruction flow                                                                                                                                                               |
|                  | Cycle-accurate tracing    | Supports inclusion of a precise cycle count of executed instructions.                                                                                                                              |
|                  | Branch broadcast tracing  | Support for tracing branch address details even in circumstances where that information might be discoverable from object code                                                                     |
|                  | Data tracing              | Support for data address and data value tracing                                                                                                                                                    |

### 13.3.8 SMS0\_HSM and MCU\_M4F Debug

Both SMS0\_HSM and MCU\_M4F include an Arm Cortex M4F with embedded debug capability, including:

- Independent debug configuration via AHB-AP
- ROM Table
- Basic debug functionality
- Cross Triggering
- DWT : Data Watchpoint and Trace
- FPB : Flash Patch Breakpoint
- ITM : Instrumentation Trace Macrocell
- ETM : Embedded Trace Macrocell

A summary of the SMS0\_HSM and MCU\_M4F debug capabilities is detailed in [Table 13-9](#).

**Table 13-9. SMS0\_HSM and MCU\_M4F Debug Capabilities**

| Capability       | Feature                              | Notes                                                                 |
|------------------|--------------------------------------|-----------------------------------------------------------------------|
| Basic Debug      | AHB-AP                               | AHB-AP provides access to resources                                   |
|                  | ROM table                            | Facilitates discovery of debug resources within AHB-AP address space  |
|                  | Processor halt                       | Support user-requested entry into the suspended state                 |
|                  | Single step                          | Execution of a single instruction before entering the suspended state |
|                  | Core register access                 | Access to processor core registers                                    |
|                  | Vector catch                         | Halting in response to an exception                                   |
|                  | Software breakpoints                 | Software breakpoints are supported via opcode replacement             |
|                  | System memory access                 | Access to M4F address space is supported via AHB-AP                   |
|                  | Arm® TrustZone® debug authentication | Provisioning for DBGEN and NIDEN                                      |
| Cross Triggering | Cross Triggering                     | Cross Triggering support via CoreSight™ CTI                           |

**Table 13-9. SMS0\_HSM and MCU\_M4F Debug Capabilities (continued)**

| Capability | Feature                                             | Notes                                                                                                                                                             |
|------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DWT        | Watchpoints                                         | Four comparators implemented that can be configured to support watchpoints, data address trace, ETM signaling and PC sampling                                     |
|            | Data address trace                                  |                                                                                                                                                                   |
|            | ETM signaling                                       |                                                                                                                                                                   |
|            | PC sampling trace                                   |                                                                                                                                                                   |
|            | Cycle count matching                                |                                                                                                                                                                   |
| FPB        | Performance counting                                | Profiling counter support provides visibility into instruction cycle count, exception overhead, sleep overhead, load-store overhead, and folded instruction count |
|            | Hardware breakpoints                                | Six instruction address comparators support hardware breakpoints                                                                                                  |
| ITM        | Remapping of literal and instruction fetch accesses | Two comparators support address remapping of literal or instruction accesses to facilitate software patching                                                      |
|            | Software trace                                      | Software writes to ITM stimulus registers provoke the generation of trace packets that convey the values written                                                  |
| ITM        | DWT hardware trace                                  | Support for conveying DWT output using trace                                                                                                                      |
|            | Timestamping                                        | Support for attaching a local timestamp to trace traffic                                                                                                          |
|            | Global timestamping                                 | Support for attaching a global timestamp to trace traffic                                                                                                         |
| ETM        | Program execution trace                             | Support for tracing instruction execution                                                                                                                         |
|            | Global timestamping                                 | Support for attaching a global timestamp to trace traffic                                                                                                         |

### 13.3.9 A53SS0 Debug

The A53SS0 is a multi-core Arm Cortex-A53 subsystem with embedded debug capability and features, including:

- Independent debug configuration
- ROM Table
- Basic debug functionality
- Cross Triggering
- PMU: Performance Monitor Unit
- ETM: Embedded Trace Macrocell

A summary of the A53SS0 debug capabilities and features is detailed in [Table 13-10](#).

**Table 13-10. A53SS0 Debug Capabilities**

| Capability                           | Feature                                                             | Notes                                                                                                             |
|--------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| Basic Debug                          | Independent debug configuration                                     | Debug resource configuration is performed over a configuration interface that is isolated from functional traffic |
|                                      | ROM table                                                           | Facilitates discovery of debug resources within debug configuration address space                                 |
|                                      | Processor halt                                                      | Support user-requested entry into the suspended state                                                             |
|                                      | Single step                                                         | Execution of a single instruction before entering the suspended state                                             |
|                                      | Software breakpoints                                                | Software breakpoints are supported via opcode replacement                                                         |
|                                      | Hardware breakpoints                                                | Six Debug Breakpoint resources support hardware breakpoints                                                       |
|                                      | Hardware watchpoints                                                | Four Debug Watchpoint resources support data address breakpoints                                                  |
|                                      | Core register access                                                | Access to processor core registers                                                                                |
|                                      | System memory access                                                | Access to memory from perspective of CPU                                                                          |
|                                      | Vector catch                                                        | Halting in response to an exception                                                                               |
| Arm® TrustZone® debug authentication | Provisioning for DBGEN, NIDEN, SPIDEN, SPNIDEN, SUIDEN, and SUNIDEN |                                                                                                                   |
|                                      |                                                                     |                                                                                                                   |

**Table 13-10. A53SS0 Debug Capabilities (continued)**

| Capability       | Feature                               | Notes                                                                                                                                     |
|------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Cross Triggering | Debug state                           | Support for controlling execution state (run, halt) via triggers and creating triggers upon entry into debug state                        |
|                  | PMU                                   | PMU interrupt trigger                                                                                                                     |
|                  | ETM                                   | Four ETM external triggers                                                                                                                |
|                  | CPU                                   | CTI interrupt into CPU                                                                                                                    |
| PMU              | Profile Counters                      | Six counters can be used to count different events available for gathering statistics on the operation of the processor and memory system |
|                  | Cycle Counter                         | One dedicated counter available for counting CPU clock cycles                                                                             |
| ETM              | Instruction trace with cycle counting | Support for tracing instruction execution with timing information                                                                         |
|                  | Branch broadcast tracing              | Support for tracing branch address details even in circumstances where that information might be discoverable from object code            |
|                  | Return stack tracing                  | Support for tracing of the return stack                                                                                                   |
|                  | Stall Control                         | Support for stalling the A53 processor to avoid ETM overflows                                                                             |
|                  | Global timestamping                   | Support for attaching a global timestamp to trace traffic                                                                                 |

### 13.3.10 PRUSS Debug

The PRUSS includes two PRU RISC cores, PRU0 and PRU1. Each PRU supports basic debug functionality as detailed in [Table 13-11](#).

**Table 13-11. PRUSS Debug Capabilities**

| Capability  | Feature              | Notes                                                                 |
|-------------|----------------------|-----------------------------------------------------------------------|
| Basic Debug | Processor halt       | Support user-requested entry into the suspended state                 |
|             | Single step          | Execution of a single instruction before entering the suspended state |
|             | Software breakpoints | Software breakpoints are supported via opcode replacement             |
|             | Core register access | Access to processor core registers                                    |
|             | System memory access | Access to memory from perspective of CPU                              |

### 13.3.11 SoC Debug and Trace

This device includes debug capabilities deployed at the system level, including:

- Software messaging trace
- Debug-aware peripherals
- Traffic monitoring with bus probes
- Global timestamping for trace

More details for each of these capability areas can be found in the corresponding sections below.

#### 13.3.11.1 Software messaging trace

Software messaging trace is supported on this device by an MIPI STP-V2 compliant Arm® CoreSight™ STM with supporting logic that maps initiator IDs to specific STP Major Source IDs. The following device initiators support software messaging:

- A53SS0 cores
- MCU\_M4F
- WKUP\_R5F
- SMS0\_HSM
- DMSS BCDMA
- DMSS PktDMA
- DAP AXI-AP

### 13.3.11.2 Debug-Aware Peripherals

Select peripherals support a debug feature that allows them to react to the debug state of a controlling processor. For instance, a timer peripheral that is allocated to a particular processor could be configured to stop counting when the associated processor is in the halted state. This device includes programmable support for shared peripherals that allows the developer to select the processor whose debug state a given peripheral should receive.

A list of the processors and peripherals that support this debug model can be found in [Table 13-12](#).

**Table 13-12. Debug-Aware Peripheral Support**

| Supported Processors | Supported Peripherals |
|----------------------|-----------------------|
| A53SS0 cores         | GTC                   |
| MCU_M4F              | CPSW3G                |
| WKUP_R5F             | DMSS                  |
| SMS0_HSM             | SA3SS                 |
| --                   | TIMER instances       |
| --                   | EPWM instances        |
| --                   | MCAN instances        |
| --                   | I2C instances         |
| --                   | MCRC64 instances      |
| --                   | ECAP instances        |
| --                   | EQEP instances        |
| --                   | PDMA_SPI              |
| --                   | PDMA_UART             |
| --                   | PDMA_MCASP            |
| --                   | RTI/WWDT instances    |

### 13.3.11.3 Traffic Monitoring With Bus Probes

Traffic monitoring bus probes are deployed at strategic points in the system interconnect and support the following capabilities:

- MIPI STP-V2 compliant trace messaging support with global timestamping support
- Latency Statistics Collection: Statistics on the timeliness of responses to read requests are collected during a sampling window and then read by a profiling entity (application thread or encoded into a trace message)
- Throughput Statistics Collection: Statistics on the amount of data moving across an interface are collected during a sampling window and then read by a profiling entity (application thread or encoded into a trace message)
- Transaction Trace: Information about specific transactions occurring at a probed location are captured and encoded into a trace message
- Complex filtering support allows discrimination of traffic being monitored
- Cross-Trigger support for enabling and disabling probe monitoring

[Table 13-13](#) details the locations in the system interconnect that are probed:

**Table 13-13. Bus Probe Points**

| Probe Point            | Bus Monitoring Details                                        |
|------------------------|---------------------------------------------------------------|
| A53SS0 Write Initiator | Provides visibility to all write requests initiated by A53SS0 |
| A53SS0 Read Initiator  | Provides visibility to all read requests initiated by A53SS0  |
| A53SS0 ACP Target      | Monitors traffic to the A53SS0 ACP port                       |
| DDR Target             | Monitors traffic to DDR                                       |
| GMPC Target            | Monitors traffic to GPMC                                      |
| FSS Target             | Monitors traffic to FSS0                                      |

**Table 13-13. Bus Probe Points (continued)**

| Probe Point              | Bus Monitoring Details                                                                                                                                                       |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DSS Initiator            | Provides visibility to all requests initiated by DSS                                                                                                                         |
| Peripheral CBASS Targets | Monitors traffic to these targets:<br>ECAP#<br>EQEP#<br>I2C#<br>MCAN#<br>PDMA_SPI<br>PDMA_UART<br>SPI#<br>UART#                                                              |
| McASP CBASS Targets      | Monitors traffic to these targets:<br>EPWM#<br>MCASP#                                                                                                                        |
| WKUP CBASS Targets       | Monitors traffic from MAIN to WKUP, including these targets:<br>WKUP_GTC<br>WKUP_R5F<br>WKUP_TIMER#<br>WKUP_RTI<br>WKUP_I2C0<br>WKUP_CTRL_MMRO<br>WKUP_VTM0                  |
| GPU Write Initiator      | Provides visibility to all write requests initiated by GPU                                                                                                                   |
| GPU Read Initiator       | Provides visibility to all read requests initiated by GPU                                                                                                                    |
| MCU CBASS Targets        | Monitors traffic from MAIN to MCU, including these targets:<br>MCU_M4F<br>MCU_SPI#<br>MCU_MCRC64<br>MCU_UART0<br>MCU_MCAN#<br>MCU_TIMER#<br>MCU_DCC0<br>MCU_RTI0<br>MCU_I2C0 |
| PSRAM 0 Target           | Monitors traffic to PSRAM (64KB)                                                                                                                                             |

**Table 13-13. Bus Probe Points (continued)**

| Probe Point                  | Bus Monitoring Details                                                                                                                                                                                                              |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Infrastructure CBASS Targets | Monitors traffic to these targets:<br>CMP_EVENT_INTRROUTER<br>CTRL_MMR<br>DCC#<br>DDPA<br>DFTSS<br>ESM<br>PSRAM#<br>GPIO#<br>EFUSE<br>GPIOMUX_INTRROUTER<br>PADCFG_CTRL_MMR0<br>PLL_MMR0<br>PLLCTRL<br>PSC<br>TIMESYNC_EVENT_ROUTER |

#### 13.3.11.4 Global timestamping for trace

Support for a global timestamp for use by debug is enabled by a 48-bit continuous timestamp managed by the device's GTC. This 48-bit global timestamp is readable by embedded software, via the GTC, and distributed across the device to various trace sources where it is used as a time reference when timestamping trace streams. Trace sources that support global timestamping, include:

- A53SS0 cores: ETM
- MCU\_M4F: ITM and ETM
- SMS0\_HSM: ITM and ETM
- STM
- Bus Probes

#### 13.3.12 Trace Traffic

Trace traffic originates from a trace source, is distributed across the device using Arm® CoreSight™ compliant trace infrastructure components, and reaches one of two possible trace sinks.

##### 13.3.12.1 Trace Sources

A summary of the trace sources present on this device is included in [Table 13-14](#).

**Table 13-14. Trace Sources**

| Domain    | Trace Source    |
|-----------|-----------------|
| SoC Debug | Bus Probes      |
|           | STM             |
| MCU_M4F   | ITM             |
|           | ETM             |
| WKUP_R5F  | ETM             |
| A53SS0    | ETM (each core) |

##### 13.3.12.2 Trace Infrastructure

Trace distribution is accomplished using standard Arm® CoreSight™ compliant trace infrastructure components:

- CoreSight™ Trace Funnels (CSTF): Non-programmable CSTFs are used at points of interleaving where multiple trace sources converge and form a single stream of trace traffic. This device includes one instance of a programmable CSTF that is deployed immediately before the TPIU.

- CoreSight™ Trace Replicator (CSREP): A programmable CSREP is used as a routing device, that can be used to forward trace traffic, based on its ID, to one, both, or none of the device trace sinks.

### 13.3.12.3 Trace Sinks

Two trace sinks are supported on this device:

- Arm® CoreSight™ TPIU: TPIU supports export of trace off-chip via LVC MOS device pins (See 1.3.3.3) for capture by an external receiver.
- TI Trace Buffer Router (TBR) with 64KB of storage: the TBR can function as a trace buffer or as a system bridge. As a trace buffer, the TBR can be setup to capture trace data until the internal buffer fills or it can operate as a circular buffer that will capture continuously. When configured as a system bridge the TBR's storage becomes an elastic buffer that supports the concurrent queueing and dequeuing of trace traffic. The system bridge mode supports interrupt and event notification capabilities that support integration with device level CPUs and/or DMAs to support a variety of use cases, including, for e.g., relocation of trace data to DDR and off-chip export over USB.

### 13.3.13 Application Support

TI includes a set of system level debug facilities in the Debug Subsystem of devices known as Chip Tools (CTools). For easy integration of A53 processor trace and system trace into applications, a set of libraries commonly referred to as CToolsLib are provided. CToolsLib is a collection of embedded target APIs/libraries focused on enabling easy access to the CTools. CToolsLib encompasses the following libraries to assist in trace integration:

- STM Library
- CP Tracer Library
- TBR Library
- ETM Library

For more information about these libraries, downloadable files, and other useful links, please visit the [CToolsLib Wiki site](#).

The previous link connects to TI community resources. Linked contents are provided “AS IS” by the respective contributors. They do not constitute TI specifications and do not necessarily reflect TI’s views; see TI’s [Terms of Use](#).

## Revision History



### Changes from November 5, 2022 to September 8, 2023 (from Revision Initial (November 2022) to Revision B (September 2023))

|                                                                                                                                             | Page |
|---------------------------------------------------------------------------------------------------------------------------------------------|------|
| • Update number of rings supported.....                                                                                                     | 18   |
| • Remove SuperSpeed as it is not supported.....                                                                                             | 20   |
| • Swap Security and Safety bits in Device ID.....                                                                                           | 30   |
| • Remove "Start as entered in chapter" column. Remove alternating bold text.....                                                            | 32   |
| • Restructured Initiator-Side Security Controls and Firewalls Section.....                                                                  | 81   |
| • Added <a href="#">Table 4-40</a> .....                                                                                                    | 120  |
| • Added <a href="#">Table 4-41</a> .....                                                                                                    | 120  |
| • Updated MCASP Clocks to include AHCLKX/AHCLKR.....                                                                                        | 122  |
| • Rename Title to GPIO0 Mapping. Add missing Table Header.....                                                                              | 128  |
| • Add missing Table Header.....                                                                                                             | 129  |
| • Rename title to MCU_GPIO0 Mapping. Add missing Table Header.....                                                                          | 130  |
| • Update unsupported GPMC_A[27:0] to GPMC_A[27:23].....                                                                                     | 154  |
| • Add High Speed DDR to Unsupported features.....                                                                                           | 156  |
| • Change Camera Streaming Interface to Camera Serial Interface.....                                                                         | 169  |
| • Add Modules and Subsystems with ECC Aggregator Table.....                                                                                 | 203  |
| • Add additional unsupported features.....                                                                                                  | 467  |
| • Reset signal only required for NOR type memories.....                                                                                     | 482  |
| • Remove "The USB backup boot option allows only 0.85 V core voltage" from note in USB backup boot mode. Restriction removed.....           | 498  |
| • Change MSRAM to internal RAM.....                                                                                                         | 509  |
| • Update delay from ns to us for entries 54-63.....                                                                                         | 530  |
| • Update Voltage monitored in POK Module Overview Table: VDDR_DDR-->VDDS_DDR, VMON_3P3 MCU-->VMON_3P3 SOC, VMON_1P8 MCU-->VMON_1P8 SOC..... | 550  |
| • Add VMON Threshold Table.....                                                                                                             | 552  |
| • Separate UV/OV Tables into POK Types. Add correct Configuration Register names.....                                                       | 552  |
| • <a href="#">PGD Allocation within Device Domains</a> and <a href="#">PGD Integration Summary</a> tables updated.....                      | 565  |
| • Reset and Naming Alignment (WARMRESET->WARMRST) (DMSC->DMSC-L) (MMR0->MMR).....                                                           | 569  |
| • MCU/MAIN domain nomenclature standardization.....                                                                                         | 571  |
| • MCU/MAIN domain nomenclature standardization.....                                                                                         | 573  |
| • CTRLMMR Register Link Updates.....                                                                                                        | 598  |
| • Update register name to MCU_CTRL_MMR_CFG0_MCU_OBSCLK_CTRL.....                                                                            | 616  |
| • Update register name to MAIN_CTRL_MMR_CFG0_OBSCLK0_CTRL.....                                                                              | 617  |
| • Update WKUP_CLKOUT0 Mux Diagram to remove divider. ....                                                                                   | 618  |
| • Update register bit name to CLKOUT_CTRL_WKUP_CLKOUT_SEL.....                                                                              | 618  |
| • Correct Register names.....                                                                                                               | 626  |
| • Correct REF_DIV name.....                                                                                                                 | 627  |
| • Correct register name FB_DIV.....                                                                                                         | 629  |
| • Update PLL Domains for SSMOD.....                                                                                                         | 630  |
| • Update register names.....                                                                                                                | 634  |
| • Correct _HSDIV_CTRL[15] bitfield.....                                                                                                     | 634  |

---

|                                                                                |      |
|--------------------------------------------------------------------------------|------|
| • Corrected some bitfield names.....                                           | 636  |
| • Added brown out note.....                                                    | 636  |
| • Updated some register names.....                                             | 637  |
| • Add PLL Integer calibration enabled recommendation.....                      | 637  |
| • added footnote for PRU MII TX pin mapping.....                               | 702  |
| • Add link to Local Interrupt Controller.....                                  | 715  |
| • Add link to Local Interrupt Controller and Interrupt Requests Mapping.....   | 715  |
| • Add link to Local Interrupt Controller.....                                  | 719  |
| • Add link to PRUSS Environment.....                                           | 729  |
| • Secure Proxy moved to Interprocessor Communications Chapter.....             | 800  |
| • Remove TimeSync Support.....                                                 | 833  |
| • Add RX State Mapping Table.....                                              | 870  |
| • Add TX State Mapping Table.....                                              | 872  |
| • Add BCDMA Mapping Table.....                                                 | 876  |
| • Update Transfer Request Packet Descriptor Layout.....                        | 893  |
| • Update number of rings supported.....                                        | 930  |
| • Add clarification of GPIO interrupt generation.....                          | 1103 |
| • Changed reference clock from 48MHz to 50MHz.....                             | 1141 |
| • Change clock rates.....                                                      | 1153 |
| • Updated Baud Rate for 192MHz Functional Clock in Subsection UART.....        | 1184 |
| • Signal names added to UART I/O Signals Table.....                            | 1188 |
| • Update Event FIFO depth from 10 to 32.....                                   | 1320 |
| • Add PORT2 to TX INFO Word 3 Format, SRD_ID field.....                        | 1332 |
| • Add Port 2 to RX INFO Word 2, TO_PORT field.....                             | 1336 |
| • Maximum bytes supported by STIG is 16.....                                   | 1374 |
| • Add 3.3V to Legacy MMC, High Speed SDR and High Speed DDR MMC Support.....   | 1506 |
| • IO Signals made generic for different device types.....                      | 1508 |
| • Remove 33 $\Omega$ resistor requirement from MMCi_CLK.....                   | 1508 |
| • EPWM I/O Signals Figure and Table updated to be generic for all devices..... | 1651 |
| • Added steps to Clear GTC Counter.....                                        | 1763 |
| • Updated DSS features list.....                                               | 1924 |
| • Change DSS0_VP_POL_FREQ IPC/RF Note to be opposite instead of match.....     | 1999 |
| • Added DAP APSEL Table.....                                                   | 2018 |

---

## IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATA SHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements.

These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI's products are provided subject to [TI's Terms of Sale](#) or other applicable terms available either on [ti.com](#) or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products.

TI objects to and rejects any additional or different terms you may have proposed.

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265  
Copyright © 2024, Texas Instruments Incorporated