



Errata sheet

## STM32MP131x/3x/5x device errata

## **Applicability**

This document applies to the part numbers of STM32MP131x/3x/5x devices and the device variants as stated in this page. It gives a summary and a description of the device errata, with respect to the device datasheet and reference manual RM0475. Deviation of the real device behavior from the intended device behavior is considered to be a device limitation. Deviation of the description in the reference manual or the datasheet from the intended device behavior is considered to be a documentation erratum. The term "errata" applies both to limitations and documentation errata.

Table 1. Device summary

| Reference   | Part numbers                                       |
|-------------|----------------------------------------------------|
| STM32MP131x | STM32MP131A, STM32MP131C, STM32MP131D, STM32MP131F |
| STM32MP133x | STM32MP133A, STM32MP133C, STM32MP133D, STM32MP133F |
| STM32MP135x | STM32MP135A, STM32MP135C, STM32MP135D, STM32MP135F |

Table 2. Device variants

| Poforonco   | Silicon revision codes        |                       |
|-------------|-------------------------------|-----------------------|
| Reference   | Device marking <sup>(1)</sup> | REV_ID <sup>(2)</sup> |
| STM32MP13xx | Y                             | 0x1003                |

- 1. Refer to the device datasheet for how to identify this code on different types of package.
- 2. REV\_ID[15:0] bitfield of DBGMCU\_IDC register.



## Summary of device errata

The following table gives a quick reference to the STM32MP131x/3x/5x device limitations and their status:

A = limitation present, workaround available

N = limitation present, no workaround available

P = limitation present, partial workaround available

"-" = limitation absent

Applicability of a workaround may depend on specific conditions of target application. Adoption of a workaround may cause restrictions to target application. Workaround for a limitation is deemed partial if it only reduces the rate of occurrence and/or consequences of the limitation, or if it is fully effective for only a subset of instances on the device or in only a subset of operating modes, of the function concerned.

Table 3. Summary of device limitations

|          |         |                                                                                                                              |           | itus      |
|----------|---------|------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|
| Function | Section | Limitation                                                                                                                   | Rev.<br>Z | Rev.<br>Y |
|          | 2.1.1   | Memory locations might be accessed speculatively due to instruction fetches when HCR.VM is set                               | А         | А         |
|          | 2.1.2   | Cache maintenance by set/way operations can execute out of order                                                             | Α         | Α         |
| Core     | 2.1.3   | PMU events 0x07, 0x0C, and 0x0E do not increment correctly                                                                   | N         | N         |
|          | 2.1.4   | PMU event counter 0x14 does not increment correctly                                                                          | Α         | Α         |
|          | 2.1.5   | Exception mask bits are cleared when an exception is taken in Hyp mode                                                       | N         | N         |
|          | 2.2.1   | TPIU fails to output sync after the pattern generator is disabled in Normal mode                                             | Α         | Α         |
| System   | 2.2.2   | Incorrect reset of glitch-free kernel clock switch                                                                           | Р         | Р         |
|          | 2.2.3   | SAES, RNG, PKA stuck after first stage bootloader (FSBL) decryption                                                          | Α         | Α         |
|          | 2.2.5   | Active tamper output channel wrongly affects unused tamper input pin                                                         | Р         | Р         |
|          | 2.4.1   | SOFx not asserted when writing into DMAMUX_CFR register                                                                      | N         | N         |
|          | 2.4.2   | OFx not asserted for trigger event coinciding with last DMAMUX request                                                       | N         | N         |
| DMAMUX   | 2.4.3   | OFx not asserted when writing into DMAMUX_RGCFR register                                                                     | N         | N         |
| 2.4.4    | 2.4.4   | Wrong input DMA request routed upon specific DMAMUX_CxCR register write coinciding with synchronization event                | Α         | Α         |
|          | 2.5.1   | NOR flash memory/PSRAM incorrect bus turnaround timing                                                                       | Α         | Α         |
|          | 2.5.2   | Incorrect FMC_CLK clock period when CLKDIV value is changed on-the-fly in Continuous clock mode                              | Α         | Α         |
| FMC      | 2.5.3   | NAND Flash memory IREF/IFEF flags wrongly asserted just after enabling in FMC_IER                                            | Α         | А         |
| FMC      | 2.5.4   | Command sequencer accesses NAND Flash memory device while PBKEN bit is cleared in FMC_PCR                                    | Α         | А         |
|          | 2.5.5   | NAND Flash memory IREF flag wrongly asserted after reset                                                                     | Α         | Α         |
|          | 2.5.6   | NAND ECC corrupted due to insufficient ECCEN low period in between sectors                                                   | Α         | А         |
| OLIADODI | 2.6.1   | Memory-mapped read of last memory byte fails                                                                                 | Р         | Р         |
| QUADSPI  | 2.6.2   | Wrong value inside the QUADSPI_VERR register                                                                                 |           | N         |
| SDMMC    | 2.7.1   | Command response and receive data end bits not checked                                                                       | N         | N         |
| ADC      | 2.8.1   | New context conversion initiated without waiting for trigger when writing new context in ADC_JSQR with JQDIS = 0 and JQM = 0 | А         | Α         |

ES0539 - Rev 6 page 2/45



|                  |        |                                                                                                                                                 |   | Status    |  |
|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------|--|
| Function Section |        | Limitation                                                                                                                                      |   | Rev.<br>Y |  |
|                  | 2.8.2  | Two consecutive context conversions fail when writing new context in ADC_JSQR just after previous context completion with JQDIS = 0 and JQM = 0 | А | А         |  |
| ADC              | 2.8.3  | Unexpected regular conversion when two consecutive injected conversions are performed in Dual interleaved mode                                  | А | Α         |  |
|                  | 2.8.4  | ADC_AWDy_OUT reset by non-guarded channels                                                                                                      | Α | Α         |  |
|                  | 2.8.5  | Injected data stored in the wrong ADC_JDRx registers                                                                                            | Α | Α         |  |
|                  | 2.8.6  | ADC slave data may be shifted in Dual regular simultaneous mode                                                                                 | Α | Α         |  |
| DTS              | 2.9.1  | DTS incorrect operation with LSE as reference clock and PCLK enabled                                                                            | Р | Р         |  |
| DCMIPP           | 2.10.1 | Global interrupt generated only through the common interrupt register                                                                           | Α | Α         |  |
| CRYP             | 2.12.1 | Endianness issue when sharing keys between SAES and CRYP                                                                                        | Р | Р         |  |
|                  | 2.13.1 | One-pulse mode trigger not detected in master-slave reset + trigger configuration                                                               | Р | Р         |  |
|                  | 2.13.2 | Consecutive compare event missed in specific conditions                                                                                         | N | N         |  |
| TIM              | 2.13.3 | Output compare clear not working with external counter reset                                                                                    | Р | Р         |  |
|                  | 2.13.4 | Bidirectional break mode not working with short pulses                                                                                          | N | N         |  |
|                  | 2.13.5 | Unexpected PWM output when using ocref_clr                                                                                                      | N | N         |  |
|                  | 2.14.1 | Device may remain stuck in LPTIM interrupt when entering Stop mode                                                                              | Α | Α         |  |
| LPTIM            | 2.14.2 | Device may remain stuck in LPTIM interrupt when clearing event flag                                                                             | Α | Α         |  |
|                  | 2.14.3 | LPTIM events and PWM output are delayed by one kernel clock cycle                                                                               | Α | Α         |  |
|                  | 2.15.1 | Alarm flag may be repeatedly set when the core is stopped in debug                                                                              | N | N         |  |
| RTC and TAMP     | 2.15.2 | Binary mode: SSR is not reloaded with 0xFFFF FFFF when SSCLR = 1                                                                                | Α | Α         |  |
|                  | 2.16.1 | Wrong data sampling when data setup time (t <sub>SU;DAT</sub> ) is shorter than one I2C kernel clock period                                     | Р | Р         |  |
|                  | 2.16.2 | Spurious bus error detection in controller mode                                                                                                 | Α | Α         |  |
| I2C              | 2.16.3 | OVR flag not set in underrun condition                                                                                                          | N | N         |  |
| 2.16.4           |        | Transmission stalled after first byte transfer                                                                                                  | Α | Α         |  |
|                  | 2.16.5 | SDA held low upon SMBus timeout expiry in target mode                                                                                           | Α | Α         |  |
|                  | 2.17.1 | Anticipated end-of-transmission signaling in SPI slave mode                                                                                     | Α | Α         |  |
|                  | 2.17.2 | Data corruption due to noisy receive line                                                                                                       | Α | Α         |  |
| USART            | 2.17.3 | Received data may be corrupted upon clearing the ABREN bit                                                                                      | Α | Α         |  |
|                  | 2.17.4 | Noise error flag set while ONEBIT is set                                                                                                        | N | N         |  |
| LPUART           | 2.18.1 | Possible LPUART transmitter issue when using low BRR[15:0] value                                                                                | Р | Р         |  |
|                  | 2.19.1 | Master data transfer stall at system clock much faster than SCK                                                                                 | Α | Α         |  |
|                  | 2.19.2 | Corrupted CRC return at non-zero UDRDET setting                                                                                                 | Р | Р         |  |
| SPI              | 2.19.3 | TXP interrupt occurring while SPI disabled                                                                                                      | Α | Α         |  |
|                  | 2.19.4 | Possible corruption of last-received data depending on CRCSIZE setting                                                                          | Α | Α         |  |
|                  | 2.19.5 | Truncation of SPI output signals after EOT event                                                                                                | Α | Α         |  |
|                  | 2.20.1 | Desynchronization under specific condition with edge filtering enabled                                                                          | Α | Α         |  |
| FDCAN            | 2.20.2 | Tx FIFO messages inverted under specific buffer usage and priority setting                                                                      | А | Α         |  |
|                  | 2.20.3 | DAR mode transmission failure due to lost arbitration                                                                                           | Α | Α         |  |

ES0539 - Rev 6 page 3/45



|            |                                                                                      | Limitation                                                                                                             |   | itus      |
|------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|---|-----------|
| Function   | Section                                                                              |                                                                                                                        |   | Rev.<br>Y |
| OTG_HS     | 2.21.1                                                                               | Host packet transmission may hang when connecting the full speed interface through a hub to a low-speed device         | N | N         |
|            | 2.22.1                                                                               | Incorrect L4 inverse filtering results for corrupted packets                                                           | N | N         |
|            | 2.22.2                                                                               | Rx DMA may fail to recover upon DMA restart following a bus error, with Rx timestamping enabled                        | Α | Α         |
|            | 2.22.3                                                                               | Spurious receive watchdog timeout interrupt                                                                            | Α | Α         |
|            | 2.22.4                                                                               | Incorrect flexible PPS output interval under specific conditions                                                       | Α | Α         |
|            | 2.22.5                                                                               | Packets dropped in RMII 10 Mbps mode due to fake dribble and CRC error                                                 | Α | Α         |
|            | 2.22.6                                                                               | ARP offload function not effective                                                                                     | Α | Α         |
|            | 2.22.7                                                                               | Spurious checksum error upon MTL pending Tx queue flush                                                                | N | N         |
| ETH 2.22.8 | Bus error coinciding with start-of-packet corrupts MAC-generated packet transmission | N                                                                                                                      | N |           |
|            | 2.22.9                                                                               | DMA spurious state upon AXI DMA slave bus error                                                                        | Р | Р         |
|            | 2.22.10                                                                              | Incorrect DMA transfer state in TEB[2:0] and REB[2:0] on bus error                                                     | Α | Α         |
|            | 2.22.11                                                                              | MAC fails to identify PTP SYNC and Follow_Up messages with peer delay reserved multicast address in 802.1AS mixed mode | Α | Α         |
|            | 2.22.12                                                                              | Fatal bus error interrupt not generated when the descriptor posted write is enabled                                    | Α | А         |
|            | 2.22.13                                                                              | Flexible PPS output incorrectly generated on target time error and subnanosecond not supported in binary rollover mode | Α | Α         |
|            | 2.22.14                                                                              | Incorrect handling of application bus error in certain boundary conditions                                             | N | N         |

The following table gives a quick reference to the documentation errata.

Table 4. Summary of device documentation errata

| Function | Section | Documentation erratum                                                                                                     |
|----------|---------|---------------------------------------------------------------------------------------------------------------------------|
|          | 2.2.4   | Boot issue when PDR_ON pin is set to VSS                                                                                  |
| System   | 2.2.6   | Additional NWAIT timing delay on synchronous access                                                                       |
| System   | 2.2.7   | fmc_ker_ck max frequency limit on synchronous access                                                                      |
| 2.2.8    |         | TIM2_CH1 and TIM2_ETR assigned to wrong GPIOs                                                                             |
| DMA      | 2.3.1   | USART/UART/LPUART DMA transfer abort                                                                                      |
| FMC      | 2.5.7   | Wrong value for t <sub>d(CLKL-ADV)</sub> max value in timing tables                                                       |
| SAES     | 2.11.1  | Data transfer from TAMP_BKPxR to key registers must be done only in ascending order when KEYSEL[2:0] is set to 010 or 100 |

ES0539 - Rev 6 page 4/45



## 2 Description of device errata

The following sections describe the errata of the applicable devices with Arm<sup>®</sup> core and provide workarounds if available. They are grouped by device functions.

Note: Arm is a registered trademark of Arm Limited (or its subsidiaries) in the US and/or elsewhere.

arm

## **2.1** Core

Reference manual and errata notice for the Arm<sup>®</sup> Cortex<sup>®</sup>-A7 core revision r0p5-REVIDR=0x01 is available from http://infocenter.arm.com. Only applicable information from the Arm errata notice is replicated in this document.

## 2.1.1 Memory locations might be accessed speculatively due to instruction fetches when HCR.VM is

This limitation is registered under Arm ID number 844169 and classified into "Category B". Its impact to the device is minor.

#### **Description**

The ARMv7 architecture requires that when all associated stages of translation are disabled for the current privilege level, memory locations are only accessed due to instruction fetches within the same or next 4 KB region as an instruction which has been or is going to be fetched due to sequential execution. In the conditions detailed below, the Cortex-A7 processor might access other locations speculatively due to instruction fetches.

The unwanted speculative instruction fetches may occur when the following conditions are all met:

- 1. The processor must be executing at PL2 or Secure PL1.
- Address translation is disabled for the current exception level (by clearing the appropriate SCTLR.M or HSCTLR.M bit).
- 3. The HCR.VM bit is set.

As the HCR.VM is reset low, this issue does not manifest during boot code.

## Workaround

This issue is most likely to arise in powerdown code, if PL2 or secure PL1 software disables address translation before the core is powered down.

To work around this erratum, software should ensure that HCR.VM is cleared before disabling address translation at PL2 or Secure PL1.

## 2.1.2 Cache maintenance by set/way operations can execute out of order

This limitation is registered under Arm ID number 814220 and classified into "Category B". Its impact to the device is limited.

## **Description**

The ARM v7 architecture states that all cache and branch predictor maintenance operations that do not specify an address execute in program order, relative to each other. However, because of this erratum, an L2 set/way cache maintenance operation can overtake an L1 set/way cache maintenance operation.

Code that intends to clean dirty data from L1 to L2 and then from L2 to L3 using set/way operations might not behave as expected. The L2 to L3 operation might happen first and result in dirty data remaining in L2 after the L1 to L2 operation has completed.

If dirty data remains in L2 then an external agent, such as a DMA agent, might observe stale data.

If the processor is reset or powered-down while dirty data remains in L2 then the dirty data are lost.

ES0539 - Rev 6 page 5/45



The failure occurs when the following conditions are all met:

- 1. A CPU performs an L1 DCCSW or DCCISW operation.
- The targeted L1 set/way contains dirty data.
- 3. Before the next DSB, the same CPU executes an L2 DCCSW or DCCISW operation while the L1 set/way operation is in progress.
- 4. The targeted L2 set/way is within the group of L2 set/ways that the dirty data from L1 can be allocated to. If the above conditions are met then the L2 set/way operation can take effect before the dirty data from L1 has been written to L2.

Note:

Conditions (3) and (4) are not likely to be met concurrently when performing set/way operations on the entire L1 and L2 caches. This is because cache maintenance code is likely to iterate through sets and ways in a consistent ascending or consistent descending manner across cache levels, and to perform all operations on one cache level before moving on to the next cache level. This means that, for example, cache maintenance operations on L1 set 0 and L2 set 0 are separated by cache maintenance operations for all other sets in the L1 cache. This creates a large window for the cache maintenance operations on L1 set 0 to complete.

#### Workaround

Correct ordering between set/way cache maintenance operations can be forced by executing a DSB before changing cache levels.

#### 2.1.3 PMU events 0x07, 0x0C, and 0x0E do not increment correctly

This limitation is registered under Arm ID number 809719 and classified into "Category C". Its impact to the device is minor.

### **Description**

The Cortex-A7 processor implements version 2 of the Performance Monitor Unit architecture (PMUv2). The PMU can gather statistics on the operation of the processor and memory system during runtime. This event information can be used when debugging or profiling code.

The PMU can be programmed to count architecturally executed stores (event 0x07), software changes of the PC (event 0x0C), and procedure returns (event 0x0E). However, because of this erratum, these events do not fully adhere to the descriptions in the PMUv2 architecture.

As a result of this limitation, the information returned by PMU counters that are programmed to count events 0x07, 0x0C, or 0x0E might be misleading when debugging or profiling code executed on the processor.

The error occurs when the following conditions are met:

#### Fither:

- 1. A PMU counter is enabled and programmed to count event 0x07. That is: instruction architecturally executed, condition code check pass, store.
- 2. A PLDW instruction is executed.

If the above conditions are met, the PMUv2 architecture specifies that the counter for event 0x07 does not increment. However, the counter does increment.

#### Or:

- 1. A PMU counter is enabled and programmed to count event 0x0C. That is: instruction architecturally executed, condition code check pass, software change of the PC.
- 2. An SVC, HVC, or SMC instruction is executed.

If the above conditions are met, the PMUv2 architecture specifies that the counter for event 0x0C increments. However, the counter does not increment.

ES0539 - Rev 6 page 6/45



#### Or:

- 1. A PMU counter is enabled and programmed to count event 0x0E. That is: instruction architecturally executed, condition code check pass, procedure return.
- 2. One of the following instructions is executed:

```
a. MOV PC, LR
```

- b. ThumbEE LDMIA R9!, {?, PC}
- C. ThumbEE LDR PC, [R9], #offset
- d. BX Rm, where Rm != R14
- e. LDM SP, {?, PC}

If the above conditions are met, the PMUv2 architecture specifies that the counter for event 0x0E increments for (a), (b), (c) and does not increment for (d) and (e). However, the counter does not increment for (a), (b), (c) and increments for (d) and (e).

#### Example:

The processor should execute interrupt handler C, and on completion of handler C should execute the handler for B. If the conditions above are met, then this erratum results in the processor erroneously clearing the pending state of interrupt C, and then executing the handler for B twice. The first time the handler for B is executed is at interrupt C's priority level. If interrupt C is pended by a level-based interrupt which is cleared by C's handler then interrupt C is pended again once the handler for B has completed and the handler for C is executed.

As the STM32 interrupt C is level based, then this interrupt eventually becomes re-pending and subsequently be handled.

#### Workaround

None.

### 2.1.4 PMU event counter 0x14 does not increment correctly

This limitation is registered under Arm ID number 805420 and classified into "Category C". Its impact to the device is minor.

## **Description**

The Cortex-A7 MPCore processor implements version 2 of the Performance Monitor Unit architecture (PMUv2). The PMU can gather statistics on the operation of the processor and memory system during runtime. This event information can be used when debugging or profiling code. When a PMU counter is programmed to count L1 instruction cache accesses (event 0x14), the counter should increment on all L1 instruction cache accesses.

This limitation has the following implications:

- 1. If SCR.{AW, FW} is set to 0 then the clearing of corresponding bit CPSR.{A, F} to 0 has no effect. The value of CPSR.{A, F} is ignored.
- 2. A PMU counter is enabled and programmed to count L1 instruction cache accesses (event 0x14).
- 3. Cacheable instruction fetches miss in the L1 instruction cache.

If the above conditions are met, the event counter does not increment.

## Workaround

To obtain a better approximation for the number of L1 instruction cache accesses, enable a second PMU counter and program it to count instruction fetches that cause linefills (event 0x01). Add the value returned by this counter to the value returned by the L1 instruction access counter (event 0x14). The result of the addition is a better indication of the number of L1 instruction cache accesses.

## 2.1.5 Exception mask bits are cleared when an exception is taken in Hyp mode

This limitation is registered under Arm ID number 804069 and classified into "Category C". Its impact to the device is minor.

### **Description**

The Cortex-A7 processor implements the ARM Virtualization Extensions and the ARM Security Extensions. Exceptions can be routed to Monitor mode by setting SCR.{EA, FIQ, IRQ} to 1. Exceptions can be masked by setting corresponding bit CPSR.{A, I, F} to 1.

ES0539 - Rev 6 page 7/45



The ARMv7-A architecture states that an exception taken in Hyp mode does not change the value of the mask bits for exceptions routed to Monitor mode. However, because of this erratum, the corresponding mask bits are cleared to 0.

The error occurs when the following conditions are met:

- 1. One or more exception types are routed to Monitor mode by setting one or more of SCR. (EA, FIQ, IRQ) to 1.
- 2. The corresponding exception types are masked by setting the corresponding CPSR.{A, F, I} bits to 1.
- 3. Any exception is taken in Hyp mode.

If the above conditions are met then the exception mask bit CPSR.{A, F, I} is cleared to 0 for each exception type that meets conditions (1) and (2). The affected mask bits are cleared together regardless of the exception type in condition (3).

The implications of this erratum are:

- If SCR.{AW, FW} is set to 0 then the clearing of corresponding bit CPSR.{A, F} to 0 has no effect. The
  value of CPSR.{A, F} is ignored.
- Otherwise, when CPSR.{A, F, I} is set to 1, Secure code cannot rely on CPSR.{A, F, I} remaining set to 1. An exception that should be masked might be routed to Monitor mode.

The impact of this limitation is considered to be minor as it is expected that the users:

- 1. set SCR.{AW, FW} to 0 when SCR.{EA, FIQ} is set to 1.
- 2. set SCR.IRQ to 0.

#### Workaround

None.

## 2.2 System

#### 2.2.1 TPIU fails to output sync after the pattern generator is disabled in Normal mode

#### Description

The TPIU includes a pattern generator that can be used by external tool to determine the operating behavior of the trace port and timing characteristics. This pattern generator includes a mode that transmits the test pattern for a specified number of cycles, and then reverts to transmitting normal trace data.

When the TPIU is configured to operate in Normal mode (FFCR.EnFCont=0), the synchronization sequence that is required between the test pattern and the trace data is not generated. Synchronization is generated at a later time, as determined by the synchronization counter.

## Conditions:

The following conditions must all occur:

- The TPIU is configured in normal mode, FFCR.EnFCont==0
- The TPIU is configured with the formatter enabled, FFCR.EnFTC==1
- The pattern generator is enabled in timed mode, Current test pattern mode.PTIMEEN==1

#### Implications

The timed mode of the TPIU is intended to permit the TPIU to transition between an initial synchronization sequence using the pattern generator and functional mode without any further programming intervention. If the synchronization sequence is not generated at the end of the test pattern, the trace port analyzer is unlikely to be able to capture the start of the trace stream correctly. Synchronization is correctly inserted based on the value configured in the FSCR, once the specified number of frames of trace data have been output.

## Workaround

Workaround requires software interaction to detect the completion of the test pattern sequence. In addition, any trace data present at the input to the TPIU is lost whilst the pattern generator is active. Any trace data present in the input to the TPIU before the formatter is re-enabled (and synchronization generated) is not de-compressible.

- 1. After enabling the pattern generator, set FFCR.StopOnFl==1 and FFCR.FOnMan==1.
- 2. Poll FFSR. FtStopped until 1 is read
- 3. Set FFCR.EnFTC==1

ES0539 - Rev 6 page 8/45



## 2.2.2 Incorrect reset of glitch-free kernel clock switch

#### **Description**

The activation of NRST (by external signal, internal watchdog or software) may not properly reset the glitch-free clock switches inside the RCC.

As a consequence, the peripheral kernel clock previously used by the application remains selected. If not enabled again (by default or by software), there is no kernel clock present on the related peripheral and the BootROM hangs.

Note:

The USB boot is usually not affected as the application always uses the same clocking scheme depending on the HSE crystal frequency choice. For example, there is no issue for HSE at 24 MHz as hse\_ker\_ck is used for clocking OTG. Other peripherals, such as LPTIM, USART, and I2C, work without care if the previous application clock is enabled again to ensure that the clock switch is not stuck.

#### Workaround

Apply one of the following measures:

- 1. By hardware, ensure that the  $V_{DDCORE}$  and  $V_{DDCPU}$  logic is reset on NRST activation:
  - With STPMIC1
     By default, a power cycle on V<sub>DDCORE</sub> and V<sub>DDCPU</sub> (and V<sub>DD</sub>) occurs upon activating NRST.
    - Without STPMIC1
      Connect the POWER\_CPU\_ON and PWR\_ON signals to the external SMPS enable inputs as illustrated next.



Figure 1. External SMPS connection

Activating NRST then causes the V<sub>DDCPU</sub> and V<sub>DDCORE</sub> supply voltages to cycle.

The drawback is that, the debug logic also being reset, it is not possible to debug the boot chain (TF-A and U-Boot) as any breakpoints set are lost during the power cycle.

ES0539 - Rev 6 page 9/45



#### 2. By software:

- For interfaces required during boot, whether flash memory peripherals (SDMMC1/2, QUADSPI, or FMC) or USART/UART (USART3/6 or UART4/5/7/8), use the same clock as the one used during the BootROM execution:
  - If BOOT[2:0] = 000 or 110 (UART boot), set UARTxxSRC[2:0] to 0 (pclk) or 2 (hsi\_ker\_ck), for all UART instances not disabled via uart\_intances\_disabled bitfield of the BSEC OTP WORD 3.
  - o If BOOT[2:0] = 001 or 111 (QUADSPI boot), set QSPISRC[2:0] to 0 (aclk) or 3 (per\_ck).
  - If BOOT[2:0] = 010 or 101 (SDMMC boot), set SDMMC1SRC[2:0] or SDMMC2SRC[2:0] to 0 (hclk6) or 3 (hsi\_ker\_ck).
- For SD card, the use of HSI (64 MHz) causes raw bandwidth performance penalty as only 32 or 64 MHz could be used instead of respectively 50 MHz (SDR25/DDR50) and 100 MHz (SDR50)
- For eMMC, the use of HSI (64 MHz) causes raw bandwidth performance penalty as only 32 or 64 MHz could be used instead of respectively 52 MHz (SDR/DDR) or over 100 MHz (HS200). Note that hclk6/hclk5/aclk are limited to 200 MHz when hclk6 is used as SDMMC1/SDMMC2 kernel clock
  - If BOOT[2:0] = 011 (FMC boot), set FMCSRC[2:0] to 0 (aclk) or 3 (per\_ck)

## 2.2.3 SAES, RNG, PKA stuck after first stage bootloader (FSBL) decryption

#### Description

When an encrypted first stage bootloader (FSBL) is used, after decryption of the FSBL, the SAES is deactivated which prevents the usage of SAES, RNG or PKA.

#### Workaround

When OpenSTLinux TF-A is used, the enabling of SAES is handled within TF-A.

When an other FSBL is used the SAES clock should be enabled in the customer software, even if SAES is not used, in order to be able to use RNG or PKA.

## 2.2.4 Boot issue when PDR ON pin is set to VSS

#### Description

The PDR\_ON pin is enabling the monitoring of the power supplies.

However, only PDR ON = VDD is usable for functional application.

PDR ON = VSS is reserved for internal ST Microelectronics production tests.

If PDR\_ON = VSS the device does not boot correctly.

## Workaround

Always connect PDR ON to VDD on an application.

#### 2.2.5 Active tamper output channel wrongly affects unused tamper input pin

### **Description**

Only relevant for active tamper mode with shared outputs (TAMPyAM = 1 and ATOSHARE = 1).

Whenever a TAMP\_OUTx pin is selected (using ATOSELy), the pin associated to TAMP\_INx is assigned by the hardware even if tamper input is not enabled (TAMPxE = 0).

This prevents using the regular TAMP\_INx pin as a GPIO or alternate function. The remapped TAMP\_INx pins are not impacted.

Regular and remapped pins are listed in below Table 5 and selected using TAMP\_OR register:

Table 5. Regular and remapped TAMP\_INx pins

| TAMP_INx | Regular pin | Remapped pin |
|----------|-------------|--------------|
| TAMP_IN1 | PF10        | PC13         |

ES0539 - Rev 6 page 10/45



| TAMP_INx | Regular pin | Remapped pin                             |
|----------|-------------|------------------------------------------|
| TAMP_IN2 | PA6         | PI1                                      |
| TAMP_IN3 | PC0         | PI2                                      |
| TAMP_IN4 | PG8         | PI3                                      |
| TAMP_IN5 | PC3         | No remap                                 |
| TAMP_IN6 | PE14        | No remap (but no TAMP_OUT6, so no issue) |
| TAMP_IN7 | PB2         | No remap (but no TAMP_OUT7, so no issue) |
| TAMP_IN8 | PI0         | No remap (but no TAMP_OUT8, so no issue) |

Instead of using the regular pin TAMP\_INx, use the remapped pin TAMP\_INx when it exists.

## 2.2.6 Additional NWAIT timing delay on synchronous access

## **Description**

FMC\_NWAIT input should be active before a specific timing delay (with respect to FMC\_NE falling edge) to be considered by the FMC sequencer for correct wait state(s) insertion above the fixed DATLAT setting. This delay value is missing in the product datasheet.

Synchronous multiplexed and non-multiplexed are both equally affected.

This delay is specified as t<sub>d(NExL-NWAITV)</sub> in the following diagrams with the max value below:

| Symbol                      | Parameter                                     | Min | Max                                         | Unit |
|-----------------------------|-----------------------------------------------|-----|---------------------------------------------|------|
| t <sub>d(NExL-NWAITV)</sub> | FMC_NEx low to<br>FMC_NWAIT valid<br>(x = 02) | -   | ((DATLAT + 2.5) × t <sub>w(CLK)</sub> ) - 4 | ns   |

Note:  $t_{w(CLK)} = FMC\_CLK \ period, \ which \ is \ defined \ by \ R \times T_{fmc\_ker\_ck}, \ with \ R = CLKDIV + 1.$ 

## Workaround

 $t_{d(\text{NExL-NWAITV})}$  max timing should be fulfilled whenever NWAIT is used.

The following figures should be used for released datasheets where the  $t_{d(NExL-NWAITV)}$  is not present.

ES0539 - Rev 6 page 11/45



Figure 2. Synchronous multiplexed NOR/PSRAM read timings



Figure 3. Synchronous multiplexed PSRAM write timings



DT72212V2

page 12/45

ES0539 - Rev 6



Figure 4. Synchronous non-multiplexed NOR/PSRAM read timings





DT72213V2

DT72214V2



#### 2.2.7 fmc ker ck max frequency limit on synchronous access

#### **Description**

On synchronous access, there is internal timing constrains which limit the maximum allowed fmc\_ker\_ck frequency.

Possible risks of internal timing violation are:

- Shifted write data generation when using NWAIT.
- Shifted read data.
- · Shift of wait cycles requested by NWAIT input.

This limitation is not dependent of CLKDIV or DATLAT settings.

#### Workaround

Limit the fmc\_ker\_ck frequency to:

- Conditions: synchronous read or write, NWAIT enabled
  - 2.7 V < VDD < 3.6 V  $\rightarrow$  fmc\_ker\_ck max is 96 MHz (that is, FMC\_CLK max is 48 MHz).
    - 1.71 V < VDD < 2.7 V  $\rightarrow$  fmc\_ker\_ck max is 60 MHz (that is, FMC\_CLK max is 30 MHz).
- Conditions: synchronous read, NWAIT disabled
  - 2.7 V < VDD < 3.6 V  $\rightarrow$  fmc ker ck max is 108 MHz (that is, FMC CLK max is 54 MHz).
  - 1.71 V < VDD < 2.7 V → fmc ker ck max is 68 MHz (that is, FMC CLK max is 34 MHz).</li>
- Conditions: synchronous write, NWAIT disabled
  - 2.7 V < VDD < 3.6 V  $\rightarrow$  fmc\_ker\_ck max is 260 MHz (that is, FMC\_CLK max is 130 MHz). No change from datasheet.
  - 1.71 V < VDD < 2.7 V → fmc\_ker\_ck max is 156 MHz (that is, FMC\_CLK max is 78 MHz).</li>
- Global condition: CLKDIV = 1, DATLAT = 0, 20 pF load, FMC CLK IOSPEEDR = 11

## 2.2.8 TIM2\_CH1 and TIM2\_ETR assigned to wrong GPIOs

#### **Description**

In certain versions of the datasheet, TIM2\_CH1 and TIM2\_ETR are assigned to wrong GPIOs (all those GPIOs include both TIM2\_CH1 and TIM2\_ETR).

The actual implementation is as follows:

- PA0, PA15, PD3, PG8 only TIM2 CH1
- PE2, PF13, PE15 only TIM2 ETR
- PA5 both TIM2\_CH1 and TIM2\_ETR

#### Workaround

None.

## 2.3 DMA

### 2.3.1 USART/UART/LPUART DMA transfer abort

#### **Description**

Some reference manual revisions may unduly present the bit 20 (TRBUFF in the corrected revisions) of the DMA\_SxCR register as reserved, to be kept at reset value (low). This bit must be set to ensure the completion of USART/UART/LPUART DMA transfer when another DMA transfer is requested concurrently. Otherwise, it may occur that the other DMA transfer request is not served and that it leads to aborting the ongoing USART/UART/LPUART DMA transfer.

This is a documentation issue rather than a device limitation.

ES0539 - Rev 6 page 14/45



No application workaround is required if the TRBUFF bit is used as indicated.

#### 2.4 DMAMUX

#### 2.4.1 SOFx not asserted when writing into DMAMUX\_CFR register

#### **Description**

The SOFx flag of the DMAMUX\_CSR status register is not asserted if overrun from another DMAMUX channel occurs when the software writes into the DMAMUX\_CFR register.

This can happen when multiple DMA channels operate in synchronization mode, and when overrun can occur from more than one channel. As the SOFx flag clear requires a write into the DMAMUX\_CFR register (to set the corresponding CSOFx bit), overrun occurring from another DMAMUX channel operating during that write operation fails to raise its corresponding SOFx flag.

#### Workaround

None. Avoid the use of synchronization mode for concurrent DMAMUX channels, if at least two of them potentially generate synchronization overrun.

### 2.4.2 OFx not asserted for trigger event coinciding with last DMAMUX request

#### **Description**

In the DMAMUX request generator, a trigger event detected in a critical instant of the last-generated DMAMUX request being served by the DMA controller does not assert the corresponding trigger overrun flag OFx. The critical instant is the clock cycle at the very end of the trigger overrun condition.

Additionally, upon the following trigger event, one single DMA request is issued by the DMAMUX request generator, regardless of the programmed number of DMA requests to generate.

The failure only occurs if the number of requests to generate is set to more than two (GNBREQ[4:0] > 00001).

## Workaround

Make the trigger period longer than the duration required for serving the programmed number of DMA requests, so as to avoid the trigger overrun condition from occurring on the very last DMA data transfer.

## 2.4.3 OFx not asserted when writing into DMAMUX\_RGCFR register

#### **Description**

The OFx flag of the DMAMUX\_RGSR status register is not asserted if an overrun from another DMAMUX request generator channel occurs when the software writes into the DMAMUX\_RGCFR register. This can happen when multiple DMA channels operate with the DMAMUX request generator, and when an overrun can occur from more than one request generator channel. As the OFx flag clear requires a write into the DMAMUX\_RGCFR register (to set the corresponding COFx bit), an overrun occurring in another DMAMUX channel operating with another request generator channel during that write operation fails to raise the corresponding OFx flag.

## Workaround

None. Avoid the use of request generator mode for concurrent DMAMUX channels, if at least two channels are potentially generating a request generator overrun.

ES0539 - Rev 6 page 15/45



# 2.4.4 Wrong input DMA request routed upon specific DMAMUX\_CxCR register write coinciding with synchronization event

#### **Description**

If a write access into the DMAMUX\_CxCR register having the SE bit at zero and SPOL[1:0] bitfield at a value other than 00:

- sets the SE bit (enables synchronization),
- modifies the values of the DMAREQ\_ID[5:0] and SYNC\_ID[4:0] bitfields, and
- does not modify the SPOL[1:0] bitfield,

and if a synchronization event occurs on the previously selected synchronization input exactly two AHB clock cycles before this DMAMUX\_CxCR write, then the input DMA request selected by the DMAREQ\_ID[5:0] value before that write is routed.

#### Workaround

Ensure that the SPOL[1:0] bitfield is at 00 whenever the SE bit is 0. When enabling synchronization by setting the SE bit, always set the SPOL[1:0] bitfield to a value other than 00 with the same write operation into the DMAMUX\_CxCR register.

### 2.5 FMC

#### 2.5.1 NOR flash memory/PSRAM incorrect bus turnaround timing

#### **Description**

The delays between consecutive device accesses, programmed through the BUSTURN[3:0] bitfield of the FMC BTRx and FMC BWTRx registers, have no effect. Instead systematic delays are applied:

- t<sub>IDI F2</sub>: 2 \* fmc ker ck cycles between accesses to two NOR/PSRAM devices
- t<sub>IDLE1</sub>: 1 \* fmc ker ck cycle between accesses to a NOR/PSRAM and a NAND flash memory

#### Workaround

Extend the bus turnaround delays to satisfy bus turnaround constraints. Three cases need to be considered:

- Two consecutive accesses to non-multiplexed NOR/PSRAM devices: Program t<sub>ADDSET</sub> (NOR/PSRAM address setup phase) as needed (see Figure 6).
- Access to a non-multiplexed NOR/PSRAM followed by an access either to a NOR/PSRAM device with multiplexed A/DQ signals or to a synchronous device:
   Decrease the FMC kernel clock frequency in order to meet the timing constraints (see Figure 7).
- 3. Access to a non-multiplexed NOR/PSRAM followed by an access to a NAND flash memory device Program t<sub>MFMSFT</sub> (NOR/PSRAM address setup phase) as needed (see Figure 8).

ES0539 - Rev 6 page 16/45

Figure 6. Bus turn timing recovery - asynchronous accesses to NOR/PSRAM devices (case 1)



Figure 7. Bus turn timing recovery - access to NOR/PSRAM followed by access to multiplexed A/DQ synchronous device (case 2)



DT69550V1

DT69551\

ES0539 - Rev 6 page 17/45

DT69552V1

Figure 8. Bus turn timing recovery - access to NOR/PSRAM followed by access to NAND Flash device (case 3)



Table 6 gives the internal latencies that are not mentioned in the product datasheets. Refer to the datasheets for more details about the others timing values.

Table 6. Timing parameter description

| Parameter             | Description                                                   | Minimum value                        |
|-----------------------|---------------------------------------------------------------|--------------------------------------|
| t <sub>KCK</sub>      | FMC kernel clock period                                       | See product datasheet                |
| t <sub>IDLE1</sub>    | NEx high to CSy low (switching to a NAND flash memory device) | 1 * t <sub>KCK</sub>                 |
| t <sub>IDLE2</sub>    | NEx high to NEy low (NOR/PSRAM devices)                       | 2 * t <sub>KCK</sub>                 |
| t <sub>ADDSET</sub>   | NOR/PSRAM address setup phase                                 | See Ref. Man.                        |
| t <sub>NADVL</sub>    | Address valid low pulse duration in synchronous mode          | (CLKDIV+1) * t <sub>KCK</sub>        |
| t <sub>AH</sub>       | Address hold in synchronous mode                              | ((CLKDIV+1) * t <sub>KCK</sub> ) / 2 |
| t <sub>DATLAT</sub>   | NOR/PSRAM data latency in synchronous mode                    | See product datasheet                |
| t <sub>MEMx</sub> SET | NAND flash memory address setup phase                         | See product datasheet                |

## 2.5.2 Incorrect FMC\_CLK clock period when CLKDIV value is changed on-the-fly in Continuous clock mode

## **Description**

When the FMC operates in Continuous clock mode (CCLKEN is set in FMC\_BCRx register), a new clock division factor is applied by changing the value of CLKDIV[3:0] in FMC\_CFGR while the FMC is disabled (FMCEN cleared in FMC\_BCRx), there is one FMC\_CLK clock cycle during which the FMC\_CLK period is not as expected: for example the clock low pulse duration matches the previous CLKDIV[3:0] value whereas the clock high pulse duration matches the new CLKDIV[3:0] value.

ES0539 - Rev 6 page 18/45



Use the following sequence:

- 1. Stop the memory traffic for all devices.
- 2. Disable the FMC (refer to the disabling sequence described in the product reference manual).
- 3. Change CCLKEN for 1 to 0 in the FMC BCRx register to stop the clock generation.
- 4. Program the desired CLKDIV[3:0] value in the FMC\_CFGR register.
- 5. Change back CCLKEN from 0 to 1.
- 6. Enable the FMC.

## 2.5.3 NAND Flash memory IREF/IFEF flags wrongly asserted just after enabling in FMC\_IER

#### **Description**

When the application enables interrupt rising edge/falling edge detection (IREE/IFEE set in FMC\_IER register) while the corresponding IREF/IFEF status flag is already set in FMC\_ISR register due to a previous event, then a spurious interrupt is immediately generated, corresponding to an out-of-date event.

#### Workaround

Clear the FMC\_ISR flags before programming FMC\_IER register.

## 2.5.4 Command sequencer accesses NAND Flash memory device while PBKEN bit is cleared in FMC\_PCR

#### Description

When the PBKEN bit is cleared in FMC\_PCR register, the FMC should discard all accesses from the system to an external NAND Flash memory device. However, the command sequencer can access NAND memory devices if it is accidentally enabled by setting CSQSTART bit in FMC\_CSQCR register.

Please note that AXI commands and data are discarded as expected (returning a bus error)

## Workaround

Deactivate the NAND Flash command sequencer to avoid unwanted accesses to NAND Flash memory devices when PBKEN is dynamically cleared during application execution.

## 2.5.5 NAND Flash memory IREF flag wrongly asserted after reset

#### **Description**

The FMC NAND Flash memory Ready/Busy input signal (RNB) is asserted when the FMC is under reset. If RNB remains high when the FMC reset is released., the IREF status flag is set in the FMC status register (FMC\_SR) thus triggering a spurious interrupt.

#### Workaround

Clear the FMC status register (FMC\_SR) after the FMC reset release.

### 2.5.6 NAND ECC corrupted due to insufficient ECCEN low period in between sectors

#### Description

When the FMC processes multiple NAND Flash memory sectors with Hamming ECC computation, the ECCEN bit of the FMC\_PCR register is cleared after the current sector and set back before the next sector. The computed ECC may be corrupted if the ECCEN bit low period in between sectors is too short to be sampled correctly.

#### Workaround

By software, ensure that between sectors, the ECCEN bit remains low for at least 1.5 kernel clock periods.

ES0539 - Rev 6 page 19/45



## 2.5.7 Wrong value for t<sub>d(CLKL-ADV)</sub> max value in timing tables

#### Description

Some datasheet revisions show wrong  $t_{d(CLKL-ADV)}$  maximum value in all timing tables of the section "FMC characteristics". The correct  $t_{d(CLKL-ADV)}$  maximum value is:

- 6 ns in the range 2.7 < VDD < 3.6</li>
- 9.5 ns in the range 1.7 < VDD < 1.9

This is a documentation issue rather than a device limitation.

#### Workaround

None.

### 2.6 QUADSPI

## 2.6.1 Memory-mapped read of last memory byte fails

## **Description**

Regardless of the number of I/O lines used (1, 2 or 4), a memory-mapped read of the last byte of the memory region defined through the FSIZE[4:0] bitfield of the QUADSPI\_DCR register always yields 0x00, whatever the memory byte content is. A repeated attempt to read that last byte causes the AXI bus to stall.

#### Workaround

Apply one of the following measures:

- Avoid reading the last byte of the memory region defined through FSIZE, for example by taking margin in FSIZE bitfield setting.
- If the last byte is read, ignore its value and abort the ongoing process so as to prevent the AXI bus from stalling.
- · For reading the last byte of the memory region defined through FSIZE, use indirect read.

## 2.6.2 Wrong value inside the QUADSPI\_VERR register

## **Description**

The value inside the QUADSPI\_VERR register that is supposed to be 0x42, is wrongly set to 0x41.

## Workaround

None.

## 2.7 SDMMC

## 2.7.1 Command response and receive data end bits not checked

## **Description**

The command response and receive data end bits are not checked by the SDMMC. A reception with only a wrong end bit value is not detected. This does not cause a communication failure since the received command response or data is correct.

#### Workaround

None.

ES0539 - Rev 6 page 20/45



## 2.8 ADC

# 2.8.1 New context conversion initiated without waiting for trigger when writing new context in ADC\_JSQR with JQDIS = 0 and JQM = 0

#### **Description**

Once an injected conversion sequence is complete, the queue is consumed and the context changes according to the new ADC\_JSQR parameters stored in the queue. This new context is applied for the next injected sequence of conversions.

However, the programming of the new context in ADC\_JSQR (change of injected trigger selection and/or trigger polarity) may launch the execution of this context without waiting for the trigger if:

- the queue of context is enabled (JQDIS cleared to 0 in ADC CFGR), and
- the queue is never empty (JQM cleared to 0 in ADC\_CFGR), and
- the injected conversion sequence is complete and no conversion from previous context is ongoing

#### Workaround

Apply one of the following measures:

- Ignore the first conversion.
- Use a queue of context with JQM = 1.
- Use a queue of context with JQM = 0, only change the conversion sequence but never the trigger selection and the polarity.

# 2.8.2 Two consecutive context conversions fail when writing new context in ADC\_JSQR just after previous context completion with JQDIS = 0 and JQM = 0

#### **Description**

When an injected conversion sequence is complete and the queue is consumed, writing a new context in ADC\_JSQR just after the completion of the previous context and with a length longer that the previous context, may cause both contexts to fail. The two contexts are considered as one single context. As an example, if the first context contains element 1 and the second context elements 2 and 3, the first context is consumed followed by elements 2 and 3 and element 1 is not executed.

This issue may happen if:

- the queue of context is enabled (JQDIS cleared to 0 in ADC\_CFGR), and
- the queue is never empty (JQM cleared to 0 in ADC\_CFGR), and
- the length of the new context is longer than the previous one

## Workaround

If possible, synchronize the writing of the new context with the reception of the new trigger.

## 2.8.3 Unexpected regular conversion when two consecutive injected conversions are performed in Dual interleaved mode

## Description

In Dual ADC mode, an unexpected regular conversion may start at the end of the second injected conversion without a regular trigger being received, if the second injected conversion starts exactly at the same time than the end of the first injected conversion. This issue may happen in the following conditions:

- two consecutive injected conversions performed in Interleaved simultaneous mode (DUAL[4:0] of ADC\_CCR = 0b00011), or
- two consecutive injected conversions from master or slave ADC performed in Interleaved mode (DUAL[4:0]of ADC CCR = 0b00111)

ES0539 - Rev 6 page 21/45



- In Interleaved simultaneous injected mode: make sure the time between two injected conversion triggers is longer than the injected conversion time.
- In Interleaved only mode: perform injected conversions from one single ADC (master or slave), making sure the time between two injected triggers is longer than the injected conversion time.

#### 2.8.4 ADC AWDy OUT reset by non-guarded channels

#### Description

ADC\_AWDy\_OUT is set when a guarded conversion of a regular or injected channel is outside the programmed thresholds. It is reset after the end of the next guarded conversion that is inside the programmed thresholds. However, the ADC\_AWDy\_OUT signal is also reset at the end of conversion of non-guarded channels, both regular and injected.

#### Workaround

When ADC\_AWDy\_OUT is enabled, it is recommended to use only the ADC channels that are guarded by a watchdog.

If ADC\_AWDy\_OUT is used with ADC channels that are not guarded by a watchdog, take only ADC\_AWDy\_OUT rising edge into account.

## 2.8.5 Injected data stored in the wrong ADC\_JDRx registers

#### **Description**

When the AHB clock frequency is higher than the ADC clock frequency after the prescaler is applied (ratio > 10), if a JADSTP command is issued to stop the injected conversion (JADSTP bit set to 1 in ADC\_CR register) at the end of an injected conversion, exactly when the data are available, then the injected data are stored in ADC\_JDR1 register instead of ADC\_JDR2/3/4 registers.

#### Workaround

Before setting JADSTP bit, check that the JEOS flag is set in ADC\_ISR register (end of injected channel sequence).

## 2.8.6 ADC slave data may be shifted in Dual regular simultaneous mode

## **Description**

In Dual regular simultaneous mode, ADC slave data may be shifted when all the following conditions are met:

- A read operation is performed by one DMA channel,
- OVRMOD = 0 in ADC\_CFGR register (Overrrun mode enabled).

#### Workaround

Apply one of the following measures:

- Set OVRMOD = 1 in ADC CFGR. This disables ADC DR register FIFO.
- Use two DMA channels to read data: one for slave and one for master.

#### 2.9 DTS

## 2.9.1 DTS incorrect operation with LSE as reference clock and PCLK enabled

## **Description**

The DTS does not operate correctly when LSE is selected as reference clock (the REFCLK\_SEL bit of the DTS\_CFGR1 register set) and the PCLK is enabled.

ES0539 - Rev 6 page 22/45



Only use the DTS with the PCLK selected as reference clock (REFCLK\_SEL cleared).

## 2.10 DCMIPP

## 2.10.1 Global interrupt generated only through the common interrupt register

#### **Description**

The global interrupt controller only triggers interrupts enabled through the common interrupt enable register DCMIPP\_CMIER. It fails to trigger interrupts enabled through dedicated function interrupt registers DCMIPP\_PRIER and DCMIPP\_POIER.

Note: All available DCMIPP interrupt sources can be enabled through the DCMIPP\_CMIER register.

#### Workaround

Do not use the DCMIPP\_PIER and DCMIPP\_POIER dedicated interrupt registers for interrupt enable configuration. Instead, exclusively use the DCMIPP\_CMIER register for that purpose.

## 2.11 SAES

# 2.11.1 Data transfer from TAMP\_BKPxR to key registers must be done only in ascending order when KEYSEL[2:0] is set to 010 or 100

#### **Description**

The KEYSEL[2:0] bitfield of the SAES\_CR register defines the source of the key information to use in the SAES cryptographic core:

- When KEYSEL[2:0] is set to 010, the boot hardware key (BHK), stored in tamper-resistant secure backup registers, is entirely transferred into the key registers upon a secure application performing a single read of all TAMP\_BKPxR registers (x = 0 to 3 for KEYSIZE = 0, x = 0 to 7 for KEYSIZE = 1).
- When KEYSEL[2:0] is set to 100, the XOR combination of DHUK and BHK is entirely transferred into the key registers upon a secure application performing a single read of all TAMP\_BKPxR registers (x = 0 to 3 for KEYSIZE = 0, x = 0 to 7 for KEYSIZE = 1).

Some revisions of the reference manual may wrongly specify that the read operation can be performed either in ascending or descending order, while it must be performed always in **ascending** order.

This is a documentation issue rather than a product limitation.

## Workaround

No application workaround is required, provided that the read operation to the TAMP\_BKPxR registers is always done in ascending order.

## 2.12 CRYP

## 2.12.1 Endianness issue when sharing keys between SAES and CRYP

## **Description**

When a key is encrypted then decrypted by SAES, to be shared with CRYP using a shared key sequence, the application must take care of the key endianness, because the different key endianness formats (little-endian in SAES, big-endian in CRYP) are not properly managed during the transfer between SAES and CRYP.

ES0539 - Rev 6 page 23/45



When the sequences described in the AES key sharing with secure AES coprocessor section of the Cryptographic processor (CRYP) chapter, and in the SAES operation with shared keys section of the Secure AES coprocessor (SAES) chapter are followed, the following measures are recommended:

- Only use in CRYP peripheral a key encrypted to be shared with CRYP.
- If the application implements a key derivation function using SAES, invert the endianness of the key before encrypting it as a key to be shared with CRYP, as described in Table 7.

| Key bits  | SAES key registers<br>(normal/wrap mode) <sup>(1)</sup> | SAES key registers to be shared with CRYP <sup>(2)</sup> | CRYP key registers |
|-----------|---------------------------------------------------------|----------------------------------------------------------|--------------------|
| [255:224] | SAES_KEYR7[31:0]                                        | SAES_KEYR0[31:0]                                         | CRYP_K0LR[31:0]    |
| [223:192] | SAES_KEYR6[31:0]                                        | SAES_KEYR1[31:0]                                         | CRYP_K0RR[31:0]    |
| [191:160] | SAES_KEYR5[31:0]                                        | SAES_KEYR2[31:0]                                         | CRYP_K1LR[31:0]    |
| [159:128] | SAES_KEYR4[31:0]                                        | SAES_KEYR3[31:0]                                         | CRYP_K1RR[31:0]    |
| [127:96]  | SAES_KEYR3[31:0]                                        | SAES_KEYR4[31:0]                                         | CRYP_K2LR[31:0]    |
| [95:64]   | SAES_KEYR2[31:0]                                        | SAES_KEYR5[31:0]                                         | CRYP_K2RR[31:0]    |
| [63:32]   | SAES_KEYR1[31:0]                                        | SAES_KEYR6[31:0]                                         | CRYP_K3LR[31:0]    |
| [31:0]    | SAES_KEYR0[31:0]                                        | SAES_KEYR7[31:0]                                         | CRYP_K3RR[31:0]    |

Table 7. Key endianness in registers

Note: 192-bit keys cannot be shared between SAES and CRYP.

#### 2.13 TIM

## 2.13.1 One-pulse mode trigger not detected in master-slave reset + trigger configuration

## **Description**

The failure occurs when several timers configured in one-pulse mode are cascaded, and the master timer is configured in combined reset + trigger mode with the MSM bit set:

OPM = 1 in TIMx\_CR1, SMS[3:0] = 1000 and MSM = 1 in TIMx\_SMCR.

The MSM delays the reaction of the master timer to the trigger event, so as to have the slave timers cycle-accurately synchronized.

If the trigger arrives when the counter value is equal to the period value set in the TIMx\_ARR register, the one-pulse mode of the master timer does not work and no pulse is generated on the output.

#### Workaround

None. However, unless a cycle-level synchronization is mandatory, it is advised to keep the MSM bit reset, in which case the problem is not present. The MSM = 0 configuration also allows decreasing the timer latency to external trigger events.

## 2.13.2 Consecutive compare event missed in specific conditions

## Description

Every match of the counter (CNT) value with the compare register (CCR) value is expected to trigger a compare event. However, if such matches occur in two consecutive counter clock cycles (as consequence of the CCR value change between the two cycles), the second compare event is missed for the following CCR value changes:

ES0539 - Rev 6 page 24/45

<sup>1.</sup> KMOD[1:0] = 0x0 or 0x1

<sup>2.</sup> KMOD[1:0] = 0x2 (shared key mode)



- <u>in edge-aligned mode</u>, from ARR to 0:
  - first compare event: CNT = CCR = ARR
  - second (missed) compare event: CNT = CCR = 0
- <u>in center-aligned mode while up-counting</u>, from ARR-1 to ARR (possibly a new ARR value if the period is also changed) at the crest (that is, when TIMx\_RCR = 0):
  - first compare event: CNT = CCR = (ARR-1)
  - second (missed) compare event: CNT = CCR = ARR
- in center-aligned mode while down-counting, from 1 to 0 at the valley (that is, when TIMx\_RCR = 0):
  - first compare event: CNT = CCR = 1
  - second (missed) compare event: CNT = CCR = 0

The timer output operates as expected in modes other than the toggle mode.

This typically corresponds to an abrupt change of compare value aiming at creating a timer clock single-cycle-wide pulse in toggle mode.

As a consequence:

- In toggle mode, the output only toggles once per counter period (squared waveform), whereas it is
  expected to toggle twice within two consecutive counter cycles (and so exhibit a short pulse per counter
  period).
- In center mode, the compare interrupt flag does note rise and the interrupt is not generated.

Note:

#### Workaround

None

## 2.13.3 Output compare clear not working with external counter reset

#### **Description**

The output compare clear event (ocref\_clr) is not correctly generated when the timer is configured in the following slave modes: Reset mode, Combined reset + trigger mode, and Combined gated + reset mode.

The PWM output remains inactive during one extra PWM cycle if the following sequence occurs:

- 1. The output is cleared by the ocref\_clr event.
- 2. The timer reset occurs before the programmed compare event.

#### Workaround

Apply one of the following measures:

- Use BKIN (or BKIN2 if available) input for clearing the output, selecting the Automatic output enable mode (AOE = 1).
- Mask the timer reset during the PWM ON time to prevent it from occurring before the compare event (for
  example with a spare timer compare channel open-drain output connected with the reset signal, pulling the
  timer reset line down).

### 2.13.4 Bidirectional break mode not working with short pulses

## **Description**

The TIM\_BKIN and TIM\_BKIN2 I/Os can be configured in bidirectional mode using the BKBID and BK2BID bits in the TIMx\_BDTR register, to be forced to 0 when a break/break2 event occurs. The bidirectional break/break2 mode is not functional when the pulse width on break/break2 input is lower than two tim\_ker\_clk periods.

This limitation is also valid when software break events are generated (the break event is correctly generated internally but not reflected on break inputs).

#### Workaround

None.

For applications that can afford some latency in bidirectional break mode, the break interrupt can eventually be enabled, for the CPU to verify the break input state and force it to zero when a break/break2 event occurred.

ES0539 - Rev 6 page 25/45



#### 2.13.5 Unexpected PWM output when using ocref clr

### **Description**

In combined PWM mode 1, asymmetric PWM mode 1, or asymmetric PWM mode 2, using ocref\_clr can cause the tim\_ocxrefc output to be unexpectedly re-enabled or disabled. This behavior depends on the timing of when ocref\_clr is activated and deactivated.

#### Workaround

None.

To prevent this issue, avoid using ocref\_clr in these modes.

#### 2.14 LPTIM

## 2.14.1 Device may remain stuck in LPTIM interrupt when entering Stop mode

#### **Description**

This limitation occurs when disabling the low-power timer (LPTIM).

When the user application clears the ENABLE bit in the LPTIM\_CR register within a small time window around one LPTIM interrupt occurrence, then the LPTIM interrupt signal used to wake up the device from Stop mode may be frozen in active state. Consequently, when trying to enter Stop mode, this limitation prevents the device from entering low-power mode and the firmware remains stuck in the LPTIM interrupt routine.

This limitation applies to all Stop modes and to all instances of the LPTIM. Note that the occurrence of this issue is very low.

#### Workaround

In order to disable a low power timer (LPTIMx) peripheral, do not clear its ENABLE bit in its respective LPTIM\_CR register. Instead, reset the whole LPTIMx peripheral via the RCC controller by setting and resetting its respective LPTIMxRST bit in the relevant RCC register.

## 2.14.2 Device may remain stuck in LPTIM interrupt when clearing event flag

## **Description**

This limitation occurs when the LPTIM is configured in interrupt mode (at least one interrupt is enabled) and the software clears any flag in LPTIM\_ISR register by writing its corresponding bit in LPTIM\_ICR register. If the interrupt status flag corresponding to a disabled interrupt is cleared simultaneously with a new event detection, the set and clear commands might reach the APB domain at the same time, leading to an asynchronous interrupt signal permanently stuck high.

This issue can occur either during an interrupt subroutine execution (where the flag clearing is usually done), or outside an interrupt subroutine.

Consequently, the firmware remains stuck in the LPTIM interrupt routine, and the device cannot enter Stop mode.

#### Workaround

To avoid this issue, it is strongly advised to follow the recommendations listed below:

- Clear the flag only when its corresponding interrupt is enabled in the interrupt enable register.
- If for specific reasons, it is required to clear some flags that have corresponding interrupt lines disabled in the interrupt enable register, it is recommended to clear them during the current subroutine prior to those which have corresponding interrupt line enabled in the interrupt enable register.
- Flags must not be cleared outside the interrupt subroutine.

Note:

The standard clear sequence implemented in the HAL\_LPTIM\_IRQHandler in the STM32Cube is considered as the proper clear sequence.

ES0539 - Rev 6 page 26/45



#### 2.14.3 LPTIM events and PWM output are delayed by one kernel clock cycle

### **Description**

The compare match event (CMPM), auto reload match event (ARRM), PWM output level and interrupts are updated with a delay of one kernel clock cycle.

Consequently, it is not possible to generate PWM with a duty cycle of 0% or 100%.

The following waveform gives the example of PWM output mode and the effect of the delay:

Figure 9. Example of PWM output mode



#### Workaround

Set the compare value to the desired value minus 1. For instance in order to generate a compare match when LPTM CNT = 0x08, set the compare value to 0x07.

#### 2.15 RTC and TAMP

## 2.15.1 Alarm flag may be repeatedly set when the core is stopped in debug

#### Description

When the core is stopped in debug mode, the clock is supplied to subsecond RTC alarm downcounter even when the device is configured to stop the RTC in debug.

As a consequence, when the subsecond counter is used for alarm condition (the MASKSS[3:0] bitfield of the RTC\_ALRMASSR and/or RTC\_ALRMBSSR register set to a non-zero value) and the alarm condition is met just before entering a breakpoint or printf, the ALRAF and/or ALRBF flag of the RTC\_SR register is repeatedly set by hardware during the breakpoint or printf, which makes any attempt to clear the flag(s) ineffective.

## Workaround

None.

## 2.15.2 Binary mode: SSR is not reloaded with 0xFFFF FFFF when SSCLR = 1

## **Description**

When SSCLR bit of the RTC\_ALRMxSSR register is set when in binary mode, SSR is reloaded with 0xFFFF FFFF at the end of the ck\_apre cycle when RTC\_SSR is set to RTC\_ALRxBINR (x stands for either A or B)

RTC\_SSR is not reloaded with 0xFFFF FFFF if RTC\_ALRxBINR is modified while RTC\_SSR is set to RTC\_ALRxBINR. Rather, SSR continues to decrement.

ES0539 - Rev 6 page 27/45



The workarounds are described for alarm A, and can be applied in the same manner for alarm B. Two workarounds are proposed, the second one requires to use the second alarm.

- Wait for one ck apre cycle after an alarm A event before changing the RTC ALRABINR register value.
- Do not reprogram RTC\_ALRABINR following the alarm A event itself. Instead, use alarm B configured with RTC\_ALRABINR set to 0xFFFF FFFF, and reprogram RTC\_ALRABINR after the alarm B event. This ensures that one ck\_apre cycle elapses following the alarm A event.

#### 2.16 I2C

## 2.16.1 Wrong data sampling when data setup time (t<sub>SU:DAT</sub>) is shorter than one I2C kernel clock period

#### **Description**

The I<sup>2</sup>C-bus specification and user manual specify a minimum data setup time (t<sub>SU:DAT</sub>) as:

- 250 ns in Standard mode
- 100 ns in Fast mode
- 50 ns in Fast mode Plus

The device does not correctly sample the  $I^2C$ -bus SDA line when  $t_{SU;DAT}$  is smaller than one I2C kernel clock ( $I^2C$ -bus peripheral clock) period: the previous SDA value is sampled instead of the current one. This can result in a wrong receipt of target address, data byte, or acknowledge bit.

#### Workaround

Increase the I2C kernel clock frequency to get I2C kernel clock period within the transmitter minimum data setup time. Alternatively, increase transmitter's minimum data setup time. If the transmitter setup time minimum value corresponds to the minimum value provided in the I<sup>2</sup>C-bus standard, the minimum I2CCLK frequencies are as follows:

- In Standard mode, if the transmitter minimum setup time is 250 ns, the I2CCLK frequency must be at least 4 MHz.
- In Fast mode, if the transmitter minimum setup time is 100 ns, the I2CCLK frequency must be at least 10 MHz.
- In Fast-mode Plus, if the transmitter minimum setup time is 50 ns, the I2CCLK frequency must be at least 20 MHz.

## 2.16.2 Spurious bus error detection in controller mode

## Description

In controller mode, a bus error can be detected spuriously, with the consequence of setting the BERR flag of the I2C\_SR register and generating bus error interrupt if such interrupt is enabled. Detection of bus error has no effect on the I<sup>2</sup>C-bus transfer in controller mode and any such transfer continues normally.

## Workaround

If a bus error interrupt is generated in controller mode, the BERR flag must be cleared by software. No other action is required and the ongoing transfer can be handled normally.

## 2.16.3 OVR flag not set in underrun condition

## Description

In target transmission with clock stretching disabled (NOSTRETCH = 1 in the I2C\_CR1 register), an underrun condition occurs if the current byte transmission is completed on the I<sup>2</sup>C bus, and the next data is not yet written in the TXDATA[7:0] bitfield. In this condition, the device is expected to set the OVR flag of the I2C\_ISR register and send 0xFF on the bus.

ES0539 - Rev 6 page 28/45



However, if the I2C\_TXDR is written within the interval between two I2C kernel clock cycles before and three APB clock cycles after the start of the next data transmission, the OVR flag is not set, although the transmitted value is 0xFF.

#### Workaround

None.

#### 2.16.4 Transmission stalled after first byte transfer

#### **Description**

When the first byte to transmit is not prepared in the TXDATA register, two bytes are required successively, through TXIS status flag setting or through a DMA request. If the first of the two bytes is written in the I2C\_TXDR register in less than two I2C kernel clock cycles after the TXIS/DMA request, and the ratio between APB clock and I2C kernel clock frequencies is between 1.5 and 3, the second byte written in the I2C\_TXDR is not internally detected. This causes a state in which the I2C peripheral is stalled in controller mode or in target mode, with clock stretching enabled (NOSTRETCH = 0). This state can only be released by disabling the peripheral (PE = 0) or by resetting it.

#### Workaround

Apply one of the following measures:

- Write the first data in I2C\_TXDR before the transmission starts.
- Set the APB clock frequency so that its ratio with respect to the I2C kernel clock frequency is lower than 1.5 or higher than 3.

#### 2.16.5 SDA held low upon SMBus timeout expiry in target mode

## **Description**

For the target mode, the SMBus specification defines  $t_{\text{TIMEOUT}}$  (detect clock low timeout) and  $t_{\text{LOW:SEXT}}$  (cumulative clock low extend time) timeouts. When one of them expires while the I2C peripheral in target mode drives SDA low to acknowledge either its address or a data transmitted by the controller, the device is expected to report such an expiry and release the SDA line.

However, although the device duly reports the timeout expiry, it fails to release SDA. This stalls the  $I^2C$  bus and prevents the controller from generating RESTART or STOP condition.

## Workaround

When a timeout is reported in target mode (TIMEOUT bit of the I2C ISR register is set), apply this sequence:

- 1. Wait until the frame is expected to end.
- 2. Read the STOPF bit of the I2C\_ISR register. If it is low, reset the I2C kernel by clearing the PE bit of the I2C CR1 register.
- 3. Wait for at least three APB clock cycles before enabling again the I2C peripheral.

## **2.17 USART**

#### 2.17.1 Anticipated end-of-transmission signaling in SPI slave mode

#### **Description**

In SPI slave mode, at low USART baud rate with respect to the USART kernel and APB clock frequencies, the *transmission complete* flag TC of the USARTx\_ISR register may unduly be set before the last bit is shifted on the transmit line.

This leads to data corruption if, based on this anticipated end-of-transmission signaling, the application disables the peripheral before the last bit is transmitted.

ES0539 - Rev 6 page 29/45



Upon the TC flag rise, wait until the clock line remains idle for more than the half of the communication clock cycle. Then only consider the transmission as ended.

## 2.17.2 Data corruption due to noisy receive line

#### **Description**

In all modes, except synchronous slave mode, the received data may be corrupted if a glitch to zero shorter than the half-bit occurs on the receive line within the second half of the stop bit.

#### Workaround

Apply one of the following measures:

- Either use a noiseless receive line, or
- add a filter to remove the glitches if the receive line is noisy.

### 2.17.3 Received data may be corrupted upon clearing the ABREN bit

#### **Description**

The USART receiver may miss data or receive corrupted data when the auto baud rate feature is disabled by software (ABREN bit cleared in the USART\_CR2 register) after an auto baud rate detection, while a reception is ongoing.

#### Workaround

Do not clear the ABREN bit.

## 2.17.4 Noise error flag set while ONEBIT is set

#### **Description**

When the ONEBIT bit is set in the USART\_CR3 register (one sample bit method is used), the noise error (NE) flag must remain cleared. Instead, this flag is set upon noise detection on the START bit.

## Workaround

None.

1401

Note:

Having noise on the START bit is contradictory with the fact that the one sample bit method is used in a noise free environment.

#### 2.18 LPUART

## 2.18.1 Possible LPUART transmitter issue when using low BRR[15:0] value

## Description

The LPUART transmitter bit length sequence is not reset between consecutive bytes, which could result in a jitter that cannot be handled by the receiver device. As a result, depending on the receiver device bit sampling sequence, a desynchronization between the LPUART transmitter and the receiver device may occur resulting in data corruption on the receiver side.

This happens when the ratio between the LPUART kernel clock and the baud rate programmed in the LPUART\_BRR register (BRR[15:0]) is not an integer, and is in the three to four range. A typical example is when the 32.768 kHz clock is used as kernel clock and the baud rate is equal to 9600 baud, resulting in a ratio of 3.41.

ES0539 - Rev 6 page 30/45



Apply one of the following measures:

- On the transmitter side, increase the ratio between the LPUART kernel clock and the baud rate. To do so:
  - Increase the LPUART kernel clock frequency, or
  - Decrease the baud rate.
- On the receiver side, generate the baud rate by using a higher frequency and applying oversampling techniques if supported.

### 2.19 SPI

## 2.19.1 Master data transfer stall at system clock much faster than SCK

## **Description**

With the system clock (spi\_pclk) substantially faster than SCK (spi\_ker\_ck divided by a prescaler), SPI master data transfer can stall upon setting the CSTART bit within one SCK cycle after the EOT event (EOT flag raise) signaling the end of the previous transfer.

#### Workaround

Apply one of the following measures:

- Disable then enable SPI after each EOT event.
- Upon EOT event, wait for at least one SCK cycle before setting CSTART.
- Prevent EOT events from occurring, by setting transfer size to undefined (TSIZE = 0) and by triggering transmission exclusively by TXFIFO writes.

## 2.19.2 Corrupted CRC return at non-zero UDRDET setting

## Description

With non-zero setting of UDRDET[1:0] bitfield, the SPI slave can transmit the first bit of CRC pattern corrupted, coming wrongly from the UDRCFG register instead of SPI\_TXCRC. All other CRC bits come from the SPI\_TXCRC register, as expected.

#### Workaround

Keep TXFIFO non-empty at the end of transfer.

## 2.19.3 TXP interrupt occurring while SPI disabled

#### Description

SPI peripheral is set to its default state when disabled (SPE = 0). This flushes the FIFO buffers and resets their occupancy flags. TXP and TXC flags become set (the latter if the TSIZE field contains zero value), triggering interrupt if enabled with TXPIE or EOTIE bit, respectively. The resulting interrupt service can be spurious if it tries to write data into TXFIFO to clear the TXP and TXC flags, while both FIFO buffers are inaccessible (as the peripheral is disabled).

## Workaround

Keep TXP and TXC (the latter if the TSIZE field contains zero value) interrupt disabled whenever the SPI peripheral is disabled.

ES0539 - Rev 6 page 31/45



## 2.19.4 Possible corruption of last-received data depending on CRCSIZE setting

#### **Description**

With the CRC calculation disabled (CRCEN = 0), the transfer size bitfield set to a value greater than zero (TSIZE[15:0] > 0), and the length of CRC frame set to less than 8 bits (CRCSIZE[4:0] < 00111), the last data received in the RxFIFO may be corrupted.

#### Workaround

Keep the CRCSIZE[4:0] bitfield at its default setting (00111) during the data reception if CRCEN = 0 and TSIZE[15:0] > 0.

## 2.19.5 Truncation of SPI output signals after EOT event

#### **Description**

After an EOT event signaling the end of a non-zero transfer size transaction (TSIZE > 0) upon sampling the last data bit, the software may disable the SPI peripheral. As expected, disabling SPI deactivates the SPI outputs (SCK, MOSI and SS when the SPI operates as a master, MISO when as a slave), by making them float or statically output their by-default levels, according to the AFCNTR bit of the SPI\_CFG2 register.

With fast software execution (high PCLK frequency) and slow SPI (low SCK frequency), the SPI disable occurring too fast may result in truncating the SPI output signals. For example, the device operating as a master then generates an asymmetric last SCK pulse (with CPHA = 0), which may prevent the correct last data bit reception by the other node involved in the communication.

#### Workaround

Apply one of the following measures or their combination:

- Add a delay between the EOT event and SPI disable action.
- Decrease the ratio between PCLK and SCK frequencies.

### 2.20 FDCAN

## 2.20.1 Desynchronization under specific condition with edge filtering enabled

#### **Description**

FDCAN may desynchronize and incorrectly receive the first bit of the frame if:

- the edge filtering is enabled (the EFBI bit of the FDCAN CCCR register is set), and
- the end of the integration phase coincides with a falling edge detected on the FDCAN Rx input pin

If this occurs, the CRC detects that the first bit of the received frame is incorrect, flags the received frame as faulty and responds with an error frame.

Note:

This issue does not affect the reception of standard frames.

## Workaround

Disable edge filtering or wait for frame retransmission.

### 2.20.2 Tx FIFO messages inverted under specific buffer usage and priority setting

#### **Description**

Two consecutive messages from the Tx FIFO may be inverted in the transmit sequence if:

- FDCAN uses both a dedicated Tx buffer and a Tx FIFO (the TFQM bit of the FDCAN\_TXBC register is cleared), and
- the messages contained in the Tx buffer have a higher internal CAN priority than the messages in the Tx FIFO.

ES0539 - Rev 6 page 32/45



Apply one of the following measures:

- Ensure that only one Tx FIFO element is pending for transmission at any time:
   The Tx FIFO elements may be filled at any time with messages to be transmitted, but their transmission requests are handled separately. Each time a Tx FIFO transmission has completed and the Tx FIFO gets empty (TFE bit of FDACN\_IR set to 1) the next Tx FIFO element is requested.
- Use only a Tx FIFO: Send both messages from a Tx FIFO, including the message with the higher priority. This message has to wait until the preceding messages in the Tx FIFO have been sent.
- Use two dedicated Tx buffers (for example, use Tx buffer 4 and 5 instead of the Tx FIFO). The following pseudo-code replaces the function in charge of filling the Tx FIFO:

```
Write message to Tx Buffer 4

Transmit Loop:
Request Tx Buffer 4 - write AR4 bit in FDCAN_TXBAR
Write message to Tx Buffer 5
Wait until transmission of Tx Buffer 4 complete (IR bit in FDCAN_IR),
read T04 bit in FDCAN_TXBTO
Request Tx Buffer 5 - write AR5 bit of FDCAN_TXBAR
Write message to Tx Buffer 4
Wait until transmission of Tx Buffer 5 complete (IR bit in FDCAN_IR),
read T05 bit in FDCAN_TXBTO
```

#### 2.20.3 DAR mode transmission failure due to lost arbitration

#### **Description**

In DAR mode, the transmission may fail due to lost arbitration at the first two identifier bits.

#### Workaround

Upon failure, clear the corresponding Tx buffer transmission request bit TRPx of the FDCAN\_TXBRP register and set the corresponding cancellation finished bit CFx of the FDCAN\_TXBCF register, then restart the transmission.

## 2.21 OTG HS

# 2.21.1 Host packet transmission may hang when connecting the full speed interface through a hub to a low-speed device

#### **Description**

When the USB on-the-go high-speed peripheral is used with the full speed interface (DM and DP pins, N.B. not available on all devices), and connects to a low-speed device via a hub, the transmitter internal state machine may hang. This leads, after a timeout expiry, to a port disconnect interrupt.

### Workaround

None. However, increasing the capacitance on the data lines may reduce the occurrence.

## 2.22 ETH

## 2.22.1 Incorrect L4 inverse filtering results for corrupted packets

#### Description

Received corrupted IP packets with payload (for IPv4) or total (IPv6) length of less than two bytes for L4 source port (SP) filtering or less than four bytes for L4 destination port (DP) filtering are expected to cause a mismatch. However, the inverse filtering unduly flags a match and the corrupted packets are forwarded to the software application. The L4 stack gets incomplete packet and drops it.

ES0539 - Rev 6 page 33/45



Note: The perfect filtering correctly reports a mismatch.

#### Workaround

None.

## 2.22.2 Rx DMA may fail to recover upon DMA restart following a bus error, with Rx timestamping enabled

#### Description

When the timestamping of Rx packets is enabled, some or all of the received packets can have Rx timestamp which is written into a descriptor upon the completion of the Rx packet/status transfer.

However, due to a defect, when bus error occurs during the descriptor read (that is subsequently used as context descriptor to update the Rx timestamp), the context descriptor write is skipped by DMA. Also, Rx DMA does not flush the Rx timestamp stored in the intermediate buffers during the error recovery process and enters Stop state. Due to this residual timestamp in the intermediate buffer, Rx DMA, after being restarted, does not transfer packets.

#### Workaround

Issue a software reset to drop all Tx packets and Rx packets present inside the controller at the time of bus error. After the software reset, reconfigure the controller and re-create the descriptors.

Note: The workaround introduces additional latency.

## 2.22.3 Spurious receive watchdog timeout interrupt

#### **Description**

Setting the RWTU[1:0] bitfield of the ETH\_DMACRXIWTR register to a non-zero value while the RWT[7:0] bitfield is at zero leads to a spurious receive watchdog timeout interrupt (if enabled) and, as a consequence, to executing an unnecessary interrupt service routine with no packets to process.

#### Workaround

Ensure that the RWTU[1:0] bitfield is not set to a non-zero value while the RWT[7:0] bitfield is at zero. For setting RWT[7:0] and RWTU[1:0] bitfields each to a non-zero value, perform two successive writes. The first is either a byte-wide write to the byte containing the RWT[7:0] bitfield, or a 32-bit write that only sets the RWT[7:0] bitfield and keeps the RWTU[1:0] bitfield at zero. The second is either a byte-wide write to the RWTU[1:0] bitfield or a 32-bit write that sets the RWTU[1:0] bitfield while keeping the RWT[7:0] bitfield unchanged.

## 2.22.4 Incorrect flexible PPS output interval under specific conditions

#### **Description**

The use of the fine correction method for correcting the IEEE 1588 internal time reference, combined with a large frequency drift of the driving clock from the grandmaster source clock, leads to an incorrect interval of the flexible PPS output used in Pulse train mode. As a consequence, external devices synchronized with the flexible PPS output of the device can go out of synchronization.

## Workaround

Use the coarse method for correcting the IEEE 1588 internal time reference.

ES0539 - Rev 6 page 34/45



Note:

## 2.22.5 Packets dropped in RMII 10 Mbps mode due to fake dribble and CRC error

#### Description

When operating with the RMII interface at 10 Mbps, the Ethernet peripheral may generate a fake extra nibble of data repeating the last packet (nibble) of the data received from the PHY interface. This results in an odd number of nibbles and is flagged as a dribble error. As the RMII only forwards to the system completed bytes of data, the fake nibble would be ignored and the issue would have no consequence. However, as the CRC error is also flagged when this occurs, the error-packet drop mechanism (if enabled) discards the packets.

Real dribble errors are rare. They may result from synchronization issues due to faulty clock recovery.

#### Workaround

When using the RMII 10 MHz mode, disable the error-packet drop mechanism by setting the FEP bit of the ETH\_MTLRXQ0OMR or ETH\_MTLRXQ1OMR register. Accept packets of transactions flagging both dribble and CRC errors.

#### 2.22.6 ARP offload function not effective

#### **Description**

When the Target Protocol Address of a received ARP request packet matches the device IP address set in the ETH\_MACARPAR register, the source MAC address in the SHA field of the ARP request packet is compared with the device MAC address in ETH\_MACA0LR and ETH\_MACA0HR registers (Address0), to filter out ARP packets that are looping back.

Instead, a byte-swapped comparison is performed by the device. As a consequence, the packet is forwarded to the application as a normal packet with no ARP indication in the packet status, and the device does not generate an ARP response.

For example, with the Address0 set to 0x6655 4433 2211:

- If the SHA field of the received ARP packet is 0x6655 4433 2211, the ARP response is generated while it should not
- If the SHA field of the received ARP packet is 0x1122 3344 5566, the ARP response not is generated while
  it should.

#### Workaround

Parse the received frame by software and send the ARP response if the source MAC address matches the byte-swapped Address0.

## 2.22.7 Spurious checksum error upon MTL pending Tx queue flush

## Description

Transmit checksum engine signals packet transmission errors via IHE (IP header error) and PCE (payload checksum error) flags.

When a flush of a pending (not currently served) MTL Tx FIFO queue 0 or 1 is initiated (by setting the FTQ bit of the ETH\_MTLTXQ0OMR or ETH\_MTLTXQ1OMR register, respectively), the MTL sends a dummy Tx status indicating the flushed packets. The checksum engine is expected to ignore this dummy Tx status.

However, when multiple transmit queues with checksum offload engines are enabled and the drop Tx status disabled (DTXSTS = 0 in the ETH\_MTLOMR register), the checksum engine unduly takes into account the dummy Tx status. The MAC Tx status of the packet under transmission then returns zeros in its checksum field, instead of the due value.

The defect is expected to have no impact to the user application as the checksum error flags are intended for

As a consequence, the checksum engine may spuriously signal transmission error for the packet under transmission and for the following packet.

Note:

Workaround

debug purposes only.

None.

ES0539 - Rev 6 page 35/45



## 2.22.8 Bus error coinciding with start-of-packet corrupts MAC-generated packet transmission

#### Description

A bus error coinciding with the start of a new packet unduly aborts the transmission of any internally MAC-generated packet (ARP, PTO, Pause). As a consequence, the packet is sent on the line as a runt frame with corrupted FCS.

The aborted packet is not retransmitted and can cause:

- flow control failure in case of Pause/PFC packet corruption
- delay in ARP handshake from ARP offload engine (the ARP stack recovers because it sends ARP requests periodically)
- delay in PTP response/SYNC packets generated by the PTP offload engine (the PTP stack recovers because it sends request packets periodically)

The occurrence rate of this failure is very low.

#### Workaround

None.

### 2.22.9 DMA spurious state upon AXI DMA slave bus error

### **Description**

Normally, upon an AXI DMA slave bus error, the ETH controller triggers a fatal bus error interrupt (by setting the FBE bit of the ETH\_DMACSR register) and stops the corresponding DMA channel by clearing the ST bit of the ETH\_DMAC0TXCR or ETH\_DMAC1TXCR register. The software can then recreate the list of descriptors and restart the Tx DMA channel (set the ST bit).

However, in the following cases, the DMA controller fails to recover from the bus error or it corrupts the TSO/USO header data:

- when the bus error occurs for a packet transfer initiated by a Tx DMA channel 1 and the OSF bit of the ETH\_DMAC0TXCR or ETH\_DMAC1TXCR register is set
- when the TSO/USO segmentation is enabled in the Tx descriptor

#### Workaround

Reset and reconfigure the ETH controller by software, then re-create the descriptors. This restores the normal DMA controller operation, although it causes the loss of all latent Tx and Rx packets in the ETH controller and adds processing latency.

## 2.22.10 Incorrect DMA transfer state in TEB[2:0] and REB[2:0] on bus error

### **Description**

When a bus error occurs during data transfer or descriptor access from Rx DMA or Tx DMA, the ETH controller updates the transfer state in the REB[2:0] (Rx DMA error) or TEB[2:0] (Tx DMA error) status bitfield of the corresponding DMA channel x status register (ETH DMACxSR)

The software uses the bus error indicated in REB[2:0] or TEB[2:0] to perform diagnostics, tracks the number of bus errors depending on the type of DMA transfer, and takes corrective actions other than a software reset.

However, when the error response to an Rx DMA write data transfer or an Rx or Tx DMA posted descriptor write transfer is received after the DMA state has already changed to another transfer type, the DMA updates the error response status in REB[2:0] or TEB[2:0] for the current transfer type, which is incorrect.

As a consequence, the software may diagnose or track incorrectly and counter-act inappropriately, which leads to frequent bus errors.

This issue has no functional impact because only the DMA transfer state is incorrect.

#### Workaround

Perform diagnostics on the entire system to identify the cause of the bus error. However, this may consume more instruction cycles and impact the software performance.

ES0539 - Rev 6 page 36/45



## 2.22.11 MAC fails to identify PTP SYNC and Follow\_Up messages with peer delay reserved multicast address in 802.1AS mixed mode

#### **Description**

When the AV8021ASMEN bit of the timestamp control register (ETH\_MACTSCR) is set, the MAC operates in the IEEE 802.1AS mixed mode. The delay request response and the peer delay mechanism are both used for PTP time correction. To capture the ingress timestamp, the MAC identifies the PTP SYNC and Follow\_Up messages that contain a PTP peer delay reserved multicast destination address.

The mixed mode can be programmed by any of the following settings in the ETH\_MACTSCR register:

- AV8021ASMEN = 1, SNAPTYPSEL[1:0] = 01 and TSEVNTENA = 0
- AV8021ASMEN = 1, SNAPTYPSEL[1:0] = 01, TSMSTRENA = 0, and TSEVNTENA = 1

However, due to the issue, when the MAC receives the PTP SYNC and Follow\_Up messages with PTP peer delay reserved multicast destination address, it does not identify the packets as PTP packets.

The MAC identifies the received PTP SYNC and Follow\_Up messages only if they contain a PTP primary multicast address.

#### Workaround

If the mixed mode is required, set the TSENALL bit of the ETH\_MACTSCR register to enable the MAC to capture the timestamp for all the received packets. The software must identify the PTP SYNC and Follow\_Up messages and associate the timestamp status provided by the MAC.

## 2.22.12 Fatal bus error interrupt not generated when the descriptor posted write is enabled

#### **Description**

Normally, upon a DMA bus error, the ETH controller triggers a fatal bus error interrupt (by setting the FBE bit of the ETH\_DMACSR register).

However, when the descriptor posted write is enabled (by setting the DSPW bit of the DMA mode register (ETH\_DMAMR)), a write transfer bus error is neither detected nor reported by the ETH controller, and the FBE bit of the ETH\_DMACSR register is not set.

#### Workaround

Do not enable the descriptor posted writes, by keeping the DSPW field of the ETH DMAMR cleared.

# 2.22.13 Flexible PPS output incorrectly generated on target time error and subnanosecond not supported in binary rollover mode

#### **Description**

Normally, the ETH controller reports the target time error and does not generate PPS output when the programmed target time is elapsed.

In addition, when the subnanosecond support is selected, it improves the accuracy of timestamping even in binary rollover mode (TSCTRLSSR bit of timestamp control register (ETH\_MACTSCR) cleared).

However, the following issues can be observed:

- The PPS output is incorrectly generated even when a target time error occurs.
- The subnanosecond accuracy cannot be used in binary rollover mode.

## Workaround

For the first issue, accurately compute the CSR access delays to avoid target time error when programming the target time register.

For the second issue, no workaround is required since the inaccuracies due to not using the subnanosecond in binary rollover mode are not significant.

ES0539 - Rev 6 page 37/45



## 2.22.14 Incorrect handling of application bus error in certain boundary conditions

#### **Description**

Normally, upon a DMA bus error, to ensure that the application can restart and reconfigure the transmit or receive DMA channel without issuing a software reset, the corresponding transmit or receive DMA channel performs the following tasks before transitioning to the stop state:

- 1. Completing the ongoing transmit packet fetching.
- 2. Accepting the pending transmit status.
- 3. Flushing the remaining part of the received packet.
- 4. Generating a fatal bus error interrupt.

However, the ETH controller does not correctly handle the bus error, due to the following issues:

- When the "Operate on Second Packet" mode (OSP) is enabled (by setting the OSF bit of the channel *x* transmit control register ETH\_DMAC*x*TXCR), the write of the previous packet transmit status to the descriptor memory is pending and a bus error occurs on the nonlast descriptor of the current packet. The transmit DMA discards the pending transmit status of these two packets.
- When the bus error occurs on the first data word of the transmit packet, the start of the packet is not indicated in the single dummy word, as expected. As a result, the start and end of packet indication is pushed to the transmit queue.

## As a consequence:

- The STXSTSF and TXSTSFSTS bits of the Tx queue debug register (ETH MTLTXQDR) are not cleared.
- The MAC transmitter does not transmit subsequent packets from any transmit queue.
- As the bus error is neither detected nor reported by the ETH controller, the software is unable to take the required corrective action, which can lead to serious system errors.
- The MTL transmit read controller does not transmit the subsequent packets from any transmit queue.
- The ETH controller requires a software reset to recover, and must be reconfigured.

## Workaround

None.

ES0539 - Rev 6 page 38/45



## Important security notice

The STMicroelectronics group of companies (ST) places a high value on product security, which is why the ST product(s) identified in this documentation may be certified by various security certification bodies and/or may implement our own security measures as set forth herein. However, no level of security certification and/or built-in security measures can guarantee that ST products are resistant to all forms of attacks. As such, it is the responsibility of each of ST's customers to determine if the level of security provided in an ST product meets the customer needs both in relation to the ST product alone, as well as when combined with other components and/or software for the customer end product or application. In particular, take note that:

- ST products may have been certified by one or more security certification bodies, such as Platform Security Architecture (www.psacertified.org) and/or Security Evaluation standard for IoT Platforms (www.trustcb.com). For details concerning whether the ST product(s) referenced herein have received security certification along with the level and current status of such certification, either visit the relevant certification standards website or go to the relevant product page on www.st.com for the most up to date information. As the status and/or level of security certification for an ST product can change from time to time, customers should re-check security certification status/level as needed. If an ST product is not shown to be certified under a particular security standard, customers should not assume it is certified.
- Certification bodies have the right to evaluate, grant and revoke security certification in relation to ST
  products. These certification bodies are therefore independently responsible for granting or revoking
  security certification for an ST product, and ST does not take any responsibility for mistakes, evaluations,
  assessments, testing, or other activity carried out by the certification body with respect to any ST product.
- Industry-based cryptographic algorithms (such as AES, DES, or MD5) and other open standard
  technologies which may be used in conjunction with an ST product are based on standards which were not
  developed by ST. ST does not take responsibility for any flaws in such cryptographic algorithms or open
  technologies or for any methods which have been or may be developed to bypass, decrypt or crack such
  algorithms or technologies.
- While robust security testing may be done, no level of certification can absolutely guarantee protections against all attacks, including, for example, against advanced attacks which have not been tested for, against new or unidentified forms of attack, or against any form of attack when using an ST product outside of its specification or intended use, or in conjunction with other components or software which are used by customer to create their end product or application. ST is not responsible for resistance against such attacks. As such, regardless of the incorporated security features and/or any information or support that may be provided by ST, each customer is solely responsible for determining if the level of attacks tested for meets their needs, both in relation to the ST product alone and when incorporated into a customer end product or application.
- All security features of ST products (inclusive of any hardware, software, documentation, and the like), including but not limited to any enhanced security features added by ST, are provided on an "AS IS" BASIS. AS SUCH, TO THE EXTENT PERMITTED BY APPLICABLE LAW, ST DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, unless the applicable written and signed contract terms specifically provide otherwise.

ES0539 - Rev 6 page 39/45



## **Revision history**

**Table 8. Document revision history** 

| Date        | Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28-Feb-2023 | 1       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16-Jun-2023 | 2       | Added Wrong value inside the QUADSPI_VERR register .  Added Endianness issue when sharing keys between SAES and CRYP .  Added Received data may be corrupted upon clearing the ABREN bit .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16-Nov-2023 | 3       | Updated status column in Table 3. Summary of device limitations .  Updated errata:  LPTIM events and PWM output are delayed by one kernel clock cycle  Data corruption due to noisy receive line  Added errata:  USART/UART/LPUART DMA transfer abort  Global interrupt generated only through the common interrupt register  Endianness issue when sharing keys between SAES and CRYP  Deleted errata:  ADC: Injected queue of context is not available if JQM = 0  ADC: Sampling time shortened in JAUTO auto delayed mode  ADC Load multiple not supported by ADC interface  ADC: Overrun flag might not be set when converted data have not been read before new data are written  I2C: Wakeup frame may not wake up the MCU from Stop mode if the close to I2C kernel clock startup time  USART: USART does not generate DMA requests after setting/clearing DMAT bit |
| 11-Apr-2024 | 4       | Added errata:  Boot issue when PDR_ON pin is set to VSS  Command response and receive data end bits not checked  Incorrect DMA transfer state in TEB[2:0] and REB[2:0] on bus error  MAC fails to identify PTP SYNC and Follow_Up messages with peer delay reserved multicast address in 802.1AS mixed mode  Fatal bus error interrupt not generated when the descriptor posted write is enabled  Flexible PPS output incorrectly generated on target time error and subnanosecond not supported in binary rollover mode  Incorrect handling of application bus error in certain boundary conditions                                                                                                                                                                                                                                                                       |
| 30-Sep-2024 | 5       | Added errata:  Active tamper output channel wrongly affects unused tamper input pin  Additional NWAIT timing delay on synchronous access  fmc_ker_ck max frequency limit on synchronous access  TIM2_CH1 and TIM2_ETR assigned to wrong GPIOs  Possible LPUART transmitter issue when using low BRR[15:0] value  Updated errata:  Additional NWAIT timing delay on synchronous access including all four figures.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 04-Jul-2025 | 6       | Added errata:  Wrong value for t <sub>d(CLKL-ADV)</sub> max value in timing tables  Unexpected PWM output when using ocref_clr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

ES0539 - Rev 6 page 40/45



## **Contents**

| 1 | Sum | mary of  | f device errata                                                                                               | 2      |
|---|-----|----------|---------------------------------------------------------------------------------------------------------------|--------|
| 2 | Des | cription | of device errata                                                                                              | 5      |
|   | 2.1 | Core .   |                                                                                                               | 5      |
|   |     | 2.1.1    | Memory locations might be accessed speculatively due to instruction fetches when HCR.VM is set                | 5      |
|   |     | 2.1.2    | Cache maintenance by set/way operations can execute out of order                                              | 5      |
|   |     | 2.1.3    | PMU events 0x07, 0x0C, and 0x0E do not increment correctly                                                    | 6      |
|   |     | 2.1.4    | PMU event counter 0x14 does not increment correctly                                                           | 7      |
|   |     | 2.1.5    | Exception mask bits are cleared when an exception is taken in Hyp mode                                        | 7      |
|   | 2.2 | System   | 1                                                                                                             | 8      |
|   |     | 2.2.1    | TPIU fails to output sync after the pattern generator is disabled in Normal mode                              | 8      |
|   |     | 2.2.2    | Incorrect reset of glitch-free kernel clock switch                                                            | 9      |
|   |     | 2.2.3    | SAES, RNG, PKA stuck after first stage bootloader (FSBL) decryption                                           | 10     |
|   |     | 2.2.4    | Boot issue when PDR_ON pin is set to VSS                                                                      | 10     |
|   |     | 2.2.5    | Active tamper output channel wrongly affects unused tamper input pin                                          | 10     |
|   |     | 2.2.6    | Additional NWAIT timing delay on synchronous access                                                           | 11     |
|   |     | 2.2.7    | fmc_ker_ck max frequency limit on synchronous access                                                          | 14     |
|   |     | 2.2.8    | TIM2_CH1 and TIM2_ETR assigned to wrong GPIOs                                                                 | 14     |
|   | 2.3 | DMA .    |                                                                                                               | 14     |
|   |     | 2.3.1    | USART/UART/LPUART DMA transfer abort                                                                          | 14     |
|   | 2.4 | DMAM     | UX                                                                                                            | 15     |
|   |     | 2.4.1    | SOFx not asserted when writing into DMAMUX_CFR register                                                       | 15     |
|   |     | 2.4.2    | OFx not asserted for trigger event coinciding with last DMAMUX request                                        | 15     |
|   |     | 2.4.3    | OFx not asserted when writing into DMAMUX_RGCFR register                                                      | 15     |
|   |     | 2.4.4    | Wrong input DMA request routed upon specific DMAMUX_CxCR register write coinciding with synchronization event | 16     |
|   | 2.5 | FMC .    |                                                                                                               | 16     |
|   |     | 2.5.1    | NOR flash memory/PSRAM incorrect bus turnaround timing                                                        | 16     |
|   |     | 2.5.2    | Incorrect FMC_CLK clock period when CLKDIV value is changed on-the-fly in Continuous clock mode               | 18     |
|   |     | 2.5.3    | NAND Flash memory IREF/IFEF flags wrongly asserted just after enabling in FMC_IEF                             | R . 19 |
|   |     | 2.5.4    | Command sequencer accesses NAND Flash memory device while PBKEN bit is cleared in FMC_PCR                     | 19     |
|   |     | 2.5.5    | NAND Flash memory IREF flag wrongly asserted after reset                                                      | 19     |
|   |     | 2.5.6    | NAND ECC corrupted due to insufficient ECCEN low period in between sectors                                    | 19     |
|   |     | 2.5.7    | Wrong value for $t_{d(CLKL-ADV)}$ max value in timing tables                                                  | 20     |
|   | 2.6 | QUADS    | SPI                                                                                                           | 20     |

ES0539 - Rev 6 page 41/45



|      | 2.6.1  | Memory-mapped read of last memory byte fails                                                                                                    | . 20 |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|
|      | 2.6.2  | Wrong value inside the QUADSPI_VERR register                                                                                                    | . 20 |
| 2.7  | SDMM   | C                                                                                                                                               | . 20 |
|      | 2.7.1  | Command response and receive data end bits not checked                                                                                          | . 20 |
| 2.8  | ADC    |                                                                                                                                                 | . 21 |
|      | 2.8.1  | New context conversion initiated without waiting for trigger when writing new context in ADC_JSQR with JQDIS = 0 and JQM = 0                    | . 21 |
|      | 2.8.2  | Two consecutive context conversions fail when writing new context in ADC_JSQR just after previous context completion with JQDIS = 0 and JQM = 0 | . 21 |
|      | 2.8.3  | Unexpected regular conversion when two consecutive injected conversions are performed in Dual interleaved mode                                  | . 21 |
|      | 2.8.4  | ADC_AWDy_OUT reset by non-guarded channels                                                                                                      | . 22 |
|      | 2.8.5  | Injected data stored in the wrong ADC_JDRx registers                                                                                            | . 22 |
|      | 2.8.6  | ADC slave data may be shifted in Dual regular simultaneous mode                                                                                 | . 22 |
| 2.9  | DTS    |                                                                                                                                                 | . 22 |
|      | 2.9.1  | DTS incorrect operation with LSE as reference clock and PCLK enabled                                                                            | . 22 |
| 2.10 | DCMIP  | P                                                                                                                                               | . 23 |
|      | 2.10.1 | Global interrupt generated only through the common interrupt register                                                                           | . 23 |
| 2.11 | SAES . |                                                                                                                                                 | . 23 |
|      | 2.11.1 | Data transfer from TAMP_BKPxR to key registers must be done only in ascending order when KEYSEL[2:0] is set to 010 or 100                       | . 23 |
| 2.12 | CRYP . |                                                                                                                                                 | . 23 |
|      | 2.12.1 | Endianness issue when sharing keys between SAES and CRYP                                                                                        | . 23 |
| 2.13 | TIM    |                                                                                                                                                 | . 24 |
|      | 2.13.1 | One-pulse mode trigger not detected in master-slave reset + trigger configuration                                                               | . 24 |
|      | 2.13.2 | Consecutive compare event missed in specific conditions                                                                                         | . 24 |
|      | 2.13.3 | Output compare clear not working with external counter reset                                                                                    | . 25 |
|      | 2.13.4 | Bidirectional break mode not working with short pulses                                                                                          | . 25 |
|      | 2.13.5 | Unexpected PWM output when using ocref_clr                                                                                                      | . 26 |
| 2.14 | LPTIM2 |                                                                                                                                                 |      |
|      | 2.14.1 | Device may remain stuck in LPTIM interrupt when entering Stop mode                                                                              | . 26 |
|      | 2.14.2 | Device may remain stuck in LPTIM interrupt when clearing event flag                                                                             | . 26 |
|      | 2.14.3 | LPTIM events and PWM output are delayed by one kernel clock cycle                                                                               | . 27 |
| 2.15 | RTC an | nd TAMP                                                                                                                                         | . 27 |
|      | 2.15.1 | Alarm flag may be repeatedly set when the core is stopped in debug                                                                              | . 27 |
|      | 2.15.2 | Binary mode: SSR is not reloaded with 0xFFFF FFFF when SSCLR = 1                                                                                | . 27 |
| 2.16 | I2C    |                                                                                                                                                 | . 28 |
|      | 2.16.1 | Wrong data sampling when data setup time (t <sub>SU;DAT</sub> ) is shorter than one I2C kernel clock period                                     | . 28 |

ES0539 - Rev 6 page 42/45



|      | 2.16.2  | Spurious bus error detection in controller mode                                                                        | . 28 |  |  |
|------|---------|------------------------------------------------------------------------------------------------------------------------|------|--|--|
|      | 2.16.3  | OVR flag not set in underrun condition                                                                                 | . 28 |  |  |
|      | 2.16.4  | Transmission stalled after first byte transfer                                                                         | . 29 |  |  |
|      | 2.16.5  | SDA held low upon SMBus timeout expiry in target mode                                                                  | . 29 |  |  |
| 2.17 | USART   |                                                                                                                        | . 29 |  |  |
|      | 2.17.1  | Anticipated end-of-transmission signaling in SPI slave mode                                                            | . 29 |  |  |
|      | 2.17.2  | Data corruption due to noisy receive line                                                                              | . 30 |  |  |
|      | 2.17.3  | Received data may be corrupted upon clearing the ABREN bit                                                             | . 30 |  |  |
|      | 2.17.4  | Noise error flag set while ONEBIT is set                                                                               | . 30 |  |  |
| 2.18 | LPUART3 |                                                                                                                        |      |  |  |
|      | 2.18.1  | Possible LPUART transmitter issue when using low BRR[15:0] value                                                       | . 30 |  |  |
| 2.19 | SPI     |                                                                                                                        | . 31 |  |  |
|      | 2.19.1  | Master data transfer stall at system clock much faster than SCK                                                        | . 31 |  |  |
|      | 2.19.2  | Corrupted CRC return at non-zero UDRDET setting                                                                        | . 31 |  |  |
|      | 2.19.3  | TXP interrupt occurring while SPI disabled                                                                             | . 31 |  |  |
|      | 2.19.4  | Possible corruption of last-received data depending on CRCSIZE setting                                                 | . 32 |  |  |
|      | 2.19.5  | Truncation of SPI output signals after EOT event                                                                       | . 32 |  |  |
| 2.20 | FDCAN   |                                                                                                                        |      |  |  |
|      | 2.20.1  | Desynchronization under specific condition with edge filtering enabled                                                 | . 32 |  |  |
|      | 2.20.2  | Tx FIFO messages inverted under specific buffer usage and priority setting                                             | . 32 |  |  |
|      | 2.20.3  | DAR mode transmission failure due to lost arbitration                                                                  | . 33 |  |  |
| 2.21 | OTG_H   | S                                                                                                                      | . 33 |  |  |
|      | 2.21.1  | Host packet transmission may hang when connecting the full speed interface through a hub to a low-speed device         | . 33 |  |  |
| 2.22 | ETH     |                                                                                                                        | . 33 |  |  |
|      | 2.22.1  | Incorrect L4 inverse filtering results for corrupted packets                                                           | . 33 |  |  |
|      | 2.22.2  | Rx DMA may fail to recover upon DMA restart following a bus error, with Rx timestamping enabled                        | . 34 |  |  |
|      | 2.22.3  | Spurious receive watchdog timeout interrupt                                                                            | . 34 |  |  |
|      | 2.22.4  | Incorrect flexible PPS output interval under specific conditions                                                       | . 34 |  |  |
|      | 2.22.5  | Packets dropped in RMII 10 Mbps mode due to fake dribble and CRC error                                                 | . 35 |  |  |
|      | 2.22.6  | ARP offload function not effective                                                                                     | . 35 |  |  |
|      | 2.22.7  | Spurious checksum error upon MTL pending Tx queue flush                                                                | . 35 |  |  |
|      | 2.22.8  | Bus error coinciding with start-of-packet corrupts MAC-generated packet transmission .                                 | . 36 |  |  |
|      | 2.22.9  | DMA spurious state upon AXI DMA slave bus error                                                                        | . 36 |  |  |
|      | 2.22.10 | Incorrect DMA transfer state in TEB[2:0] and REB[2:0] on bus error                                                     | . 36 |  |  |
|      | 2.22.11 | MAC fails to identify PTP SYNC and Follow_Up messages with peer delay reserved multicast address in 802.1AS mixed mode | . 37 |  |  |
|      | 2.22.12 | Fatal bus error interrupt not generated when the descriptor posted write is enabled                                    | . 37 |  |  |
|      |         |                                                                                                                        |      |  |  |

ES0539 - Rev 6 page 43/45







| 2.22.14                   | not supported in binary rollover mode |  |  |  |  |  |
|---------------------------|---------------------------------------|--|--|--|--|--|
| Important security notice |                                       |  |  |  |  |  |
| evision history           |                                       |  |  |  |  |  |

ES0539 - Rev 6 page 44/45



#### **IMPORTANT NOTICE - READ CAREFULLY**

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgment.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of purchasers' products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. For additional information about ST trademarks, refer to www.st.com/trademarks. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2025 STMicroelectronics – All rights reserved

ES0539 - Rev 6 page 45/45