

# ABSTRACT

This document describes the known exceptions to the functional specifications (advisories). This document may also contain usage notes. Usage notes describe situations where the device's behavior may not match presumed or documented behavior. This may include behaviors that affect device performance or functional correctness.

# **Table of Contents**

| 1 Modules Affected                                                 | 2   |
|--------------------------------------------------------------------|-----|
| 2 Nomenclature. Package Symbolization, and Revision Identification | 4   |
| 3 Silicon Revision 1.0. 2.0 Usage Notes and Advisories             | . 6 |
| Revision History                                                   | 36  |
| ·····                                                              |     |

1



# **1 Modules Affected**

Table 1-1 shows the module(s) that are affected by each usage note.

# Table 1-1. Usage Note by Modules

| MODULE | USAGE NOTE |
|--------|------------|
| N/A    |            |

Table 1-2 shows the module(s) that are affected by each advisory.

Table 1-2. Advisories by Modules

| MODULE   | ADVISORY                                                                                                      | SILICON REVISIONS |        |
|----------|---------------------------------------------------------------------------------------------------------------|-------------------|--------|
|          |                                                                                                               | SR 1.0            | SR 2.0 |
| Boot     | i2307 — Boot: ROM does not properly select OSPI clocking modes based on BOOTMODE                              | YES               | YES    |
|          | i2360 — Boot: Ethernet RMII Boot Mode is not supported                                                        | YES               | YES    |
|          | i2361 — Boot: SPI and xSPI BOOTMODE Pin Mapping changes for SR2.0                                             | NO                | YES    |
| CBASS    | i2207 — CBASS: Command Arbitration Blocking                                                                   | YES               | YES    |
|          | i2235 — CBASS Null Error Interrupt Not Masked By Enable Register                                              | YES               | YES    |
| CPSW     | i2184 — CPSW: IET express traffic policing issue                                                              | YES               | YES    |
|          | i2185 — CPSW: Policer color marking issue                                                                     | YES               | YES    |
|          | i2208 — CPSW: ALE IET Express Packet Drops                                                                    | YES               | YES    |
| DCC      | i2209 — DCC: Incorrect clock selection                                                                        | YES               | NO     |
| DDR      | i2157 — DDR: Controller anomaly in setting wakeup time for low power states                                   | YES               | YES    |
|          | i2159 — DDR: VRCG high current mode must be used during LPDDR4 CBT                                            | YES               | YES    |
|          | i2160 — DDR: Valid VRef Range Must be Defined During LPDDR4 Command Bus Training                              | YES               | YES    |
|          | i2166 — DDR: Entry and exit to/from Deep Sleep low-power state can cause PHY internal clock misalignment      | YES               | YES    |
|          | i2182 — DDR: Dual-rank non-power-of-2 density not supported with row-cs-bank-col address mapping              | YES               | YES    |
|          | i2186 — DDR rate limited to 2666 MT/s 1333 MHz clock                                                          | YES               | NO     |
|          | i2232 — DDR: Controller postpones more than allowed refreshes after frequency change                          | YES               | YES    |
|          | i2244 — DDR: Valid stop value must be defined for write DQ VREF training                                      | YES               | YES    |
| DMSC     | i2245 — DMSC: Firewall Region requires specific configuration                                                 | YES               | YES    |
| ECC AGGR | i2049 — ECC AGGR: Potential IP Clockstop/reset sequence hang due to pending ECC Aggregator interrupts         | YES               | YES    |
| 13C      | i2197 — I3C: Slave mode is not supported                                                                      | YES               | YES    |
|          | i2205 — I3C Command fetched during pending IBI is not properly processed in some cases                        | YES               | YES    |
|          | i2216 — I3C: Command execution may fail during slave-initiated IBI address byte reception                     | YES               | YES    |
| IA       | i2196 — IA: Potential deadlock scenarios in IA                                                                | YES               | YES    |
| JTAG     | i2228 — JTAG: TAP used by Debuggers may be inaccessible if TRSTn device pin is never asserted                 | YES               | NO     |
| MCAN     | i2278 — MCAN: Message Transmit order not guaranteed from dedicated Tx Buffers configured with same Message ID | YES               | YES    |
|          | i2279 — MCAN: Specification Update for dedicated Tx Buffers and Tx Queues configured with same Message ID     | YES               | YES    |
| MCU      | i2217 — Recommended POST selection via MCU_BOOTMODE[09:08]                                                    | YES               | NO     |
| MDIO     | i2329 — MDIO: MDIO interface corruption (CPSW and PRU-ICSS)                                                   | YES               | YES    |
| MSMC     | i2116 — MSMC: Set-hazarding logic withholding RT access waiting on NRT access completion                      | YES               | YES    |
|          | i2187 — MSMC: Cache Resize to 0 Refreshes Tags instead of Updating them                                       | YES               | YES    |
|          | i2201 — MSMC: Incorrect Parity Detect on bytecount                                                            | YES               | NO     |
| OSPI     | i2189 — OSPI: Controller PHY Tuning Algorithm                                                                 | YES               | YES    |
| PCle     | i2183 — PCIe: Link up failure when unused lanes are not assigned to PCIe Controller                           | YES               | YES    |

2

| MODULE  | ADVISORY                                                                                                                     | SILICON REVISIONS |        |
|---------|------------------------------------------------------------------------------------------------------------------------------|-------------------|--------|
|         |                                                                                                                              |                   | SR 2.0 |
|         | i2237 — PCIe: SerDes Reference Clock Output does not comply to Vcross, Rise-Fall Matching, and Edge Rate limits              | YES               | NO     |
|         | i2241 — PCle: The SerDes PCle Reference Clock Output can exceed the 5.0 GT/s Data Rate RMS jitter limit                      | YES               | NO     |
|         | i2242 — PCIe: The 4-L SerDes PCIe Reference Clock Output is temporarily disabled while changing Data Rates                   | YES               | YES    |
| POK     | i2277 — POK: De-Glitch (filter) is based upon only two samples                                                               | YES               | NO     |
| PSIL    | i2137 — Clock stop operation can result in undefined behavior                                                                | YES               | YES    |
| R5FSS   | i2161 — R5FSS: Debugger cannot access VIM module while it is active                                                          | YES               | NO     |
|         | i2227 — R5FSS: Error interrupt CCM_COMPARE_STAT_PULSE_INTR incorrectly driven                                                | YES               | YES    |
| RAT     | i2062 — RAT: Error Interrupt Triggered Even When Error Logging Disable Is Set                                                | YES               | YES    |
| RINGACC | i2177 — RINGACC: The ring accelerator's debug transaction trace stream can be corrupted by certain ring access sequences     | YES               | YES    |
| STOG    | i2123 — STOG: Timed Out Emulation Debug write responses from the Slave Gasket always return Success                          | YES               | YES    |
|         | i2126 — STOG: Error miscounting when there are two concurrent timeouts or two concurrent unexpected responses                | YES               | YES    |
|         | i2127 — STOG: SRC side write data bus hang when a write command timeout occurs the same cycle as last acceptance on DST side | YES               | YES    |
| UDMA    | i2146 — UDMA: Force teardown bitfield readback is masked in realtime TX/RX registers                                         | YES               | YES    |
|         | i2320 — UDMA, UDMAP: Descriptors and TRs required to be returned unfragmented                                                | YES               | YES    |
| UDMAP   | i2163 — UDMAP: UDMA transfers with ICNTs and/or src/dst addr NOT aligned to 64B fail when used in "event trigger" mode       | YES               | YES    |
|         | i2234 — UDMA: TR15 hangs if ICNT0 is less than 64 bytes                                                                      | YES               | YES    |
| USART   | i2310 — USART: Erroneous clear/trigger of timeout interrupt                                                                  | YES               | YES    |
|         | i2311 — USART: Spurious DMA Interrupts                                                                                       | YES               | YES    |
| USB     | $\rm i2091-2.0~PHY$ hangs if received signal amplitude crosses squelch threshold multiple times within the same packet       | YES               | YES    |
|         | i2134 — USB: 2.0 compliance receive sensitivity test limitation                                                              | YES               | YES    |
| xSPI    | i2257 — xSPI boot mode redundant image boot failure                                                                          | YES               | NO     |

# Table 1-2. Advisories by Modules (continued)



# 2 Nomenclature, Package Symbolization, and Revision Identification 2.1 Device and Development-Support Tool Nomenclature

To designate the stages in the product development cycle, TI assigns prefixes to the part numbers of all microprocessors (MPUs) and support tools. Each device has one of three prefixes: X, P, or null (no prefix) (for example, DRA821). Texas Instruments recommends two of three possible prefix designators for its support tools: TMDX and TMDS. These prefixes represent evolutionary stages of product development from engineering prototypes (TMDX) through fully qualified production devices and tools (TMDS).

Device development evolutionary flow:

- **X** Experimental device that is not necessarily representative of the final device's electrical specifications and may not use production assembly flow.
- **P** Prototype device that is not necessarily the final silicon die and may not necessarily meet final electrical specifications.

null Production version of the silicon die that is fully qualified.

Support tool development evolutionary flow:

TMDX Development-support product that has not yet completed Texas Instruments internal qualification testing.

TMDS Fully-qualified development-support product.

X and P devices and TMDX development-support tools are shipped against the following disclaimer:

"Developmental product is intended for internal evaluation purposes."

Production devices and TMDS development-support tools have been characterized fully, and the quality and reliability of the device have been demonstrated fully. TI's standard warranty applies.

Predictions show that prototype devices (X or P) have a greater failure rate than the standard production devices. Texas Instruments recommends that these devices not be used in any production system because their expected end-use failure rate still is undefined. Only qualified production devices are to be used.

For additional information how to read the complete device name for any DRA821 device, see the specific-device Datasheet (SRPSP57).

# 2.2 Devices Supported

This document supports the following devices:

• DRA821

Reference documents for the supported devices are:

• Jacinto™ DRA821 Automotive Processors Datasheet (SPRSP57)



# 2.3 Package Symbolization and Revision Identification

Figure 2-1 shows an example of package symbolization.

Table 2-1 lists the device revision codes.



Figure 2-1. Package Symbolization

| Table 2-1. Revision | Identification |
|---------------------|----------------|
|---------------------|----------------|

| DEVICE REVISION CODE | SILICON REVISION | COMMENTS |
|----------------------|------------------|----------|
| A or BLANK           | 1.0              |          |
| В                    | 2.0              |          |



# 3 Silicon Revision 1.0, 2.0 Usage Notes and Advisories

This section lists the usage notes and advisories for this silicon revision.

# 3.1 Silicon Revision 1.0, 2.0 Usage Notes

No known usage notes for this silicon revision.

# 3.2 Silicon Revision 1.0, 2.0 Advisories

| i2049          | ECC_AGGR: Potential IP Clockstop/Reset Sequence Hang due to Pending ECC<br>Aggregator Interrupts                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Details:       | The ECC Aggregator module is used to aggregate safety error occurrences (which are rare) and generate interrupts to notify software. The ECC Aggregator provides software control over the enabling/disabling and clearing of safety errors interrupts.                                                                                                                                                                                                                                                |  |
|                | When software is performing a clockstop/reset sequence on an IP, the sequence can<br>potentially not complete because the IP's associated ECC Aggregator instance is not idle.<br>The ECC Aggregator idle status is dependent upon any pending safety error interrupts<br>either enabled or disabled, which have not been cleared by software. As a result, the<br>IP's clockstop/reset sequence may never complete (hang) if there are any pending safety<br>errors interrupts that remain uncleared. |  |
| Workaround(s): | General Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                | Clockstopping the ECC Aggregator is not supported in functional safety use-cases.                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                | Software should use the following workaround for non-functional safety use-cases:<br>1. Enable all ECC Aggregator interrupts for the IP<br>2. Service and clear all Pending interrupts<br>3. Step 3:                                                                                                                                                                                                                                                                                                   |  |
|                | <ul><li>a. Disable all interrupt sources to the ECC Aggregator, followed by performing<br/>Clockstop/reset sequence.</li><li>b. Perform Clockstop/reset sequence, while continuing to service/clear pending<br/>interrupts.</li></ul>                                                                                                                                                                                                                                                                  |  |
|                | <ul> <li>Due to interrupts being external stimuli, software has two options for step 3:</li> <li>1. Disable all interrupt sources (EDC CTRL checkers) that can generate pending ECC_AGGR interrupts prior to performing the clockstop/reset sequence</li> <li>2. Continue to service/clear pending interrupts that occur while performing the clkstop/ reset sequence. The sequence would proceed when all interrupts are cleared.</li> </ul>                                                          |  |
|                | Software in general may need to detect pending interrupts that continuously fire during this entire sequence (ex. in the case of a stuck-at fault scenario), and disable their associated EDC CTRL safety checkers to allow the clockstop/reset sequence to progress towards completion.                                                                                                                                                                                                               |  |
| i2062          | RAT: Error Interrupt Triggered Even When Error Logging Disable Is Set                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Details:       | If the RAT error logging is programmed to disable logging and enable interrupts, then<br>an error will incorrectly trigger an interrupt but the error log registers will correctly not be<br>updated. The error interrupt should not have been generated.                                                                                                                                                                                                                                              |  |
| Workaround(s): | If the RAT error logging is disabled, then the error interrupt should also be disabled by software.                                                                                                                                                                                                                                                                                                                                                                                                    |  |

| i2091          | USB: 2.0 PHY Hangs if Received Signal Amplitude Crosses Squelch Threshold<br>Mmultiple Times Within the Same Packet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Details:       | USB 2.0 PHY implements a squelch detection circuit on the receiver to ensure noise is not interpreted as valid data when the bus is idle. The squelch circuit blocks invalid data by disabling the receiver output while the DP/DM differential signal amplitude is less than the squelch threshold.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                | The PHY may hang if the DP/DM differential signal amplitude drops below the squelch<br>threshold for a brief period of time and increases back above the squelch threshold within<br>the same packet. The issue does not occur if the DP/DM differential signal amplitude<br>crosses the squelch threshold during the idle time between two packets.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Workaround(s): | The issue can be avoided by ensuring the DP/DM differential signal amplitude applied to the receiver input remains above the squelch threshold during valid data transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| i2116          | MSMC: Set-hazarding logic withholding RT access waiting on NRT access completion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Details:       | The DDR controller prioritizes writes over reads to the same page. Additionally, MSMC hazards transactions on the same set regardless of the real-time attribute. Due to these two facts, a stream of writes to the same page followed by a non real-time read to the same page can effectively block out a real-time access command indefinitely.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                | <ul> <li>Example sequence:</li> <li>1. Stream of Writes to page A sent from MSMC to DDR Controller</li> <li>2. Non Real-Time Read to page A sent from MSMC to DDR Controller <ul> <li>This command will be stalled in the DDR Controller behind the completion of the 1) Stream of Writes</li> </ul> </li> <li>3. Real-Time Access to same set as the 2) Non Real-Time Read will be stalled inside MSMC due to Set Hazarding</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Workaround(s): | <ul> <li>Software should attempt the following workarounds in order of least to most impact to SW.</li> <li>1. Cadence DDR controller prioritizes writes to the same page over a read from another page causing a delay in returning the read. Try reducing the DDR controller command_age_count from 0xto 0xF - corresponding to reducing the command age count from 16 DDR refresh cycles (62 us) to 1 refresh cycle (3.9 us). In most of the cases issue is resolved with this setting, but in some cases there are still some underflows. In that case SW may require either 2 or 3 workaround.</li> <li>2. If possible set the ARM MMU attribute to configure DDR as "Normal memory" instead of "Device memory" type. This makes ARM to DDR access to be more efficient and helps to alleviate the problem. This is the observation based on test results so far, but it may need more analysis and further system testing. If this workaround is not possible in the system, SW may require workaround 3).</li> <li>3. If possible make the Real-Time access as non IO-coherent. Set the RT access ATYPE = 3 for non-virtualized cases, and set ATYPE=1 &amp; MEMTYPE=0 for PVU</li> </ul> |
|                | specific cases. This forces the RT traffic to bypass the MSMC set-hazarding logic. SW will have to do the cache operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



| i2123          | STOG: Timed Out Emulation Debug write responses from the Slave Gasket always return Success                                                                                           |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Details:       | When the gasket flushes transactions, all responses should go back with a time-out error, but in the case of emulation debug writes, the response is incorrectly returned as Success. |
| Workaround(s): | SW should not assume emulation debug writes are successful when there is a system timeout occurrence/interrupt.                                                                       |

| i2126          | STOG: Error miscounting when there are two concurrent timeouts or two concurrent unexpected responses                                                                                                                                                                                                                                                                                                                              |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Details:       | When there is a read command and write command that timeout in the same cycle, the timeout counter will only increment by 1 instead of 2 in this situation. Likewise, if an unexpected read response and an unexpected write response both arrive in the same cycle, the unexpected response counter will only increment by 1 instead of 2.                                                                                        |  |  |
| Workaround(s): | The error counters are primarily supplemental information for software debug. Only one timeout error command/transaction info is recorded. The counters saturate at a count of 3, so the software should primarily focus on the error counter value being non-zero vs the exact counter value. The same approach should be applied to the unexpected response counter. Note: unexpected responses are dropped by the flush gasket. |  |  |



| i2127          | STOG: SRC side write data bus hang when a write command timeout occurs the same cycle as last acceptance on DST side                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Details:       | If a write command times out the same cycle the last write dataphase is accepted on the destination side of the gasket, the gasket's source side will permanently stop accepting write data and won't be able to flush/auto respond properly.                                                                                                                                                                                                                                                                                     |
|                | Programming the gasket with low timeout period can result in a system hang due to the time out gasket stop accepting write data.                                                                                                                                                                                                                                                                                                                                                                                                  |
| Workaround(s): | Software should set a sufficiently large timeout period that well exceeds the longest possible write command burst transmission period. The default timeout period for the gasket is sufficient - 3 x 2^30 cycles.                                                                                                                                                                                                                                                                                                                |
| i2134          | USB: 2.0 Compliance Receive Sensitivity Test Limitation                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Details:       | Performing receive sensitivity tests (EL_16 and EL_17) as defined in the USB-IF USB 2.0<br>Electrical Compliance Test Specification may invoke the problem described in Advisory<br>i2091.                                                                                                                                                                                                                                                                                                                                        |
|                | The issue was originally found while performing these tests using automation software,<br>which increased USB signal amplitude while sending packets. The software was<br>sweeping the amplitude from a value less than 100 mV to a value greater than 150<br>mV while verifying the device under test (DUT) NAK'd all packets below 100 mV and<br>NAK'd no packets above 150 mV. However, increasing the amplitude through the squelch<br>threshold while sending valid packets may lock the PHY as described in Advisory i2091. |
| Workaround(s): | Enable both of the following hardware workarounds.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                | Set cdr_eb_wr_reset bit (bit 7) to 1'b1 in UTMI_REG28 register present in USB*_PHY2 region.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                | Set phyrst_a_enable bit (bit 0) to 1'b1 in PHYRST_CFG register present in USB*_MMR_MMRVBP_USBSS_CMN region. Please note that phyrst_a_value (bits 12:8) in PHYRST_CFG register should be retained at default value of 0xE.                                                                                                                                                                                                                                                                                                        |
| i2137          | PSIL: Clock stop operation can result in undefined behavior                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Details:       | The clock stop interface is a request/acknowledge interface used to coordinate the handshaking of properly stopping the main clock to the module. Attempting a clock stop on the module without first performing the channel teardowns or clearing of global enable bits will result in module-specific behavior that may be undefined.                                                                                                                                                                                           |
|                | The impacted modules are PDMA, SA2UL, Ethernet SW, CSI, UDMAP, ICSS, and CAL.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Workaround(s): | 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 modules), 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 modules).                                                                                                                                                                           |
| i2146          | UDMA: Force teardown bitfield readback is masked in realtime TX/RX registers                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Details:       | The force teardown bit field will not remain set in the read back of the realtime TX/RX registers after a force teardown is initiated.                                                                                                                                                                                                                                                                                                                                                                                            |
| Workaround(s): | The Force Teardown operation is only used by software to intervene to address a catastrophic system condition, so software should separately track when it initiates a forced teardown verses a normal teardown, and thus not depend on the readback value of the force teardown bitfield to obtain this information.                                                                                                                                                                                                             |

| i2157          | DDR: Controller Anomaly in Setting Wakeup Time for Low Power States                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Details:       | The DDR controller may erroneously decrease the wakeup time for the present low power state if the wakeup time for the next deeper power state is either disabled, or set to a lower value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Workaround(s): | If a particular low power state is enabled by setting a bit in the DDRSS_CTL_139[29-24] LPI_WAKEUP_EN bit field, all deeper power state bits must also be enabled. From bit 0 through 4, low power states go deeper and deeper as the bit number increases. For example, if bit 0 is set, all bits from 1 through 4 must also be set. Similarly, if bit 2 is set, bit 3 and 4 must also be set.                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                | <ul> <li>In addition, the following wakeup values must be programmed in increasing order:</li> <li>1. LPI_CTRL_IDLE_WAKEUP_FN related to LPI_WAKEUP_EN[0] -&gt; value should be less than all fields below</li> <li>2. LPI_PD_WAKEUP_FN related to LPI_WAKEUP_EN[1] -&gt; value should be less than all fields below</li> <li>3. LPI_SR_SHORT_WAKEUP_FN, LPI_SR_LONG_WAKEUP_FN, LPI_SRPD_SHORT_WAKEUP_FN, LPI_SRPD_LONG_WAKEUP_FN related to LPI_WAKEUP_EN[2] -&gt; value should be less than all fields below</li> <li>4. LPI_SR_LONG_MCCLK_GATE_WAKEUP_FN, LPI_SRPD_LONG_WAKEUP_EN[3] -&gt; value should be less than all fields below</li> <li>5. LPI_TIMER_WAKEUP_FN related to LPI_WAKEUP_EN[4] -&gt; highest value, where FN = F0, F1, and F2 for different frequency set points.</li> </ul> |  |
| i2159          | DDR: VRCG High Current Mode Must be Used During LPDDR4 CBT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 12155          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Details:       | The DDR PHY updates VREFca for the command/address bus during LPDDR4<br>Command Bus Training (CBT). Bit 3 in LPDDR4 Mode Register 13 (MR13) defines the<br>VRef Current Generator (VRCG) mode inside the LPDDR4 device. If this bit is set to<br>0, the VREFca settling time is too long for subsequent operations to work properly. To<br>ensure proper operation of CBT, bit 3 in MR13 must be set to 1 (VRef Fast Response high<br>current mode) during CBT.                                                                                                                                                                                                                                                                                                                                    |  |
| Workaround(s): | Set the following fields to 1 before enabling CBT, and clear to 0 after CBT is complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                | For chip select 0: PI_MR13_DATA_0[3] in the DDRSS_PI_259 register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                | For chip select 1: PI_MR13_DATA_1[3] in the DDRSS_PI_261 register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| i2160          | DDR: Valid VRef Range Must be Defined During LPDDR4 Command Bus Training                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| Details:       | The DDR PHY updates VREF(ca) for the command/address bus during LPDDR4<br>Command Bus Training (CBT). If VREF(ca) search range is set to invalid values such<br>as no working settings can be found during CBT, the training process could fail or hang.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| Workaround(s): | Set the following fields to known valid working values before enabling CBT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                | For frequency set 0: DDRSS_PI_199[6-0] PI_CALVL_VREF_INITIAL_START_POINT_F0 and DDRSS_PI_199[14-8] PI_CALVL_VREF_INITIAL_STOP_POINT_F0 bit fields.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                | For frequency set 1: DDRSS_PI_199[22-16]<br>PI_CALVL_VREF_INITIAL_START_POINT_F1 and DDRSS_PI_199[30-24]<br>PI_CALVL_VREF_INITIAL_STOP_POINT_F1 bit fields.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                | For frequency set 2: DDRSS_PI_200[6-0] PI_CALVL_VREF_INITIAL_START_POINT_F2 and DDRSS_PI_200[14-8] PI_CALVL_VREF_INITIAL_STOP_POINT_F2 bit fields.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |



| i2160 (continued) | DDR: Valid VRef Range Must be Defined During LPDDR4 Command Bus Training                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                   | Recommendation is to use the nominal VRef value (based on the device programming of VDDQ/3 or VDDQ/2.5 along with the drive/termination settings used) +/- 4%.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| i2161             | R5FSS: Debugger Cannot Access VIM Module While It Is Active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Details:          | This issue impacts the Vectored Interrupt Module (VIM) inside R5FSS. There are registers inside VIM which change the state of the IP when they are read (such as VIM_IRQVEC). The expected behavior is that only functional reads should cause the state change. Debug reads (generated by TI debug tools such as CCS) to these registers should leave the state as it is. An issue exists currently where VIM treats debug register reads in the same way as functional register reads. This can cause a debug operation (such as opening a VIM register memory window in CCS) to inadvertently change the state of the VIM IP, making debug ineffective. |  |
| Workaround(s):    | There is no work-around for this issue. The user should avoid accessing VIM registers while debugging.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |

# i2163

UDMAP: UDMA transfers with ICNTs and/or src/dst addr NOT aligned to 64B fail when used in "event trigger" mode

Details:

Note

The following description uses an example a C7x DSP core, but it applies to any other processing cores which can program the UDMA.

For DSP algorithm processing on C6x/C7x, the software often uses UDMA in NavSS or DRU in MSMC. In many cases, UDMA is used instead of DRU, because DRU channels are reserved in many use-cases for C7x/MMA deep learning operations. In a typical DSP algorithm processing, data is DMA'ed block by block to L2 memory for DSP, and DSP operates on the data in L2 memory instead of operating from DDR (through the cache). The typical DMA setup and event trigger for this operation is as below; this is referred to as "2D trigger and wait" in the following example.

For each "frame":

- 1. Setup a TR typically 3 or 4 dimension TR.
  - a. Set TYPE = 4D\_BLOCK\_MOVE\_REPACKING\_INDIRECTION
  - b. Set EVENT\_SIZE = ICNT2\_DEC
  - c. Set TRIGGER0 = GLOBAL0
  - d. Set TRIGGER0\_TYPE = ICNT2\_DEC
  - e. Set TRIGGER1 = NONE
  - f. ICNT0 x ICNT1 is block width x block height
  - g. ICNT2 = number of blocks
  - h. ICNT3 = 1
  - i. src addr = DDR
  - j. dst addr = C6x L2 memory
- 2. Submit this TR
  - a. This TR starts a transfer on GLOBAL TRIGGER0 and transfers ICNT0xICNT1 bytes, then raises an event
- 3. For each block do the following:
  - a. Trigger DMA by setting GLOBAL TRIGGER0
  - b. Wait for the event that indicates that the block is transferred
  - c. Do DSP processing

This sequence is a simplified sequence; in the actual algorithm, there can be multiple channels doing DDR to L2 or L2 DDR transfer in a "ping-pong" manner, such that DSP processing and DMA runs in parallel. The event itself is programmed appropriately at the channel OES registers, and the event status check is done using a free bit in IA for UDMA.

When the following conditions occur, the event in step 3.2 is not received for the first trigger:

- Condition 1: ICNT0xICT1 is NOT a multiple of 64.
- Condition 2: src or dst is NOT a multiple of 64.
- Condition 3: ICNT0xICT1 is NOT a multiple of 64 and src/dst address not a multiple of 64

Multiple of 16B or 32B for ICNT0xICNT1 and src/dst addr also has the same issue, where the event is not received. Only alignment of 64B makes it work.

Conditions in which it works:

- If ICNT0xICNT1 is made a multiple of 64 and src/dst address a multiple of 64, the test case passes.
- If DRU is used instead of UDMA, then the test passes. You must submit the TR to DRU through the UDMA DRU external channel. With DRU and with ICNTs and src/dst addr unaligned, the user can trigger and get events as expected when TR is



| i2163 (continued) | UDMAP: UDMA transfers with ICNTs and/or src/dst addr NOT aligned to 64B fail when used in "event trigger" mode                                                                                                                                                                                                                                                                                                                                              |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                   | programmed such that the number of events and number of triggers in a frame is 1,<br>i.e ICNT2 = 1 in above case or EVENT_SIZE = COMPLETION and trigger is NONE.<br>Then the completion event occurs as expected. This is not feasible to be used by the<br>use-cases in question.                                                                                                                                                                          |  |
|                   | Above is a example for "2D trigger and wait", the same constraint applies for "1D trigger and wait" and "3D trigger and wait":                                                                                                                                                                                                                                                                                                                              |  |
|                   | <ul> <li>For "1D trigger and wait", ICNT0 MUST be multiple of 64</li> <li>For "3D trigger and wait", ICNT0xICNT1xICNT2 MUST be multiple of 64</li> </ul>                                                                                                                                                                                                                                                                                                    |  |
| Workaround(s):    | Set the EOL flag in TR for UDMAP as shown in following example:                                                                                                                                                                                                                                                                                                                                                                                             |  |
|                   | <ul> <li>1D trigger and wait <ul> <li>TR.FLAGS  = CSL_FMK(UDMAP_TR_FLAGS_EOL, CSL_UDMAP_TR_FLAGS_EOL_ICNT0);</li> </ul> </li> <li>2D trigger and wait <ul> <li>TR.FLAGS  = CSL_FMK(UDMAP_TR_FLAGS_EOL, CSL_UDMAP_TR_FLAGS_EOL_ICNT0_ICNT1);</li> </ul> </li> <li>3D trigger and wait <ul> <li>TR.FLAGS  = CSL_FMK(UDMAP_TR_FLAGS_EOL, CSL_UDMAP_TR_FLAGS_EOL, CSL_FMK(UDMAP_TR_FLAGS_EOL, CSL_UDMAP_TR_FLAGS_EOL_ICNT0_ICNT1_ICNT2);</li> </ul> </li> </ul> |  |
|                   | There is no performance impact due to this workaround.                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| i2166             | DDR: Entry and exit to/from Deep Sleep low-power state can cause PHY internal clock misalignment                                                                                                                                                                                                                                                                                                                                                            |  |
| Details:          | When DDR PHY enters the Deep Sleep low-power state, there is a delay before the PHY PLL is disabled and gated off. If exit from Deep Sleep occurs before the PHY PLL is disabled, the PHY internal clocks can get misaligned with respect to each other, resulting in timing failures inside the PHY.                                                                                                                                                       |  |
| Workaround(s):    | If using software-initiated low-power mode by writing to LP_CMD in the DENALI_CTL_132 register, ensure that when entry into low-power mode has been acknowledged, wait for a minimum of 160 DDR clock cycles before requesting an exit from low-power mode. Another option is to use the following workaround.                                                                                                                                              |  |
|                   | If using PSC to disable the DDR interface, ensure that after disabling of DDR interface has been acknowledged, wait for a minimum of 160 DDR clock cycles before sending a request to enable it. Another option is to use the following workaround.                                                                                                                                                                                                         |  |
|                   | If using the controller's automatic mechanism for low power entry/exit using LP_AUTO_ENTRY_EN in the DENALI_CTL_141 register, use the following workaround.                                                                                                                                                                                                                                                                                                 |  |
|                   | Workaround: Ensure that DDR PHY does not enter Deep Sleep low-power state.                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                   | This can be ensured by programming the value of PHY_LP_WAKEUP[3:0] in the<br>DENALI_PHY_1318 register is greater than the values of all the following thresholds in<br>DDR controller registers.                                                                                                                                                                                                                                                            |  |
|                   | LPI_CTRL_IDLE_WAKEUP_FN, LPI_PD_WAKEUP_FN,<br>LPI_SR_SHORT_WAKEUP_FN, LPI_SR_LONG_WAKEUP_FN,<br>LPI_SRPD_SHORT_WAKEUP_FN, LPI_SRPD_LONG_WAKEUP_FN,<br>LPI_SR_LONG_MCCLK_GATE_WAKEUP_FN,<br>LPI_SRPD_LONG_MCCLK_GATE_WAKEUP_FN, and LPI_TIMER_WAKEUP_FN                                                                                                                                                                                                      |  |

| i2166 (continued) | DDR: Entry and exit to/from Deep Sleep low-power state can cause PHY internal<br>clock misalignment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                   | where FN = F0, F1, and F2 for different frequency set points.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| i2177             | RINGACC: The ring accelerator's debug transaction trace stream can be corrupted by certain ring access sequences                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Details:          | The Ring Accelerator allows for hardware assisted debug through direct debugger access<br>of its memory space and by the ability to export a trace stream of its transactions out to<br>the cptracer network. Typically this debug information is enabled, collected and analyzed<br>using a JTAG based debugger which interfaces with the ring accelerator through the SOC<br>debug fabric. An errata exists which can result in a corruption or a hang of the ring debug<br>trace information. This failure can be triggered by normal ring peek operation or if the<br>debugger is used to initiate a ring pop operation. The corruption signature for this errata is<br>a peek wrongly being reported as a pop in the trace. Additionally during non-ring modes<br>(message or credential) a normal ring pop operation can result in incorrect information<br>in the trace's empty filed or a debug pop operation can result in incorrect destination<br>address. |  |  |
| Workaround(s):    | To use the Ring Accelerator's hardware trace features for development, code should avoid using ring peek operations and debugger initiated pop operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| i2182             | DDR: Dual-rank non-power-of-2 density not supported with row-cs-bank-col address mapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Details:          | DDR controller does not support dual-rank non-power-of-2 density LPDDR4 devices with row-cs-bank-col address mapping.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|                   | Please note that the above does not apply to single-rank non-power-of-2 density devices as well as all power-of-2 density devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Workaround(s):    | Use cs-row-bank-col address mapping with dual-rank non-power-of-2 density LPDDR4 devices. To ensure cs-row-bank-col address mapping is selected, the cs_lower_addr_en field in the Cadence controller register must be set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| i2183             | PCIe: Link up failure when unused lanes are not assigned to PCIe Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Details:          | PCIe fails to link up if SERDES lanes not used by PCIe are assigned to another protocol.<br>For example, link training fails if lanes 2 and 3 are assigned to another protocol while<br>lanes 0 and 1 are used for PCIe to form a two lane link. This failure is due to an incorrect<br>tie-off on an internal status signal indicating electrical idle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                   | Status signals going from SERDES to PCIe Controller are tied-off when a lane is not assigned to PCIe. Signal indicating electrical idle is incorrectly tied-off to a state that indicates non-idle. As a result, PCIe sees unused lanes to be out of electrical idle and this causes LTSSM to exit Detect.Quiet state without waiting for 12ms timeout to occur. If a receiver is not detected on the first receiver detection attempt in Detect.Active state, LTSSM goes back to Detect.Quiet and again moves forward to Detect.Active state without waiting for 12ms as required by PCIe base specification. Since wait time in Detect.Quiet is skipped, multiple receiver detect operations are performed back-to-back without allowing time for capacitances on the transmit lines to discharge. This causes subsequent receiver detections to always fail even if a receiver gets connected eventually.                                                          |  |  |
| Workaround(s):    | Enable 2ms minimum wait time for Detect.Quiet state using DQMDC field in<br>PCIE_CORE_LM_I_PL_CONFIG_2_REG register. This will cause LTSSM to wait for a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |



| i2183 (continued) | PCle: Link up failure when unused lanes are not assigned to PCle Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                   | minimum of 2ms in Detect.Quiet state. This allows sufficient time for capacitances on transmit lines to discharge between successive receiver detect operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| i2184             | CPSW: IET express traffic policing issue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| Details:          | This applies to 9-port CPSW, 5-port CPSW, 3-port CPSW, and 2-port CPSW IET traffic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                   | <ul> <li>In IET (Interspersed Express traffic), if a preempted packet was interrupted by an express packet, two things can occur:</li> <li>1. If the express traffic is policed, the frame size for the preempted packets is applied to the express traffic policer. Assuming a policer was set up to rate schedule an express traffic stream, it would take a hit by the preempted packet size it interrupted. The preempted packet also takes on the express traffic policer status. As a result, preempted packets could get dropped along with other express traffic due to the express traffic policer.</li> <li>2. If the express traffic was not policed, the interrupted preempt packet would not get its</li> </ul> |  |  |  |
| Workaround(s):    | Do not police IET express traffic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| i2185             | CPSW: Policer color marking issue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| Details:          | Only applies to CPSW9G and CPSW5G.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                   | When packets from two different ports hit the same policer such that one port has a large packet and the other has a short packet and the short packet arrives just after the large packet starts, the short packet will stop the backlog counting, resulting in potentially flagging the next frame for this policer as yellow when it should have been green. Because the policer is normally set up to not drop yellow, it should not cause an issue. This is only true of packets that arrive on different ports that share the same policer index.                                                                                                                                                                      |  |  |  |
| Workaround(s):    | Ensure policers are unique to ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| i2186             | DDR: LPDDR4 should be configured to 2666 MT/S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| Details:          | LP4-3200 is not supported on pre-production units. Characterization is ongoing to determine the LPDDR4 maximum data rate supported.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| Workaround(s):    | LP4-2666 is recommended for SW development.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| i2187             | MSMC: Cache Resize to 0 Refreshes Tags instead of Updating them                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Details:          | Data corruption (MSMC returning all 0's) occurs upon changing MSMC L3\$ Size from non-zero to zero and back to non-zero for lines that previously had cached dirty data in MSMC's L3\$ (DDR). A 0->N configuration directly after release of MSMC reset is not impacted by this issue.                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|                   | MSMC internal cache resize transactions are always marked as <i>non-allocating</i> misses.<br>Tags are only updated with new values on <i>allocating</i> misses and hits. This results in<br>cache resize operations leaving the tags unchanged, while zeroing out the underlying<br>data.                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                   | Because all existing TAGs remain in MSMC when changing L3 Cache Size but data is<br>zeroed, subsequent reads to these previously cached lines will see all 0's returned for<br>data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |

| i2187 (continued) | MSMC: Cache Resize to 0 Refreshes Tags instead of Updating them                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Workaround(s):    | Reset MSMC after L3 Cache is resized from N to 0 and prior to resizing L3 from 0 to X.<br>This workaround preserves data because the L3 Cache Size N -> 0 transition forces dat<br>into DDR allowing DDR (in self refresh) to contain valid data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| i2189             | OSPI: Controller PHY Tuning Algorithm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Details:          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                   | The OSPI controller uses a DQS signal to sample data when the PHY Module is<br>enabled. However, there is an issue in the module which requires that this sample must<br>occur within a window defined by the internal clock. Read operations are subject to<br>external delays, which change with temperature. In order to guarantee valid reads at any<br>temperature, a special tuning algorithm must be implemented which selects the most<br>robust TX, RX, and Read Delay values.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Workaround(s):    | <ul> <li>The workaround for this bug is described in detail in the application note spract2 (link: https://www.ti.com/lit/spract2). To sample data under some PVT conditions, it is necessar to increment the Read Delay field to shift the internal clock sampling window. This allows sampling of the data anywhere within the data eye. However, this has these side effects:</li> <li>PHY Pipeline mode must be enabled for all read operations. Because PHY Pipeline mode must be disabled for writes, reads and writes must be handled separately.</li> <li>Hardware polling of the busy bit is broken when the workaround is in place, so SW polling must be used instead. Writes must occur through DMA accesses, within page boundaries, to prevent interruption from either the host or the flash device. Software must poll the busy bit between page writes. Alternatively, writes can be performed in non-PHY mode with hardware polling enabled.</li> <li>STIG reads must be padded with extra bytes, and the received data must be right-shifted.</li> </ul> |  |  |
| i2196             | IA: Potential deadlock scenarios in IA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Details:          | The interrupt Aggregator (IA) has one main function, which is to convert events arriving on the Event Transport Lane (ETL) bus, can convert them to interrupt status bits which are used to generate level interrupts. The block that performed this function in IA version 1.0 was called the status event block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                   | In addition to the status event block, there are two other main processing blocks; the multicast event block, and the counted event block. The multicast block really functions as an event splitter. For every event it takes in, it can generate two output events. The counted event block is used to convert high frequency events into a readable count. It counts input events and generates output events on count transitions to/from 0 to/from non-zero count values. Unlike the status event block, the multicast and counted event blocks generate output ETL events that are then mapped to other processing blocks.                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|                   | An issue was found after design that could cause the IA to deadlock. The issue occurs when event "loops" occur between these three processing blocks. It is possible to create a situation where a processing block can not output an event because the path is blocked, and since it can not output an event, it can not take any new input events. This inability to take input events prevents the output path from being able to unwind, and thus both paths remain blocked.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| Workaround(s):    | Figure 3-1 shows the conceptual block diagram of IA 1.0. Potential loops are avoided by adopting the policy of not allowing the counted event block to send events to the multicast block. This method was chosen because it is more common to split an event first, and then count one while sending the other elsewhere. With this path blocked by convention,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |



# i2196 (continued) IA: Potential deadlock scenarios in IA

it is not possible for a single event to visit any block more than once and thus not possible for paths to become blocked so long as the outputs remain unblocked.



Figure 3-1. Interrupt Aggregator Version 1.0

By following the conventions outlined here, the system is safe from looping hazards that can create a deadlock scenario.

| i2197          | I3C: Slave mode is not supported                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Details:       | I3C Slave mode is not available. Only Master role on a single-master bus should be used.                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Workaround(s): | None. Only Master role on a single-master bus should be used.                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| i2201          | MSMC: Incorrect Parity Detect on bytecount                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| Details:       | A signal connection to check the parity of of byte enables for transactions coming from the navigator sub-system to the MSMC is incorrect, this causes false indications of a party error at the boundary of MSMC and throughout the path to DDR. To avoid these false error indications, the entire ECC aggregator must be disabled, which also disables detection of many other (potentially valid) errors and a loss of safety coverage. |  |  |
| Workaround(s): | The COMPUTE_CLUSTER0_MSMC_ECC_AGGR0 must be disabled. There is no direct way to reproduce the diagnostic coverage provided by these mechanisms. High-level system diagnostics may be implemented to mitigate the loss of coverage, but this will be application specific.                                                                                                                                                                   |  |  |
| i2205          | I3C: Command fetched during pending IBI is not properly processed in some cases                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Details:       | Writing command by host during target-initiated IBI address byte reception may lead to improper command execution by controller, including incorrect frame generation.                                                                                                                                                                                                                                                                      |  |  |
| Workaround(s): | Host must disable IBI by sending Broadcast DISEC CCC before sending commands to the controller.                                                                                                                                                                                                                                                                                                                                             |  |  |

| i2207          | CBASS: Command Arbitration Blocking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Details:       | When the interconnect arbitrates commands from multiple sources, the higher priority request always takes precedence. Requests that are at the same priority level are arbitrated in round-robin fashion. The issue is after the higher priority request goes idle and there are two or more pending requests that are at the same priority level, the hardware selects one of them arbitrarily. A potential issue may arise when software polls from multiple sources to the same endpoint: after servicing the higher priority source, the hardware may repeatedly select the same lower priority source for access. That means other same-lower priority requests may be blocked for a long time, and in the worst case if there are dependencies between the polling sequences, the software may run into a livelock state. |  |  |
|                | This issue only affects certain interconnect where in one switch module there are at least<br>three sources that can access the same target simultaneously. Also note that when all<br>requests are at the same priority level, the issue does not apply.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Workaround(s): | When multiple sources are simultaneously polling from the same endpoint, and there is expected dependency based on the read data, ensure that all sources are sending the read commands at the same priority level. The source that breaks the dependency should be at equal or higher priority than other dependent sources.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| i2208          | CPSW: ALE IET Express Packet Drops                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Details:       | This issue impacts the following Module:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                | [J7VCL] 5-port CPSW at 2.5G on ports 2-4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                | The issue with ALE is due to CPSW frequency and IET operation with short express traffic and pre-empted packets that get pre-empted between 60-69 bytes on non-10G capable ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                | If an IET pre-emptible packet get interrupted at 60-69 bytes, the lookup will occur when the next chunk arrives. The CPSW only gives the ALE 64 bytes from the pre-emptible MAC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                | As a result, a short express traffic lookup will start at the end of a 64 byte express traffic, but when the pre-empted queue continues, the pre-empted traffic will complete the 64 bytes and attempt a lookup for the pre-empt packet. But this lookup is less that 64 clocks from the express lookup start, so the express lookup will be aborted(express traffic dropped) and start the new lookup for the pre-empted traffic.                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                | <ul> <li>Rules to induce the issue:</li> <li>You are in IET (Interspersed Express Traffic) mode on ports not capable of 5/10G operation</li> <li>Remote express packets can be preempt packets as low as 60 bytes</li> <li>Pre-empt packet traffic that is 128 bytes or more.</li> <li>Express traffic that interrupts the pre-empt traffic between 60-69 bytes.</li> <li>A short express traffic immediately followed by the continuation of the pre-empt traffic. <ul> <li>a. Gap between express frame and pre-empt frame be its minimum.</li> </ul> </li> <li>The CPSW frequency is at its lowest capability for the speeds required.</li> </ul>                                                                                                                                                                            |  |  |
| Workaround(s): | During IET negotiation, tell the remote to fragment at 128 bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| i2209          | DCC: Incorrect clock selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| Details:       | An incorrect clock hookup on the MCU DCC means that the HFOSC1 clock cannot be selected for comparison. The primary purpose of the DCC on MCU island (run off of HFOSC0) is to compare with the independent clock source provided by HFOSC1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |



| i2209 (continued) | DCC: Incorrect clock selection                                                                                                                                                                                                                                                                 |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Workaround(s):    | Other clock sources for comparison are available (including the internal oscillator) with<br>less accuracy. More attention should be paid to external watchdog mechanisms as well<br>in order to indirectly check that clocks are working as expected by checking for loss of<br>availability. |
| i2216             | I3C: Command execution may fail during slave-initiated IBI address byte reception                                                                                                                                                                                                              |
| Details:          | An SoC host command to the I3C controller may lead to improper command execution by the controller, including incorrect frame generation, if the command was written while a slave-initiated IBI address byte reception is in progress.                                                        |
|                   | In such case, the command response queue is incorrectly filled with responses.<br>Additionally, if received IBI has no payload and is ACKed by Master, then slave fetched<br>command causes incorrect frame issued over bus.                                                                   |
| Workaround(s):    | Host needs to disable IBI by sending Broadcast DISEC CCC before sending commands to the controller.                                                                                                                                                                                            |
| i2217             | Recommended POST selection via MCU_BOOTMODE[09:08]                                                                                                                                                                                                                                             |
| Details:          | The MCU_BOOTMODE[09:08] pins can be used to configure the Power-on-Selftest (POST) mode of operation. The effect of the MCU_BOOTMODE[09:08] depends on the TI factory setting for internal efuse override control. The options defined in the TRM are:                                         |

| Table 4-6. POST Selection |       |                                                                       |
|---------------------------|-------|-----------------------------------------------------------------------|
| POST Config Pins          |       | POST Sequence                                                         |
| MCU 9                     | MCU 8 |                                                                       |
| 0                         | 0     | DMSC LBIST followed by MCU LBIST followed by PBIST <sup>(2)</sup>     |
| 0                         | 1     | DMSC LBIST and MCU LBIST in parallel followed by PBIST <sup>(2)</sup> |
| 1                         | 0     | Reserved <sup>(2)</sup>                                               |
| 1                         | 1     | POST bypass <sup>(1)</sup>                                            |
|                           |       |                                                                       |

The recommended MCU\_BOOTMODE[09:08] settings depends on the Device Type, as summarized in the Workaround section.

The Device Type is identified by the part number Y/Device Type designator, which is described in the SoC Data Manual chapter 10. This is illustrated in the following diagram:



Figure 10-1. Printed Device Reference



## i2217 (continued) Recommended POST selection via MCU\_BOOTMODE[09:08]

Workaround(s):

For Device Type = C, 5, D

- MCU\_BOOTMODE[09:08] pins are "don't care" overridden by efuse ٠
- Factory efuse post\_enable = 1 ٠
  - The SoC will run the POST sequence for "DMSC LBIST and MCU LBIST in parallel followed by PBIST" with a run-time of approximately 20 ms.
- TI recommends MCU\_BOOTMODE[09:08] be set to '01' to ensure compatibility with future devices.

For Device Type = G, 0

MCU\_BOOTMODE[09:08] must be set to '11' for "POST Bypass". •



| i2227      | R5FSS: Error interrupt CCM_COMPARE_STAT_PULSE_INTR incorrectly driven                                                                                                                                                                                                                                                           |  |  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Details    | When modules on the device are functionally disabled/isolated to conserve power, any outputs from the device need to be held to a fixed value to avoid any downstream system issues.                                                                                                                                            |  |  |
|            | Error interrupt CCM_COMPARE_STAT_PULSE_INTR from R5FSS is incorrectly driven to<br>an active high value when the R5FSS is isolated/disabled. This will be recorded as an<br>error occurring in the device if the detection logic is enabled in the Error Signaling Module<br>(ESM). By default the detection logic is disabled. |  |  |
| Workaround | Do not enable ESM detection for this error until the R5FSS module is functionally active.<br>Disable ESM detection for this error before disabling the R5FSS module.                                                                                                                                                            |  |  |
| i2228      | JTAG: TAP used by Debuggers may be inaccessible if TRSTn device pin is never asserted                                                                                                                                                                                                                                           |  |  |
| Details    | If TRSTn is never observed LOW, access to the embedded Debugger scan chains might<br>be blocked by uninitialized logic. JTAG bypass and Boundary Scan functionality is not<br>affected.                                                                                                                                         |  |  |
| Workaround | Prior to connecting a Debugger, ensure that the TRSTn pin is asserted LOW for 100ns and subsequently de-asserted HIGH at-least one time after device power on.                                                                                                                                                                  |  |  |

# i2232DDR: Controller postpones more than allowed refreshes after frequency changeDetailsWhen dynamically switching from a higher to lower clock frequency, the rolling window<br/>counters that control the postponing of refresh commands are not loaded correctly to<br/>scale to the lower clock frequency. This will result in controller postponing more refresh<br/>commands than allowed by the DRAM specification, thus violating refresh requirement for<br/>the DRAM.WorkaroundWorkaround 1:Disable dynamic frequency change by programing DFS\_ENABLE = 0<br/>Workaround 2:If switching frequency, program the register field values based on the<br/>pseudo code listed below.Note that the controller requires AREF\_\*\_THRESHOLD values<br/>to be programmed before triggering initialization. Their values cannot be changed during

| if (old freq/new freq >= 7) {                                                                         |
|-------------------------------------------------------------------------------------------------------|
| if (PBR EN==1) { // Per-bank refresh is enabled                                                       |
| AREF HIGH THRESHOLD = 19                                                                              |
| AREF NORM THRESHOLD = 18                                                                              |
| AREF PBR CONT EN THRESHOLD = 17                                                                       |
| AREF CMD MAX PER TREF = 8                                                                             |
| }                                                                                                     |
| else { // Per-bank refresh is disabled                                                                |
| AREF HIGH THRESHOLD = 18                                                                              |
| AREF NORM THRESHOLD = 17                                                                              |
| // AREF PBR CONT EN THRESHOLD <=== don't care, PBR not enabled                                        |
| AREF CMD MAX PER TREF = 8                                                                             |
| }                                                                                                     |
| }                                                                                                     |
| else {                                                                                                |
| AREF HIGH THRESHOLD = 21                                                                              |
| AREF NORM THRESHOLD //<=== keep AREF NORM THRESHOLD < AREF HIGH THRESHOLD                             |
| AREF CMD MAX PER TREF = 8                                                                             |
| if (PBR EN==1) { // Per-bank refresh is enabled                                                       |
| //keep AREF PBR CONT EN THRESHOLD <aref high="" norm="" td="" threshold<="" threshold<aref=""></aref> |
| AREF_PBR_CONT_EN_THRESHOLD                                                                            |
| }                                                                                                     |
| }                                                                                                     |

mission mode after initialization . Therefore, the value of these parameters must be the lowest of all values needed for every frequency change transition planned to be used.

# i2234 UDMA: TR15 hangs if ICNT0 is less than 64 bytes

**Details** The UDMA always attempts to send the burst size for a transaction. If the actual ICNT0 is less than the minimum burst size of 64 the UDMA will wait for data that is never coming and will hang. If the EOL is set in the TR then the UDMA always sends the data for the last data regardless of the size allowing for the transfer to be sent.

Workaround This can be worked around by setting the EOL to 1 in the TR



| i2235      | CBASS Null Error Interrupt Not Masked By Enable Register                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Details    | There is optional feature in CBASS that adds the null error reporting MMR and interrupt source. When the feature is present and the interrupt is enabled, these two output ports: "err_intr_intr" (level interrupt source) and "err_intr_pls_intr" (pulse interrupt source) will be asserted when an access to a null region occurs. The enable for the interrupt is in the ERR_INTR_ENABLE_SET register (address offset 0x58). |  |  |  |
|            | The issue is CBASS ignores this enable bit, and as a result any null access always produces the interrupt sources/events.                                                                                                                                                                                                                                                                                                       |  |  |  |
| Workaround | There is no spurious event due to this bug because of the default disable status of processor events. At system level, processors don't receive any event unless it's enabled in the associated GIC/VIM interrupt controller.                                                                                                                                                                                                   |  |  |  |
|            | When the interrupt is enabled, and an interrupt does occur, write to the following registers at cbass level to clear it:                                                                                                                                                                                                                                                                                                        |  |  |  |
|            | write 0x1 to the err_intr_enabled_stat register, then write 0x1 to the err_eoi register.                                                                                                                                                                                                                                                                                                                                        |  |  |  |

| i2237      | PCle: SerDes Reference Clock Output does not comply to Vcross, Rise-Fall<br>Matching, and Edge Rate limits                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Details    | The PCIe Reference Clock Output of the SerDes does not comply with the PCI-SIG specifications for VCROSS and Edge Rate limits. Therefore, some external PCIe components may have an issue receiving and using the Reference Clock. However, the SerDes in this Device family does not have an issue accepting this non-compliant Reference Clock. This means that a link that connects the SerDes in one Device to the SerDes in a second Device will not have an issue when one Device generates the Reference Clock and the other Device receives the Reference Clock. |  |  |  |
| Workaround | Option 1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|            | Add an external circuit to the PCIe Reference Clock SERDES0_REFCLK_P/N Output to<br>bring the signal into electrical compliance.                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|            | <ul> <li>A passive re-biasing circuit can be used to achieve a compliant Vcross level:</li> <li>Use the SerDes internal 50-ohm termination</li> <li>On each leg of the SERDES0_REFCLK_P/N output, use 100nF AC coupling capacitors, followed by a bias network formed by 1k-ohm pull-down resistor and a 3.5k-ohm pull-up resistor toVDDA_1P8_SERDES0</li> <li>Component tolerances should be +/-5% for the resistors and +/-30% for the capacitors</li> </ul>                                                                                                           |  |  |  |
|            | <ul> <li>There are two options to achieve a compliant Edge Rate:</li> <li>An external buffer can be added to the Output SERDES0_REFCLK_P/N signal.<br/>Depending on the buffer chosen, a re-biasing circuit may also be needed to comply with the external buffer input requirements.</li> <li>A reduced channel loss spec of -4dB@4MHz can be followed to achieve compliant Edge Rates.</li> </ul>                                                                                                                                                                      |  |  |  |
|            | Option 2:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |

Use an external clock source to supply the PCIe Reference Clock to both the Root Complex and End Point Devices of the Link.



| i2241      | PCle: The SerDes PCle Reference Clock Output can exceed the 5.0 GT/s Data Rate RMS jitter limit                                                                                                                                      |  |  |  |  |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Details    | When operating the SerDes PCIe Reference Clock in Output mode, the RMS jitter of the clock may exceed the PCIe specification limit for the 5.0 GT/s Data Rate.                                                                       |  |  |  |  |
| Workaround | Option 1:                                                                                                                                                                                                                            |  |  |  |  |
|            | Configure the Reference Clock output in Derived Refclk mode (as opposed to Received Refclk mode) and program the PLL configuration registers as follows:                                                                             |  |  |  |  |
|            | <ul> <li>Set CMN_PDIAG_PLL0_CP_PADJ_M0 = 0x0128 to enable lower jitter operation</li> </ul>                                                                                                                                          |  |  |  |  |
|            | (Note for Devices that support 8.0 GT/s operation: Derived Refclk mode has an associated errata i2242 related to temporary disabling of the Refclk while changing Data Rates to/from 8.0 GT/s in a Single PLL SerDes Configuration). |  |  |  |  |
|            | Option 2:                                                                                                                                                                                                                            |  |  |  |  |
|            | Do not operate the PCIe interface at the 5.0 GT/s Data Rate.                                                                                                                                                                         |  |  |  |  |
|            | Option 3:                                                                                                                                                                                                                            |  |  |  |  |
|            | Use an external clock source to supply the PCIe Reference Clock to both the Root<br>Complex and End Point Devices of the Link.                                                                                                       |  |  |  |  |

| i2242      | PCIe: The 4-L SerDes PCIe Reference Clock Output is temporarily disabled while changing Data Rates                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Details    | The 4-L SerDes PCIe Reference Clock Output will be temporarily disabled when changing Data Rates to or from 8.0 GT/s in Derived Refclk mode (as opposed to Received Refclk mode) and using a single SerDes PLL to generate the PCIe TX and RX clocks. This is due to the PLL reprogramming which must be performed when changing the data rate from 2.5 GT/s or 5.0 GT/s to 8.0 GT/s in this mode.                                                                                                             |  |  |
|            | Some external PCIe components that are using the PCIe Reference Clock may not tolerate the disabling of the clock when changing data rates. However, the 2-L and 4-L SerDes in this Device family does not have an issue accepting this Reference Clock behavior. This means that a link that connects the 2-L or 4-L SerDes in one Device to the 2-L or 4-L SerDes in a second Device will not have an issue when one Device generates the Reference Clock and the other Device receives the Reference Clock. |  |  |
| Workaround | Option 1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|            | Configure the 4-L SerDes to use one PLL to generate the clocks for 2.5 GT/s and 5.0 GT/s data rates, and a second PLL to generate the clocks for 8.0 GT/s data rate. This option imposes some limitations:                                                                                                                                                                                                                                                                                                     |  |  |
|            | A) If Internal SSC mode is used, the two PLLs will not spread in sync with each other.<br>This could result in up to 5000ppm difference between frequency of the two PLLs, and<br>therefore between the TX and RX of the link partners. Because of this, Internal SSC mode<br>is not recommended.                                                                                                                                                                                                              |  |  |
|            | B) Protocols used simultaneously with PCIe on different Lanes of the SerDes must be<br>compatible with sharing the PLL configuration of at least one of the two PLLs used for<br>PCIe.                                                                                                                                                                                                                                                                                                                         |  |  |
|            | Option 2:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|            | Use Received Refclk mode. Note that this mode is impacted by the separate Output Refclk jitter errata advisory (i2241)                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|            | Option 3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|            | Do not operate the PCIe interface at the 8.0 GT/s Data Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|            | Option 4:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|            | Use an external clock source to supply the PCIe Reference Clock to both the Root Complex and End Point Devices of the Link.                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |



| i2244      | DDR: Valid stop value must be defined for write DQ VREF training                                                                                                                                                                                                |  |  |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Details    | The DDR PHY uses start, stop, and step-size values for write DQ VREF training. If the stop value is not equal to the start value + a multiple of the step-size, then the final VREF setting can go beyond the maximum VREF range, causing the training to hang. |  |  |
| Workaround | Program the stop value as follows:                                                                                                                                                                                                                              |  |  |
|            | PI_WDQLVL_VREF_INITIAL_STOP = (multiple of<br>PI_WDQLVL_VREF_INITIAL_STEPSIZE) + PI_WDQLVL_VREF_INITIAL_START                                                                                                                                                   |  |  |

| i2245                                                                                                                                                                                               | DMSC: Firewall Region requires specific configuration                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Details The ECC Aggregator inside DMSC (DMSC0_ECC_AGGR) has an endpoint firew is used to protect this region. By default, this firewall blocks all the transactions e from the M3 core inside DMSC. |                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Workaround                                                                                                                                                                                          | If another processor or endpoint needs to access DMSC0_ECC_AGGR region,<br>software shall configure the firewall region with starting address 0x0 and end<br>address 0xFFFF_FFF, using the CBASS_FW_REGION_i_START_ADDRESS and<br>END_ADDRESS registers associated with the DMSC0_ECC_AGGR region. This is the<br>only allowable address configuration for this region. |  |  |  |  |
| i2257                                                                                                                                                                                               | xSPI boot mode redundant image boot failure                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| Details                                                                                                                                                                                             | xSPI boot is not able to boot from redundant image offset at 0x400000 when image at offset 0x0 is corrupted. xSPI boot failure API in the ROM does not handle the header check for xSPI properly.                                                                                                                                                                       |  |  |  |  |
| Workaround                                                                                                                                                                                          | For xSPI 1S mode operation, enable SPI as backup boot mode. Note that this workaro<br>does not apply to xSPI SFDP and 8D modes. No workaround exists for SFDP and 8D<br>modes.                                                                                                                                                                                          |  |  |  |  |
| i2277                                                                                                                                                                                               | POK: De-Glitch (filter) is based upon only two samples                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Details                                                                                                                                                                                             | The POK is sampled on an approximate period of 1.25us. The "near-by" sample history is saved in a circular buffer. The De-Glitch (filter) is designed to AND the last <i>n</i> entries from the sample history in order to generate the output (to the ESM).                                                                                                            |  |  |  |  |
|                                                                                                                                                                                                     | On J7ES (SR1.0, SR1.1), the De-Glitch filter checks only the last entry (0th) and four samples ago (3rd). The filter ANDs these two results (instead of 4) in order to to generate the FAIL output to the ESM.                                                                                                                                                          |  |  |  |  |
|                                                                                                                                                                                                     | On AM64x_SR1.0 and J7VCL_SR1.0, the De-Glitch filter is programmable to {4, 8, 12, 16} samples. The De-Glitch output is based upon a check of only the last entry (0th) and programmed number of samples ago (i.e. 3rd, 7th, 11th, or 15th). The filter ANDs these two results (instead of 4, 8, 12, or 16) in order to to generate the FAIL output to the ESM.         |  |  |  |  |
|                                                                                                                                                                                                     | Notice that when the POK is set to monitor a fixed threshold (UV or OV but not set to ping-pong), the un-checked samples will be used. Using J7ES as an example: On the next sample of the POK, the previously ignored 2nd sample will be incremented to the 3rd place and will therefore be included in the generation of the FAIL output.                             |  |  |  |  |
|                                                                                                                                                                                                     | When the POKs are controlled in a ping-pong manner, the skipped samples will be discarded.                                                                                                                                                                                                                                                                              |  |  |  |  |
| Workaround                                                                                                                                                                                          | There is no workaround.                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                                                                                                                                                                                     | However, the intent of the De-Glitch (filtering) is to insure that a discrete voltage dip or rise does not trigger FAIL. The sampling of two points significantly separated in time means that the voltage dip / rise was not a single isolated event.                                                                                                                  |  |  |  |  |
|                                                                                                                                                                                                     | Since the filter requires all N samples to fail before generating a FAIL signal to the ESM, the inclusion of 2 points instead of N makes this circuit more sensitive.                                                                                                                                                                                                   |  |  |  |  |
| i2278                                                                                                                                                                                               | MCAN: Message Transmit order not guaranteed from dedicated Tx Buffers configured with same Message ID                                                                                                                                                                                                                                                                   |  |  |  |  |
| Details                                                                                                                                                                                             | The erratum is limited to the case when multiple Tx Buffers are configured with the same Message ID (TXBC.NDTB > 1).                                                                                                                                                                                                                                                    |  |  |  |  |



| i2278 (continued) | MCAN: Message Transmit order not guaranteed from dedicated Tx Buffers<br>configured with same Message ID                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                   | <ul> <li>Under the following conditions, a message may be transmitted out of order:</li> <li>Multiple Tx Buffers configured with the same Message ID</li> <li>Tx requests for these Tx Buffers are submitted sequentially with delays between each</li> </ul>                                                                                                                                                                                                                                                                           |  |  |  |
| Workaround        | Workaround #1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                   | After writing the Tx messages with same Message ID to the Message RAM, request transmission of all these message concurrently by single write access to TXBAR. Make sure none of these messages have a pending Tx request before making the concurrent request.                                                                                                                                                                                                                                                                         |  |  |  |
|                   | Workaround #2:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                   | Use the Tx FIFO instead of dedicated Tx Buffers (set bit MCAN_TXBC[30] TFQM = 0 to use Tx FIFO) for the transmission of several messages with the same Message ID in a specific order.                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| i2279             | MCAN: Specification Update for dedicated Tx Buffers and Tx Queues configured with same Message ID                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Details           | The erratum updates the descriptions in Section 3.5.2 Dedicated Tx Buffers and 3.5.4 Tx Queue of the M_CAN User's Manual related to message transmission from multiple dedicated Tx Buffers configured with the same Message ID.                                                                                                                                                                                                                                                                                                        |  |  |  |
| Workaround        | Workaround #1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                   | After writing the Tx messages with same Message ID to the Message RAM, request transmission of all these message concurrently by single write access to TXBAR. Make sure none of these messages have a pending Tx request before making the concurrent request.                                                                                                                                                                                                                                                                         |  |  |  |
|                   | Workaround #2:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                   | Use the Tx FIFO instead of dedicated Tx Buffers (set bit MCAN_TXBC[30] TFQM = 0 to use Tx FIFO) for the transmission of several messages with the same Message ID in a specific order.                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| i2307             | Boot: ROM does not properly select OSPI clocking modes based on BOOTMODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| Details           | The ROM bootloader only selects an internal loopback mode for SPI/QSPI/OSPI/xSPI boot, regardless of the lclk field value selected by the BOOTMODE pins (see the device specific TRM for BOOTMODE pin mappings), which is intended to allow the user to choose an internal or external clocking method. This results in less flexibility in board topology in customers designs. Customers intending to use the external board loopback mode could see timing issues in ROM boot because the external loopback clock is not being used. |  |  |  |
| Workaround        | The topology of the OSPI design must conform to the design guidelines for "No<br>Loopback" mode, which is found in the device specific datasheet, section "Applications,<br>Implementation, and Layout". The guidelines for "External Board Loopback" cannot be<br>used.                                                                                                                                                                                                                                                                |  |  |  |
| i2310             | USART: Erroneous clear/trigger of timeout interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| Details:          | The USART may erroneously clear or trigger the timeout interrupt when RHR/MSR/LSR registers are read.                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |



| 2310 (continued) USART: Erroneous clear/trigger of timeout interrupt |                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Workaround(s):                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|                                                                      | For CPU use-case.                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                                                                      | If the timeout interrupt is erroneously cleared:                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                                                                      | -This is OK since the pending data inside the FIFO will retrigger the timeout interrupt                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                                                                      | If timeout interrupt is erroneously set, and the FIFO is empty, use the following SW workaround to clear the interrupt:                                                                                                                                                                                                                                                                                                     |  |  |  |
|                                                                      | - Set a high value of timeout counter in TIMEOUTH and TIMEOUTL registers                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                                                                      | - Set EFR2 bit 6 to 1 to change timeout mode to periodic                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                                                                      | - Read the IIR register to clear the interrupt                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                                                                      | - Set EFR2 bit 6 back to 0 to change timeout mode back to the original mode                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|                                                                      | For DMA use-case.                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                                                                      | If timeout interrupt is erroneously cleared:                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                                                                      | -This is OK since the next periodic event will retrigger the timeout interrupt                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                                                                      | -User must ensure that RX timeout behavior is in periodic mode by setting EFR2 bit6 to 1                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                                                                      | If timeout interrupt is erroneously set:                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                                                                      | -This will cause DMA to be torn down by the SW driver                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|                                                                      | -OK since next incoming data will cause SW to setup DMA again                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| i2311                                                                | USART Spurious DMA Interrupts                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| Details:                                                             | Spurious DMA interrupts may occur when DMA is used to access TX/RX FIFO with a non-power-of-2 trigger level in the TLR register.                                                                                                                                                                                                                                                                                            |  |  |  |
| Workaround(s):                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|                                                                      | Use power of 2 values for TX/RX FIFO trigger levels (1, 2, 4, 8, 16, and 32).                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| i2320                                                                | UDMA and UDMAP : Descriptors and TRs required to be returned unfragmented                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Details                                                              | The UDMA and UDMAP require that the descriptors and TRs are placed in a memory subsystem that returns the descriptor or TR without any fragmenting of the descriptors. However, there are some memories that contain a fragmentation bridge, which makes them not available for holding the descriptors and TRs.                                                                                                            |  |  |  |
|                                                                      | For this device, the R5 TCM memory cannot hold descriptors or TRs for UDMA or UDMAP                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Workaround                                                           | None                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| i2329                                                                | MDIO: MDIO interface corruption (CPSW and PRU-ICSS)                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Details:                                                             | It is possible that the MDIO interface of all instances of CPSW and PRU-ICSS peripherals (if present) returns corrupt read data on MDIO reads (e.g. returning stale or previous data), or sends incorrect data on MDIO writes. It is also possible that the MDIO interface becomes unavailable until the next peripheral reset (either by LPSC reset or global device reset with reset isolation disabled in case of CPSW). |  |  |  |



# i2329 (continued) MDIO: MDIO interface corruption (CPSW and PRU-ICSS)

Possible system level manifestations of this issue could be (1) erroneous ethernet PHY link down status (2) inability to properly configure an ethernet PHY over MDIO (3) incorrect PHY detection (e.g. wrong address) (4) read or write timeouts when attempting to configure PHY over MDIO.

For boot mode (only CPSW if supported), there is no workaround to guarantee the primary ethernet boot is successful. If this exception occurs during primary boot, the boot may possibly initiate retries which may or may not be successful. If the retries are unsuccessful, this would result in an eventual timeout and transition to the backup boot mode (if one is selected). If no backup boot mode is selected, then such failure will result in a timeout and force device reset via chip watchdog after which the complete boot process will restart again.

To select a backup boot option (if supported), populate the appropriate pull resistors on the boot mode pins. See boot documentation for each specific device options, but the typical timeout for primary boot attempts over ethernet is 60 seconds.

Workaround(s): On affected devices, following workaround should be used:

# MDIO manual mode: applicable for PRU-ICSS and for CPSW.

MDIO protocol can be emulated by reading and writing to the appropriate bits within the MDIO\_MANUAL\_IF\_REG register of the MDIO peripheral to directly manipulate the MDIO clock and data pins. Refer to TRM for full details of manual mode register bits and their function.

In this case the device pin multiplexing should be configured to allow the IO to be controlled by the CPSW or PRU-ICSS peripherals (same as in normal intended operation), but the MDIO state machine must be disabled by ensuring MDIO\_CONTROL\_REG.ENABLE bit is 0 in the MDIO\_CONTROL\_REG and enable manual mode by setting MDIO\_POLL\_REG.MANUALMODE bit to 1.

Contact TI regarding implementation of software workaround.

# Note

If using Ethernet DLR (Device Level Ring) (on CPSW or PRU-ICSS) or EtherCat protocol (on PRU-ICSS) there may be significant CPU or PRU loading impact to implement the run-time workaround 1 due to required polling interval for link status checks. Resulting system impact should be considered.

In case of PRU-ICSS, the loading of the software workaround may be reduced by using the MLINK feature of MDIO to do automatic polling of link status via the MIIx\_RXLINK input pin to PRU-ICSS which must be connected to a status output from the external PHY which does not toggle while the link is active. Depending on the specified behavior of the external PHY device, this PHY status output may be LED\_LINK or LED\_SPEED or the logic OR of LED\_LINK and LED SPEED. Refer to the MDIO section of TRM for details on using the MLINK feature of MDIO. This feature is not available on the CPSW peripheral.

For EtherCAT implementation on PRU-ICSS, the software workaround will be done in RTUx/ TX\_PRUx Core. The core will have to be dedicated for workaround, which means this can't be used for other purpose. The implementation will support two user access channels for MDIO access. This provides option for R5f core and PRU core to have independent access channel. The APIs will be similar to the ones we will have in RTOS Workaround implementation.

EtherCAT will continue to use PHY fast link detection via MDIO MLINK bypassing state m/c for link status (as this path is not affected by errata). This makes sure that cable redundancy related latency requirements are still met.



# i2329 (continued) MDIO: MDIO interface corruption (CPSW and PRU-ICSS)



# Figure 3-2. MDIO Emulation via Manual Mode using PRU Core

| i2360          | Boot: Ethernet RMII Boot Mode is not supported                                                                                 |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|
| Details:       | Ethernet RMII Boot Mode is not supported and should not be used. It will be marked as Reserved in future revisions of the TRM. |  |  |
| Workaround(s): | None. An alternative Boot Mode should be selected.                                                                             |  |  |

i2361 Boot: SPI and xSPI BOOTMODE Pin Mapping changes for SR2.0

**Details:** The SPI and xSPI BOOTMODE pin mappings are changed between silicon revisions SR1.0 and SR2.0 (to align with other J7 Family device bootmode definitions), per the following table:

| Primary Boot<br>Mode B Pin | Primary Boot<br>Mode A Pins | (merge left) | (merge left) | Boot Mode<br>Selected for<br>SR1.0 | Boot Mode<br>Selected for<br>SR2.0 |
|----------------------------|-----------------------------|--------------|--------------|------------------------------------|------------------------------------|
|                            | MCU 5                       | MCU 4        | MCU 3        |                                    |                                    |
| 0                          | 0                           | 1            | 1            | SPI                                | xSPI                               |
| 1                          | 1                           | 1            | 0            | xSPI                               | SPI                                |



i2361 (continued) Boot: SPI and xSPI BOOTMODE Pin Mapping changes for SR2.0

**Workaround(s):** Configure the BOOTMODE pins per the above table to select the desired Boot Mode for each Silicon Revision.



# **Trademarks**

All trademarks are the property of their respective owners.



# **Revision History**

| Changes from April 1, 2022 to September 8, | 2022 (from Revision B | (April 2022) to Revision C |
|--------------------------------------------|-----------------------|----------------------------|
| (September 2022))                          |                       |                            |

| (S | September 2022))                                                                                   | Page  |
|----|----------------------------------------------------------------------------------------------------|-------|
| •  | Added Advisory i2062; RAT: Error Interrupt Triggered Even When Error Logging Disable Is Set        | 6     |
| •  | Updated Description and Workaround for i2227; R5FSS: Error interrupt                               |       |
|    | CCM_COMPARE_STAT_PULSE_INTR incorrectly driven                                                     | 22    |
| •  | Added Advisory i2278; MCAN: Message Transmit order not guaranteed from dedicated Tx Buffers config | jured |
| •  | Added Advisory i2279: MCAN: Specification Update for dedicated Tx Buffers and Tx Queues configured | with  |
|    | same Message ID                                                                                    | 30    |
| •  | Added Advisory i2310; USART: Erroneous clear/trigger of timeout interrupt                          | 30    |
| •  | Added Advisory i2311; USART Spurious DMA Interrupts                                                | 31    |
| •  | Added Advisory i2320: UDMA and UDMAP : Descriptors and TRs required to be returned unfragmented.   | 31    |
| •  | Added Advisory i2329: MDIO: MDIO interface corruption (CPSW and PRU-ICSS)                          | 31    |
| •  | Added Advisory i2360; Boot: Ethernet RMII Boot Mode is not supported                               | 33    |
| •  | Added Advisory i2361; Boot: SPI and xSPI BOOTMODE Pin Mapping changes for SR2.0                    | 33    |

# 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 © 2022, Texas Instruments Incorporated