# STM32F74xxx STM32F75xxx Errata sheet ## STM32F74xxx and STM32F75xxx device limitations ## **Applicability** This document applies to the part numbers of STM32F74xxx and STM32F75xxx devices listed in *Table 1* and their variants shown in *Table 2*. Section 1 gives a summary and Section 2 a description of / workaround for device limitations, with respect to the device datasheet and reference manual RM0385. **Table 1. Device summary** | Reference | Part numbers | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STM32F74xxx | STM32F745ZG, STM32F745IG, STM32F745ZE, STM32F745IE, STM32F745VG, STM32F746VG, STM32F746ZG, STM32F746IG, STM32F746BG, STM32F746NG, STM32F746NE, STM32F746VE, STM32F746ZE, STM32F746BE, STM32F746NE | | STM32F75xxx | STM32F756VG, STM32F756ZG, STM32F756IG, STM32F756BG, STM32F756NG<br>STM32F750V8, STM32F750Z8, STM32F750N8 | #### Table 2. Device variants | Deference | Silicon revision codes | | |-------------|-------------------------------|-----------------------| | Reference | Device marking <sup>(1)</sup> | REV_ID <sup>(2)</sup> | | STM32F74xxx | Z and 1 | 0x1001 | | STM32F75xxx | Z allu I | | <sup>1.</sup> Refer to the device data sheet for how to identify this code on different types of package. July 2019 ES0290 Rev 7 1/28 <sup>2.</sup> REV\_ID[15:0] bit field of DBGMCU\_IDCODE register. Refer to the reference manual. ## **Contents** | 1 | Sum | mary of | device limitations | . 4 | |---|------|--------------------|-------------------------------------------------------------------------------------------|------| | 2 | Desc | cription ( | of device limitations | . 6 | | | 2.1 | Arm <sup>®</sup> 3 | 2-bit Cortex <sup>®</sup> -M7 core | . 6 | | | | 2.1.1 | Cortex <sup>®</sup> -M7 data corruption when using data cache configured in write-through | 7 | | | 2.2 | System | | . 8 | | | | 2.2.1 | Missed ADC triggers from TIM1/TIM8, TIM2/TIM5/TIM4/TIM6/TRGO of TGRO2 event | | | | | 2.2.2 | Internal noise impacting the ADC accuracy | 8 | | | | 2.2.3 | Wakeup from Standby mode when the back-up SRAM regulator is enabled | 8 | | | | 2.2.4 | Full JTAG configuration without NJTRST pin cannot be used | 9 | | | 2.3 | FMC . | | . 9 | | | | 2.3.1 | Dummy read cycles inserted when reading synchronous memories | 9 | | | | 2.3.2 | Wrong data read from a busy NAND memory | 9 | | | | 2.3.3 | Spurious clock stoppage with continuous clock feature enabled | . 10 | | | | 2.3.4 | Data read might be corrupted when the write FIFO is disabled | . 10 | | | 2.4 | QUADS | SPI | .11 | | | | 2.4.1 | Extra data written in the FIFO at the end of a read transfer | . 11 | | | | 2.4.2 | First nibble of data not written after a dummy phase | . 11 | | | | 2.4.3 | Wrong data from memory-mapped read after an indirect mode operation | . 12 | | | | 2.4.4 | Memory-mapped read operations may fail when timeout counter is enabled. | . 12 | | | 2.5 | ADC . | | 12 | | | | 2.5.1 | ADC sequencer modification during conversion | . 12 | | | 2.6 | DAC . | | 13 | | | | 2.6.1 | DMA underrun flag management | . 13 | | | | 2.6.2 | DMA request not automatically cleared by clearing DMAEN | . 13 | | | 2.7 | LPTIM | | 14 | | | | 2.7.1 | MCU may remain stuck in LPTIM interrupt when entering Stop mode | . 14 | | | 2.8 | RTC . | | | | | - | 2.8.1 | RTC calendar registers are not locked properly | | | | | 2.8.2 | Spurious tamper detection when disabling the tamper channel | | | | | | · | | | | 2.9 | I2C | | 15 | |---|----------|-----------|------------------------------------------------------------------------------------------------------------------------|------| | | | 2.9.1 | Wrong data sampling when data setup time (t <sub>SU;DAT</sub> ) is shorter than one I2C kernel clock period | . 15 | | | | 2.9.2 | Spurious bus error detection in master mode | . 16 | | | | 2.9.3 | 10-bit master mode: new transfer cannot be launched if first part of the address is not acknowledged by the slave | . 16 | | | | 2.9.4 | Last-received byte loss in reload mode | . 16 | | | 2.10 | USART | | 17 | | | | 2.10.1 | Start bit detected too soon when sampling for NACK signal from the smartcard | . 17 | | | | 2.10.2 | Break request can prevent the transmission complete flag (TC) from being set | . 18 | | | | 2.10.3 | nRTS is active while RE or UE = 0 | . 18 | | | 2.11 | SPI/I2S | | 18 | | | | 2.11.1 | I2S slave in PCM short pulse mode sensitive to timing between WS and CK | . 18 | | | | 2.11.2 | BSY bit may stay high at the end of a data transfer in Slave mode | . 19 | | | 2.12 | SDMM | 01 | 20 | | | | 2.12.1 | Wrong CCRCFAIL status after a response without CRC is received | . 20 | | | | 2.12.2 | MMC stream write of less than 8 bytes does not work correctly | . 20 | | | 2.13 | BxCAN | | 21 | | | | 2.13.1 | BxCAN time triggered mode communication not supported | . 21 | | | 2.14 | Etherne | t | 21 | | | | 2.14.1 | Incorrect layer 3 (L3) checksum is inserted in transmitted IPv6 packets without TCP, UDP or ICMP payloads | | | | | 2.14.2 | The Ethernet MAC processes invalid extension headers in the receive IPv6 frames | | | | | 2.14.3 | MAC stuck in the Idle state on receiving the TxFIFO flush command exactly 1 clock cycle after a transmission completes | . 22 | | | | 2.14.4 | Transmit frame data corruption | . 23 | | | | 2.14.5 | Successive write operations to the same register might not be fully taken into account | . 23 | | • | <b>D</b> | | <b>.</b> | 00 | | 3 | Kevis | sion nisi | tory | 26 | ## 1 Summary of device limitations The following table gives a quick references to all documented device limitations of STM32F74xxx and STM32F75xxx 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 | Function | Section | Limitation | Status | |------------------------------------------------------------|---------|------------------------------------------------------------------------------|--------------| | Function Section | | Limitation | Rev. Z and 1 | | Arm <sup>®</sup> 32-bit<br>Cortex <sup>®</sup> -M7<br>core | 2.1.1 | Cortex®-M7 data corruption when using data cache configured in write-through | А | | | 2.2.1 | Missed ADC triggers from TIM1/TIM8, TIM2/TIM5/TIM4/TIM6/TRGO or TGRO2 event | А | | Overte m | 2.2.2 | Internal noise impacting the ADC accuracy | А | | System | 2.2.3 | Wakeup from Standby mode when the back-up SRAM regulator is enabled | А | | | 2.2.4 | Full JTAG configuration without NJTRST pin cannot be used | А | | | 2.3.1 | Dummy read cycles inserted when reading synchronous memories | N | | FMC | 2.3.2 | Wrong data read from a busy NAND memory | А | | | 2.3.3 | Spurious clock stoppage with continuous clock feature enabled | А | | | 2.3.4 | Data read might be corrupted when the write FIFO is disabled | А | | | 2.4.1 | Extra data written in the FIFO at the end of a read transfer | А | | | 2.4.2 | First nibble of data not written after a dummy phase | А | | QUADSPI | 2.4.3 | Wrong data from memory-mapped read after an indirect mode operation | А | | | 2.4.4 | Memory-mapped read operations may fail when timeout counter is enabled. | А | | ADC | 2.5.1 | ADC sequencer modification during conversion | Α | | DAC | 2.6.1 | DMA underrun flag management | А | | DAC | 2.6.2 | DMA request not automatically cleared by clearing DMAEN | Α | | LPTIM | 2.7.1 | MCU may remain stuck in LPTIM interrupt when entering Stop mode | Α | Table 3. Summary of device limitations (continued) | Fatia | Section | I in the state of | Status | |-----------------|---------|------------------------------------------------------------------------------------------------------------------------|--------------| | Function Sectio | | Limitation | Rev. Z and 1 | | RTC | 2.8.1 | RTC calendar registers are not locked properly | Р | | RIC | 2.8.2 | Spurious tamper detection when disabling the tamper channel | N | | | 2.9.1 | Wrong data sampling when data setup time (tSU;DAT) is shorter than one I2C kernel clock period | А | | I2C | 2.9.2 | Spurious bus error detection in master mode | А | | 120 | 2.9.3 | 10-bit master mode: new transfer cannot be launched if first part of the address is not acknowledged by the slave | А | | | 2.9.4 | Last-received byte loss in reload mode | А | | | 2.10.1 | Start bit detected too soon when sampling for NACK signal from the smartcard | N | | USART | 2.10.2 | Break request can prevent the transmission complete flag (TC) from being set | А | | | 2.10.3 | nRTS is active while RE or UE = 0 | А | | SPI/I2S | 2.11.1 | I2S slave in PCM short pulse mode sensitive to timing between WS and CK | А | | | 2.11.2 | BSY bit may stay high at the end of a data transfer in Slave mode | А | | SDMMC1 | 2.12.1 | Wrong CCRCFAIL status after a response without CRC is received | А | | SDIVINICT | 2.12.2 | MMC stream write of less than 8 bytes does not work correctly | Α | | BxCAN | 2.13.1 | BxCAN time triggered mode communication not supported | N | | Ethernet | 2.14.1 | Incorrect layer 3 (L3) checksum is inserted in transmitted IPv6 packets without TCP, UDP or ICMP payloads | Α | | | 2.14.2 | The Ethernet MAC processes invalid extension headers in the received IPv6 frames | N | | | 2.14.3 | MAC stuck in the Idle state on receiving the TxFIFO flush command exactly 1 clock cycle after a transmission completes | Α | | | 2.14.4 | Transmit frame data corruption | А | | | 2.14.5 | Successive write operations to the same register might not be fully taken into account | А | ES0290 Rev 7 5/28 ## 2 Description of device limitations The following sections describe limitations of the applicable devices with $Arm^{\otimes(a)}$ core and provide workarounds if available. They are grouped by device functions. ## 2.1 Arm<sup>®</sup> 32-bit Cortex<sup>®</sup>-M7 core An errata notice of the STM32F74xxx and STM32F75xxx core is available from http://infocenter.arm.com. All the described limitations are minor and related to the revision r0p1 of the Cortex<sup>®</sup>-M7 core. Refer to: - Arm processor Cortex<sup>®</sup>-M7 (AT610) and Cortex<sup>®</sup>-M7 with FPU (AT611) software developer errata notice - Arm embedded trace macrocell CoreSight ETM-M7 (TM975) software developer errata notice *Table 4* summarizes these limitations and their implications on the behavior of STM32F74xxx and STM32F75xxx devices. Table 4. Cortex®-M7 core limitations and impact on microcontroller behavior | Arm<br>ID | Arm category | Impact on STM32F74xxx and STM32F75xxx devices | |-----------|--------------|-----------------------------------------------| | 837070 | Cat B | Minor | | 834922 | Cat B | Minor | | 838169 | Cat B (rare) | Minor | | 839269 | Cat C | Minor | | 839169 | Cat C | Minor | | 837069 | Cat C | Minor | | 834971 | Cat C | Minor | | 834924 | Cat C | Minor | | 834923 | Cat C | Minor | | 833872 | Cat C | Minor | | 830969 | Cat C | Minor | a. Arm is a registered trademark of Arm Limited (or its subsidiaries) in the US and/or elsewhere. ## 2.1.1 Cortex<sup>®</sup>-M7 data corruption when using data cache configured in write-through #### Description This limitation is registered under Arm<sup>®</sup> ID number 1259864 and classified into "Category A". If a particular sequence of stores and loads is performed to write-through memory, and some timing-based internal conditions are met, then a load might not get the last data stored to that address. This erratum only occurs if the loads and stores are to write-through memory. This is due to any of the following: - The MPU has been programmed to set this address as write-through. - The default memory map is being used and this address is write-through in that map. - The memory is cacheable, and the CM7\_CACR.FORCEWT bit is set. - The memory is cacheable, shared, and the CM7\_CACR.SIWT bit is set. The following sequence is required for this erratum to occur: - 1. The address of interest must be in the cache. - 2. A write-through store to the same doubleword as the address of interest. - One of the following: - A linefill is started (to a different cacheline to the address of interest) that allocates to the same set as the address of interest. - An ECC error. - A cache maintenance operation without a following DSB. - 4. A store to the address of interest. - 5. A load from the address of interest. If certain specific timing conditions are met, the load gets the data from the first store, or from what was in the cache at the start of the sequence instead of the data from the second store. The effect of this erratum is that load operations can return incorrect data. #### Workaround There is no direct workaround for this erratum. Where possible, Arm<sup>®</sup> recommends the use of the MPU to change the attributes on any write-through memory to write-back memory. If this is not possible, it might be necessary to disable the cache for sections of code that access write-through memory. ES0290 Rev 7 7/28 ## 2.2 System ## 2.2.1 Missed ADC triggers from TIM1/TIM8, TIM2/TIM5/TIM4/TIM6/TRGO or TGRO2 event #### **Description** The ADC external triggers for regular and injected channels by the TIM1, TIM8, TIM2, TIM5, TIM4 and TIM6 TRGO or TRGO2 events are missed at the following conditions: - Prescaler enabled on the PCLK2 clock. - TIMxCLK = 2xADCCLK and the master mode selection (MMS or MMS2 bits in the TIMx\_CR2 timer register) as reset, update, or compare pulse configuration. - TIMxCLK = 4xADCCLK. #### Workarounds - For TIM1 and TIM8 TRGO or TRGO 2 events: select the trigger detection on both the rising and falling edges. The EXTEN[1:0] or JEXTEN[1:0] bits must be set to 0x11 in the ADC CR2 register. - For TIM2/TIM4/TIM5/TIM6/ TRGO or TGRO2 events: enable the DAC peripheral clock in the RCC\_APB1ENR register. ## 2.2.2 Internal noise impacting the ADC accuracy #### **Description** An internal noise generated on V<sub>DD</sub> supplies and propagated internally may impact the ADC accuracy. This noise is always active whatever the power mode of the MCU (Run or Sleep). #### Workaround To adapt the accuracy level to the application requirements, set one of the following options: - Option1 - Set the ADCDC1 bit in the PWR\_CR register. - Option2 Set the corresponding ADCxDC2 bit in the SYSCFG\_PMC register. Only one option can be set at a time. For more details on option1 and option2 mechanisms, refer to AN4073 ## 2.2.3 Wakeup from Standby mode when the back-up SRAM regulator is enabled #### **Description** When writing to the PWR\_CSR1 register to enable or disable the back-up SRAM regulator, if the EIWUP bit is overwritten 0, the RTC wakeup event (alarm, RTC Tamper, RTC TimeStamp or RTC wakeup time) does not wake up the system from Standby mode. #### Workaround For each write access on the PWR\_CSR1 register to enable or disable the back-up SRAM regulator, the EIWKUP bit must be set to 1 in order to enable a wakeup from Standby mode using RTC events. ### 2.2.4 Full JTAG configuration without NJTRST pin cannot be used #### **Description** When using the JTAG debug port in debug mode, the connection with the debugger is lost if the NJTRST pin (PB4) is used as a GPIO. Only the 4-wire JTAG port configuration is impacted. #### Workaround Use the SWD debug port instead of the full 4-wire JTAG port. ## 2.3 FMC ## 2.3.1 Dummy read cycles inserted when reading synchronous memories ## **Description** When performing a burst read access from a synchronous memory, two dummy read accesses are performed at the end of the burst cycle whatever the type of burst access. The extra data values read are not used by the FMC and there is no functional failure. #### Workaround None. ### 2.3.2 Wrong data read from a busy NAND memory #### **Description** When a read command is issued to the NAND memory, the R/B signal gets activated upon the de-assertion of the chip select. If a read transaction is pending, the NAND controller might not detect the R/B signal (connected to NWAIT) previously asserted and sample a wrong data. This problem occurs only when the MEMSET timing is configured to 0x00 or when ATTHOLD timing is configured to 0x00 or 0x01. #### Workaround Either configure MEMSET timing to a value greater than 0x00 or ATTHOLD timing to a value greater than 0x01. ## 2.3.3 Spurious clock stoppage with continuous clock feature enabled ## **Description** With the continuous clock feature enabled, the FMC CLK clock may spuriously stop when: - the FMC CLK clock is divided by 2, and - an FMC bank set as 32-bit is accessed with a byte access. division ratio set to 2, the FMC\_CLK clock may spuriously stop upon an Note: With static memories, a spuriously stopped clock can be restarted by issuing a synchronous transaction or any asynchronous transaction different from a byte access on 32-bit data bus width. #### Workaround With the continuous clock feature enabled, do not set the FMC\_CLK clock division ratio to 2 when accessing 32-bit asynchronous memories with byte access. ## 2.3.4 Data read might be corrupted when the write FIFO is disabled #### **Description** When the write FIFO is disabled, the FIFO empty event is generated for every write access. During a write access, if a new read access occurs, the FMC grants the read access and waits till the FIFO gets empty. If another read access occurs in a very short window (one cycle the FIFO empty event), the returned data are corrupted. This issue occurs only when the write FIFO is disabled (the WFDIS bit in the FMC\_BCR1 register is set). #### Workaround Enable the write FIFO. 577 ## 2.4 QUADSPI ### 2.4.1 Extra data written in the FIFO at the end of a read transfer #### **Description** When all the conditions listed below are gathered: - QUADSPI is used in indirect mode. - QUADSPI clock is AHB/2 (PRESCALER = 0x01 in the QUADSPI\_CR). - QUADSPI is in quad mode (DMODE = 0b11 in the QUADSPI\_CCR). - QUADSPI is in DDR mode (DDRM = 0b1 in the QUADSPI\_CCR). - A data is read in the instant when the FIFO buffer gets full at the end of a read transfer, an extra data is unduly written in the FIFO buffer. #### Workarounds Apply one of the following measures: - Read out the extra data until the BUSY flag goes low, then discard the extra data. - After reading out all the expected received data, set the ABORT bit of the QUADSPI\_CR register to flush FIFO and keep the BUSY flag low. The last register configuration is kept.. ## 2.4.2 First nibble of data not written after a dummy phase #### **Description** The first nibble of data to be written to the external Flash memory is lost when the following conditions are met: - The QUADSPI is used in the indirect write mode - At least one dummy cycle is used #### Workaround Use alternate bytes instead of dummy phase to add latency between the address phase and the data phase. This works only if the number of dummy cycles to substitute corresponds to a multiple of eight bits of data. #### Example: - To substitute one dummy cycle, send one alternate byte (only possible in DDR mode with four data lines). - To substitute two dummy cycles, send one alternate byte in SDR mode with four data lines - To substitute four dummy cycles, send two alternate bytes in SDR mode with four data lines, or one alternate byte in SDR mode with two data lines. - To substitute eight dummy cycles, send one alternate byte in SDR mode with one data line. ES0290 Rev 7 11/28 ## 2.4.3 Wrong data from memory-mapped read after an indirect mode operation ### **Description** The first memory-mapped read in indirect mode can yield wrong data if the QUADSPI peripheral enters memorymapped mode with bits ADDRESS[1:0] of the QUADSPI\_AR register both set. #### Workaround Before entering memory-mapped mode, apply the following measure, depending on access mode: - Indirect read mode: clear the QUADSPI\_AR register then issue an abort request to stop reading and to clear the BUSY bit. - Indirect write mode: clear the QUADSPI AR register. **Caution:** The QUADSPI\_DR register must not be written after clearing the QUADSPI\_AR register. ## 2.4.4 Memory-mapped read operations may fail when timeout counter is enabled. ## **Description** In memory-mapped mode with the timeout counter enabled (by setting the TCEN bit of the QUADSPI\_CR register), the QUADSPI peripheral may hang and the memory-mapped read operations fail. This occurs if the timeout flag TOF is set at the same clock edge as a new memory-mapped read request.. #### Workaround Disable the timeout counter. To raise the chip select, perform an abort at the end of each memory-mapped read operation. ## 2.5 ADC ### 2.5.1 ADC sequencer modification during conversion #### **Description** If an ADC conversion is started by software (writing the SWSTART bit), and if the ADC\_SQRx or ADC\_JSQRx registers are modified during the conversion, the current conversion is reset and the ADC does not restart a new conversion sequence automatically. If an ADC conversion is started by hardware trigger, this limitation does not apply. The ADC restarts a new conversion sequence automatically. #### Workaround When an ADC conversion sequence is started by software, a new conversion sequence can be restarted only by setting the SWSTART bit in the ADC\_CR2 register. ### 2.6 DAC ## 2.6.1 DMA underrun flag management ## **Description** If the DMA is not fast enough to input the next digital data to the DAC, as a consequence, the same digital data is converted twice. In these conditions, the DMAUDR flag is set, which usually leads to disable the DMA data transfers. This is not the case: the DMA is not disabled by DMAUDR=1, and it keeps serving the DAC. #### Workaround To disable the DAC DMA stream, reset the EN bit (corresponding to the DAC DMA stream) in the DMA SxCR register. ## 2.6.2 DMA request not automatically cleared by clearing DMAEN #### **Description** Upon an attempt to stop a DMA-to-DAC transfer, the DMA request is not automatically cleared by clearing the DAC channel bit of the DAC\_CR register (DMAEN) or by disabling the DAC clock. If the application stops the DAC operation while the DMA request is pending, the request remains pending while the DAC is reinitialized and restarted, with the risk that a spurious DMA request is serviced as soon as the DAC is enabled again. #### Workaround Apply the following sequence to stop the current DMA-to-DAC transfer and restart the DAC:: - Check if DMAUDR bit is set in DAC\_CR. - 2. Clear the DAC channel DMAEN bit. - 3. Disable the DAC clock. - 4. Reconfigure the DAC, DMA and the triggers. - 5. Restart the application. ES0290 Rev 7 13/28 ## 2.7 LPTIM ## 2.7.1 MCU may remain stuck in LPTIM interrupt when entering Stop mode #### **Description** This limitation occurs when disabling the low power timer (LPTIM). When the firmware clears the LPTIM\_CR.ENABLE bit within a small time window around one LPTIM interrupt occurrence, then the LPTIM interrupt signal used to wake up the MCU from Stop mode may be frozen in active state. Consequently, when trying to enter Stop mode, this limitation prevents the MCU 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 LPTIMx\_CR register. Instead, reset the whole LPTIMx peripheral via the RCC controller by setting and resetting its respective LPTIMxRST bit in the RCC\_APByRSTRz register. #### 2.8 RTC ## 2.8.1 RTC calendar registers are not locked properly #### **Description** When reading the calendar registers with BYPSHAD = 0, the RTC\_TR and RTC\_DR registers may not be locked after reading the RTC\_SSR register. This happens if the read operation is initiated one APB clock period before the shadow registers are updated. This can result in a non-consistency of the three registers. Similarly, the RTC\_DR register can be updated after reading the RTC\_TR register instead of being locked. #### Workaround Apply one of the following measures: - Use BYPSHAD = 1 mode (bypass shadow registers), or - 2. If BYPSHAD = 0, read the RTC\_SSR register again after reading the RTC\_SSR, RTC\_TR, RTC\_DR registers to confirm that RTC\_SSR is still the same, otherwise read the values again. ## 2.8.2 Spurious tamper detection when disabling the tamper channel ## **Description** If the tamper detection is configured for a detection on the falling edge event (TAMPFLT=00 and TAMPxTRG=1) and if the tamper event detection is disabled when the tamper pin is at high level, a false tamper event is detected. #### Workaround None. ### 2.9 I2C ## 2.9.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 MCU 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 slave 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 I2C-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. 5 ES0290 Rev 7 15/28 ## 2.9.2 Spurious bus error detection in master mode #### **Description** In master 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 master mode and any such transfer continues normally. #### Workaround If a bus error interrupt is generated in master mode, the BERR flag must be cleared by software. No other action is required and the ongoing transfer can be handled normally. ## 2.9.3 10-bit master mode: new transfer cannot be launched if first part of the address is not acknowledged by the slave #### Description An I<sup>2</sup>C-bus master generates STOP condition upon non-acknowledge of I<sup>2</sup>C address that it sends. This applies to 7-bit address as well as to each byte of 10-bit address. When the MCU set as I<sup>2</sup>C-bus master transmits a 10-bit address of which the first byte (5-bit header + 2 MSBs of the address + direction bit) is not acknowledged, the MCU duly generates STOP condition but it then cannot start any new I<sup>2</sup>C-bus transfer. In this spurious state, the NACKF flag of the I2C\_ISR register and the START bit of the I2C\_CR2 register are both set, while the START bit should normally be cleared. #### Workaround In 10-bit-address master mode, if both NACKF flag and START bit get simultaneously set, proceed as follows: - 1. Wait for the STOP condition detection (STOPF = 1 in I2C\_ISR register). - 2. Disable the I2C peripheral. - 3. Wait for a minimum of three APB cycles. - Enable the I2C peripheral again. ## 2.9.4 Last-received byte loss in reload mode #### **Description** If in master receiver mode or slave receive mode with SBC = 1 the following conditions are all met: - I2C-bus stretching is enabled (NOSTRETCH = 0) - RELOAD bit of the I2C\_CR2 register is set - NBYTES bitfield of the I2C\_CR2 register is set to N greater than 1 - byte N is received on the I2C-bus, raising the TCR flag - N 1 byte is not yet read out from the data register at the instant TCR is raised, then the SCL line is pulled low (I2C-bus clock stretching) and the transfer of the byte N from the shift register to the data register inhibited until the byte N-1 is read and NBYTES bitfield reloaded with a new value, the latter of which also clears the TCR flag. As a consequence, the software cannot get the byte N and use its content before setting the new value into the NBYTES field. For I2C instances with independent clock, the last-received data is definitively lost (never transferred from the shift register to the data register) if the data N - 1 is read within four APB clock cycles preceding the receipt of the last data bit of byte N and thus the TCR flag raising. Refer to the product reference manual or datasheet for the I2C implementation table. #### Workaround - In master mode or in slave mode with SBC = 1, use the reload mode with NBYTES = 1. - In master receiver mode, if the number of bytes to transfer is greater than 255 bytes, do not use the reload mode. Instead, split the transfer into sections not exceeding 255 bytes and separate them with repeated START conditions. - Make sure, for example through the use of DMA, that the byte N 1 is always read before the TCR flag is raised. Specifically for I2C instances with independent clock, make sure that it is always read earlier than four APB clock cycles before the receipt of the last data bit of byte N and thus the TCR flag raising. The last workaround in the list must be evaluated carefully for each application as the timing depends on factors such as the bus speed, interrupt management, software processing latencies, and DMA channel priority. ### 2.10 **USART** ## 2.10.1 Start bit detected too soon when sampling for NACK signal from the smartcard #### **Description** In the ISO7816, when a character parity error is incorrect, the smartcard receiver shall transmit a NACK error signal at (10.5 +/- 0.2) etu after the character Start bit falling edge. In this case, the USART transmitter should be able to detect correctly the NACK signal by sampling at (11.0 +/-0.2) etu after the character Start bit falling edge. The USART peripheral used in smartcard mode does not respect the (11 +/-0.2) etu timing, and when the NACK falling edge arrives at 10.68 etu or later, the USART might misinterpret this transition as a Start bit even if the NACK is correctly detected. ### Workaround None. ES0290 Rev 7 17/28 ## 2.10.2 Break request can prevent the transmission complete flag (TC) from being set #### **Description** After the end of transmission of a data (D1), the transmission complete (TC) flag is not set in the following conditions: - CTS hardware flow control is enabled. - D1 is being transmitted. - A break transfer is requested before the end of D1 transfer. - nCTS is de-asserted before the end of transfer of D1. #### Workaround If the application needs to detect the end of transfer of the data, the break request must be done after making sure that the TC flag is set. #### 2.10.3 nRTS is active while RE or UE = 0 #### **Description** The nRTS line is driven low as soon as the RTSE bit is set, even if the USART is disabled (UE = 0) or the receiver is disabled (RE = 0), that is, not ready to receive data. #### Workaround Upon setting the UE and RE bits, configure the I/O used for nRTS into alternate function. ### 2.11 SPI/I2S ## 2.11.1 I2S slave in PCM short pulse mode sensitive to timing between WS and CK #### **Description** When the device is configured in I2S slave PCM short frame mode (I2SMOD = 1, I2SCFG[1:0] = 00 or 01, I2SSTD[1:0] = 11, PCMSYNC = 0), with the asynchronous start disabled (ASTREN = 0), then if the master does not respect the WS hold time versus clock, the data transmitted and received by the device get desynchronized (shifted by one bit). This results in discarding two frames instead of one, irrespectively of the clock polarity. #### Workaround Use legacy mode (ASTERN = 1), while ensuring a perfect synchronization between the master and the slave. ## 2.11.2 BSY bit may stay high at the end of a data transfer in Slave mode ## **Description** The BSY flag may sporadically remain high at the end of a data transfer in slave mode. This occurs upon coincidence of internal CPU clock and external SCK clock provided by master. In such an event, if the software only relies on BSY flag to detect the end of SPI slave data transaction (for example to enter low-power mode or to change data line direction in half-duplex bidirectional mode), the detection fails. As a conclusion, the BSY flag is unreliable for detecting the end of data transactions. #### Workaround Depending on SPI operating mode, use the following means for detecting the end of transaction: - When NSS hardware management is applied and NSS signal is provided by master, use NSS flag. - In SPI receiving mode, use the corresponding RXNE event flag. - In SPI transmit-only mode, use the BSY flag in conjunction with a timeout expiry event. Set the timeout such as to exceed the expected duration of the last data frame and start it upon TXE event that occurs with the second bit of the last data frame. The end of the transaction corresponds to either the BSY flag becoming low or the timeout expiry, whichever happens first. Prefer one of the first two measures to the third as they are simpler and less constraining. Alternatively, apply the following sequence to ensure reliable operation of the BSY flag in SPI transmit mode: - 1.Write last data to data register - 2. Poll the TXE flag until it becomes high, which occurs with the second bit of the data frame transfer - 3. Disable SPI by clearing the SPE bit mandatorily before the end of the frame transfer - 4. Poll the BSY bit until it becomes low, which signals the end of transfer Note: The alternative method can only be used with relatively fast CPU speeds versus relatively slow SPI clocks or/and long last data frames. The faster is the software execution, the shorter can be the duration of the last data frame. ES0290 Rev 7 19/28 ## 2.12 SDMMC1 ## 2.12.1 Wrong CCRCFAIL status after a response without CRC is received #### Description The CRC is calculated even if the response to a command does not contain any CRC field. As a consequence, after the SDIO command IO\_SEND\_OP\_COND (CDM5) is sent, the CCRCFAIL bit of the SDIO STA register is set. #### Workaround The CCRCFAIL bit in the SDIO\_STA register must be ignored by the software. CCRCFAIL must be cleared by setting the CCRCFAILC bit in the SDIO\_ICR register after reception of the response to the CMD5 command. ## 2.12.2 MMC stream write of less than 8 bytes does not work correctly #### Description When the SDMMC host starts a stream write (WRITE\_DAT\_UNTIL\_STOP CMD20), the number of bytes to transfer is not known by the card. The card writes data from the host until a STOP\_TRANSMISSION (CMD12) command is received. Use the WAITRESP value equal to "00" to indicate to SDMMC CPSM that no response is expected. The WAITPEND bit 9 of the SDMMC\_CMD register is set to synchronize the sending of the STOP\_TRANSMISSION (CMD12) command with the data flow. When WAITPEND is set, the transmission of this command stays pending until 50 data bits (including the Stop bit) remain to transmit. For a stream write of less than 8 bytes, the STOP\_TRANSMISSION (CMD12) command must be started before the data transfer starts. Instead of this, the data write and the command sending are started simultaneously. It implies that when less than 8 bytes must be transmitted, (8 - DATALENGTH) bytes are programmed to 0xFF in the card after the last byte programmed (where DATALENGTH is the number of data bytes to be transferred). #### Workaround Do not use stream write WRITE\_DAT\_UNTIL\_STOP (CMD20) with a DATALENGTH less than 8 bytes. Use set block length (SET\_BLOCKLEN: CMD16) followed by the single block write command (WRITE\_BLOCK\_CMD24) instead of the stream write (CMD20) with the desired block length. ## 2.13 **BxCAN** ## 2.13.1 BxCAN time triggered mode communication not supported #### **Description** The time triggered communication mode described in the reference manual is not supported. As a result the time stamp values are not available. The TTCM bit of the CANMCR register must be kept cleared (time-triggered communication mode disabled). #### Workaround None. #### 2.14 Ethernet ## 2.14.1 Incorrect layer 3 (L3) checksum is inserted in transmitted IPv6 packets without TCP, UDP or ICMP payloads ### **Description** The application provides the per-frame control to instruct the MAC to insert the L3 checksums for TCP, UDP and ICMP packets. When an automatic checksum insertion is enabled and the input packet is an IPv6 packet without the TCP, UDP or ICMP payload, then the MAC may incorrectly insert a checksum into the packet. For IPv6 packets without a TCP, UDP or ICMP payload, the MAC core considers the next header (NH) field as the extension header and continues to parse the extension header. Sometimes, the payload data in such packets matches the NH field for TCP, UDP or ICMP and, as a result, the MAC core inserts a checksum. ### Workaround When the IPv6 packets have a TCP, UDP or ICMP payload, enable checksum insertion for transmit frames, or bypass checksum insertion by using the CIC (checksum insertion control) bits in TDES0 (bits 23:22). ## 2.14.2 The Ethernet MAC processes invalid extension headers in the received IPv6 frames ## **Description** In the IPv6 frames, there can be zero or some extension headers preceding the actual IP payload. The Ethernet MAC processes the following extension headers defined in the IPv6 protocol: hop-by-hop options header, routing header and destination options header. All the extension headers, except the hop-by-hop extension header, can be present multiple times and in any order before the actual IP payload. The hop-by-hop extension header, if present, has to come immediately after the IPv6's main header. The Ethernet MAC processes all (valid or invalid) extension headers including the hop-by-hop extension headers that are present after the first extension header. For this reason, the GMAC core accepts IPv6 frames with invalid hop-by-hop extension headers. As a ES0290 Rev 7 21/28 consequence, it accepts any IP payload as valid IPv6 frames with TCP, UDP or ICMP payload, and then incorrectly update the receive status of the corresponding frame. #### Workaround None. ## 2.14.3 MAC stuck in the Idle state on receiving the TxFIFO flush command exactly 1 clock cycle after a transmission completes #### **Description** When the software issues a TxFIFO flush command, the transfer of frame data stops (even in the middle of a frame transfer). The TxFIFO read controller goes into the idle state (TFRS=00 in ETH\_MACDBGR) and then resumes its normal operation. However, if the TxFIFO read controller receives the TxFIFO flush command exactly one clock cycle after receiving the status from the MAC, the controller remains stuck in the Idle state and stops transmitting frames from the TxFIFO. The system can recover from this state only with a reset (e.g. a soft reset). #### Workaround Do not use the TxFIFO flush feature. If TXFIFO flush is really needed, wait until the TxFIFO is empty prior to using the TxFIFO flush command. **47**/ ## 2.14.4 Transmit frame data corruption The frame data is corrupted when the TxFIFO is repeatedly transitioning from non empty to empty and then back to non empty. #### **Description** The frame data may get corrupted when the TxFIFO is repeatedly transitioning from non empty to empty for a very short period, and then from empty to non empty, without causing an underflow. This transitioning from non empty to empty and back to non empty happens when the rate at which the data is being written to the TxFIFO is almost equal to or a little less than the rate at which the data is being read. This corruption cannot be detected by the receiver when the CRC is inserted by the MAC, as the corrupted data is used for the CRC computation. #### Workaround Use the Store-and-Forward mode: TSF=1 (bit 21 in ETH\_DMAOMR). In this mode, the data is transmitted only when the whole packet is available in the TxFIFO. ## 2.14.5 Successive write operations to the same register might not be fully taken into account #### **Description** A write to a register might not be fully taken into account if a previous write to the same register is performed within a time period of four TX\_CLK/RX\_CLK clock cycles. When this error occurs, reading the register returns the most recently written value, but the Ethernet MAC continues to operate as if the latest write operation never occurred. See *Table 5: Impacted registers and bits* for the registers and bits impacted by this limitation. Register name Bit number Bit name DMA registers ETH DMABMR 7 **EDFE** 26 **DTCEFD** 25 **RSF** 20 FTF ETH DMAOMR 7 **FEF** 6 **FUGF** 4:3 **RTC GMAC** registers Table 5. Impacted registers and bits ES0290 Rev 7 23/28 Table 5. Impacted registers and bits (continued) | Register name | Bit number | Bit name | |-----------------|------------|-----------------------------| | | 25 | CSTF | | | 23 | WD | | | 22 | JD | | | 19:17 | IFG | | | 16 | CSD | | | 14 | FES | | | 13 | ROD | | ETIL MACOR | 12 | LM | | ETH_MACCR - | 11 | DM | | | 10 | IPCO | | | 9 | RD | | | 7 | APCS | | | 6:5 | BL | | | 4 | DC | | | 3 | TE | | | 2 | RE | | ETH_MACFFR | - | MAC frame filter register | | ETH_MACHTHR | 31:0 | Hash Table High Register | | ETH_MACHTLR | 31:0 | Hash Table Low Register | | | 31:16 | PT | | | 7 | ZQPD | | | 5:4 | PLT | | ETH_MACFCR | 3 | UPFD | | | 2 | RFCE | | | 1 | TFCE | | | 0 | FCB/BPA | | ETIL MACVI ANTD | 16 | VLANTC | | ETH_MACVLANTR - | 15:0 | VLANTI | | ETH_MACRWUFFR | - | all remote wakeup registers | | | 31 | WFFRPR | | | 9 | GU | | ETH_MACPMTCSR | 2 | WFE | | | 1 | MPE | | | 0 | PD | | ETH_MACA0HR | - | MAC address 0 high register | Table 5. Impacted registers and bits (continued) | Register name | Bit number | Bit name | |--------------------------------|------------|-----------------------------| | ETH_MACA0LR | - | MAC address 0 low register | | ETH_MACA1HR | - | MAC address 1 high register | | ETH_MACA1LR | - | MAC address 1 low register | | ETH_MACA2HR | - | MAC address 2 high register | | ETH_MACA2LR | - | MAC address 2 low register | | ETH_MACA3HR | - | MAC address 3 high register | | ETH_MACA3LR | - | MAC address 3 low register | | IEEE 1588 time stamp registers | | | | | 18 | TSPFFMAE | | | 17:16 | TSCNT | | | 15 | TSSMRME | | | 14 | TSSEME | | | 13 | TSSIPV4FE | | | 12 | TSSIPV6FE | | | 11 | TSSPTPOEFE | | ETH_PTPTSCR | 10 | TSPTPPSV2E | | | 9 | TSSSR | | | 8 | TSSARFE | | | 5 | TSARU | | | 3 | TSSTU | | | 2 | TSSTI | | | 1 | TSFCU | | | 0 | TSE | #### Workarounds Two workarounds can be applicable: - Ensure a delay of four TX\_CLK/RX\_CLK clock cycles between the successive write operations to the same register. - Make several successive write operations without delay, then read the register when all the operations are complete, and finally reprogram it after a delay of four TX\_CLK/RX\_CLK clock cycles. ## 3 Revision history **Table 6. Document revision history** | Date | Revision | Changes | | |-------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 19-Jan-2015 | 1 | Initial release. | | | 26-May-2015 | 2 | Updated Section 2.12: SDMMC1 removing limitation: Section: SDIO interrupt period not correctly handled when 4 data lines are selected. Section: Wait for response bits "10" configuration does not work correctly. Added Section 2.10: USART: Section 2.10: USART: Section 2.10: Start bit detected too soon when sampling for NACK signal from the smartcard. Section 2.10: Break request can prevent the transmission complete flag (TC) from being set. Section 2.10: RRTS is active while RE or UE = 0. Updated Section 2.1: Cortex®-M7 data corruption when using data cache configured in write-through removing: Section: Extra current consumption in Standby mode when PC13 or PI8 pins are left floating. Section: Extra consumption in Standby mode when wakeup pins configured in falling edge. Section: Standby mode entry. Section: Standby mode entry. Section: Bypass regulator mode forcing all wakeup pins in input mode. Section: ADC external triggers unavailability Section: User option byte update when RDP level 1 is active and BOOT pin is high Updated Section 2.2:1: Missed ADC triggers from TIM1/TIM8, TIM2/TIM5/TIM4/TIM6/TRGO or TGRO2 event titles and description. Updated the whole document: Changing revision A into the revision Z. Updating with STM32F75xxx and STM32F74xxx. Updated Table 2: Device variants adding STM32F745xx RPNs. Removed "NAND/PCCard transaction and wait timing" limitation. Added Section 2.1: Arm® 32-bit Cortex®-M7 core. | | | 07-Jan-2016 | 3 | Added limitations: - Section 2.2.3: Wakeup from Standby mode when the back-up SRAM regulator is enabled. in System limitation section. - Section 2.11.1: I2S slave in PCM short pulse mode sensitive to timing between WS and CK in I2S limitation section. - Section 2.8.2: Spurious tamper detection when disabling the tamper channel in I2C limitation section. - Section 2.3.2: Wrong data read from a busy NAND memory and | | | | | Section 2.3.2: Wrong data read from a busy NAND memory and Section 2.3.3: Spurious clock stoppage with continuous clock feature enabled in FMC limitation section. | | Table 6. Document revision history (continued) | Date | Revision | Changes | |-------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 24-Nov-2016 | 4 | <ul> <li>I2C2 limitation:</li> <li>Added Section 2.9.3: 10-bit master mode: new transfer cannot be launched if first part of the address is not acknowledged by the slave.</li> <li>QUADSPI limitations:</li> <li>Added Section 2.4.2: First nibble of data not written after a dummy phase.</li> <li>Added Section 2.4.3: Wrong data from memory-mapped read after an indirect mode operation.</li> </ul> | | 18-May-2017 | 5 | Updated whole document in line with the new errata sheet structure. FMC limitation: - Added Section 2.3.4: Data read might be corrupted when the write FIFO is disabled. QUADSPI limitation: - Updated Section 2.4.2: First nibble of data not written after a dummy phase. | | 25-Jun-2018 | 6 | Updated Table 1: Device summary adding STM32F750x8 part numbers. Added Revision 1: - Updated Table 2: Device variants. - Updated Table 3: Summary of device limitations QUADSPI limitation: - Added Section 2.4.4: Memory-mapped read operations may fail when timeout counter is enabled I2C limitations: - Added Section 2.9.4: Last-received byte loss in reload mode. - Updated limitations in line with I2C2 errata sheet. FMC limitations: - Updated Section 2.3.1: Dummy read cycles inserted when reading synchronous memories. - Updated Section 2.3.2: Wrong data read from a busy NAND memory. - Updated Section 2.3.3: Spurious clock stoppage with continuous clock feature enabled. - Updated Section 2.3.4: Data read might be corrupted when the write FIFO is disabled. RTC limitations: - Added Section 2.8.1: RTC calendar registers are not locked properly. LPTIM limitation: - Added Section 2.7.1: MCU may remain stuck in LPTIM interrupt when entering Stop mode. SPI/I2S limitation: - Updated Section 2.11.2: BSY bit may stay high at the end of a data transfer in Slave mode. | | 18-Jul-2019 | 7 | Added: - Section 2.1.1: Cortex <sup>®</sup> -M7 data corruption when using data cache configured in write-through. - Section 2.2.4: Full JTAG configuration without NJTRST pin cannot be used. | #### **IMPORTANT NOTICE - PLEASE 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 acknowledgement. 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, please refer to <a href="www.st.com/trademarks">www.st.com/trademarks</a>. 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. © 2019 STMicroelectronics – All rights reserved